Hi there
I'm wondering how big the bone count can influence performance
In my case I have to choose if I want to give the 4 main characters 10 fingers or only 4 (connecting the 4 fingers together + the thumb)
Simply for the look I would love to have separate fingers but I have to admit that they would only be necessary for some occasions like casting spells and maybe cutscenes.
Of course this question is based on a case with limited resources like the iphone or something where you actually don't have that much headroom performance wise
Replies
in the end it always comes down to optimizing along you go. But typically removing stuff is easier than adding, I'd think (on the other hand it's wasting money if you remove). Also keep in mind do you actually see those fingers? Are the characters that big on screen. Do they move that slow/detailed that one could realize the individual fingers?
Basically if you have a character with 80 bones and 100 animations each with an average of 3 animated components per bone (I'm making these numbers up, may not be realistic, but think of an animated component as any "translate" or "rotate" value on XYZ, this is the data you will have store for animations), then your character anim set will take up some amount of memory equivalent 80*100*3 = 24000.
Now if you have 100 bones (that's 25% more bones than before), and the same 100 animations, with the same average of 3 animated components per bone, you may now have a memory equivalent of 100*100*3 = 30000, which is 25% more animation data to store, not insignificant.
Obviously if the extra bones you're adding don't get animated often, then it's not as much of an issue, but at that point it might be worth questioning why you're adding them at all if they're not really needed
In terms of skinning and performance I don't think it's really that much of an issue on most hardware, but I'm not sure about iPhone or something. I imagine it might have more impact there.
the difference would be (if 4 main characters are on screen)
4(player) * 2(hands) * 3(additional finger) * 2 (bones per finger) = 48 bones more in a worst case (maybe there are less main chars)
Seems I will need to test it anyway but would be great to have an idea of the performance needed to calculate one-bone-more
And just to mention it, I'm using unity as engine
As for the number of keys chunking up the size of the animation there are advantages to going key per frame. I think it allows you to remove any kind of key/curve interpolation your engine might have to do, which might not be that much of a performance boost but it can take away a lot of the headaches of "why don't my curves match?". Also if you budget key perframe and are able to interpret curves accurately and for cheaper you come in under budget, win for you!
Some animation systems (like Granny3D) allow you to adjust the bone influence on the fly making it really easy to see what the advantages are and how it looks at the different levels.
I'm working now with separate fingers but be able to export only 1 finger + thumb if needed. I don't need any complex finger animations so animating them shouldn't cost that much extra time.
Unity seems to have some strange animation handling anyway. I can apply a animations with additional and missing bones (!!) to my current character version.
Not that I'm going to use that but might be, that unity is doing some optimization in the background already?!
I'm now able to jump between both finger versions with a few minutes of reexporting .. I think thats fine.