I am loading an animated model as a GLB file with four different animations made in Blender.
When I preview the model in model-viewer : Model Viewer, everything shows up and works fine.
When I import the model into Playcanvas’s Editor, there are no console errors.
If I try to preview the model (selecting the Model/Source file) in model-viewer through Playcanvas, it loads properly and I can select each animation and verify they are fine.
However, if I select an individual animation (e.g. Idle.glb) it shows up broken in model-viewer, with meshes, materials, etc all zero. Same occurs on launching the game.
@slimbuck@mvaligursky : This is not limited to a single model. On a fresh project, the models which were previously working, have also stopped working.
Can you please let us know if there was some very recent change to the UI/GLB import process?
Happy to add you to a test project with the models present.
Thanks for getting back @slimbuck . I have added you to the test project I created last night.
There is a Readme.md (Type:Text) which lists all the steps to replicate the issue.
Please let me know if you need any additional info.
We are using artist services to provide the assets, so if you have a specific question for them, I am happy to relay it to them.
@yaustar : Thank you for looking into this.
I have shared a sample project with @slimbuck (Due to the seat limitation of the licence, I cannot add more than one).
Apologies if the problem is not apparent in a straightforward way but here are two videos that may help.
First one is when the test project is launched. The animation graph is set to cycle through the idle pose and then the walk pose for about 5 sec each. However, instead of proper walking and idle, only the hair mesh moves.
However, the model-viewer video (second one) shows that there is proper idle and walk animation set up for the entire model.
@yaustar : Yes, overall that seems to be the root cause (the import process not setting the root bone hierarchy correctly). However, is there a better way to fix this (for e.g. in Blender?). We have two models which work fine, but remaining four don’t. And manual edits in Playcanvas to those four are a bit of trial and error. We would like to identify a permanent fix and guide the artist to make relevant changes. @slimbuck : Any help/advice would be greatly appreciated.
Model which works with hierarchy matching what we see in Blender:
I don’t think it’s a bug. In case the anim component is not added to the root of the animation hierarchy, the rootBone property needs to point to it … so that we know where to search for the bones and similar.
@mvaligursky : Apologies, but in this case, root of the animation hierarchy appears to be the Template. What would be the fix in Blender if we wanted to ensure that Playcanvas sees the anim component under the root of the animation hierarchy?
I’m not sure, I’m not familiar with Blender. I’d suggest to compare the model that works vs model that does not work. How is the hierarchy set up, where is the mesh in the hierarchy.
@mvaligursky@slimbuck : We have compared the working versus non-working character files in Blender and there is no visible difference in the hierarchy. The only difference is how the Playcanvas Editor is treating the two files. Every single viewer/validator we have tested allows us to play the animations correctly. Only PlayCanvas Editor processes the file differently to generate a template without the armature node and assigns the meshes to the template as root, minus a root bone.
At the moment, we are able to get the models working partially by using a variation of the workaround suggested by @yaustar.
However, we could not understand what the difference is and thus we could not instruct the artist on what changes to make.
Does it mean that you cannot get some models to work in the project at all? What does the partially means here? What is the issue if you set up the rootBone properties?
@mvaligursky : Partially means, we are able to work with the current lot of models, but we have no way of knowing if the next batch of models delivered by the artist will work or not. We were relying on the Playcanvas model-viewer to confirm that the model works as proof of delivery, but since the Playcanvas Editor is treating the imported version differently, we are left with a lot of uncertainty. The reparenting was not straightforward either, took us a while to figure out that the root-bone needs to point to the template and not the mixamo:hips node.