-
Notifications
You must be signed in to change notification settings - Fork 831
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Prevent the code to fail when loading models without the "materials" property or having a mesh primitive without the material association #3287
base: master
Are you sure you want to change the base?
Conversation
…hout breaking the model and primitive-node constructors. Arranging the material panel in space-opera to fit that change.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks, this looks great. I especially appreciate all the added tests!
packages/space-opera/src/test/materials_panel/materials_panel_test.ts
Outdated
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks! I wonder if khronos_SimpleTriangle would work; it's a lot smaller and will load faster in the tests.
On the surface it would seems so, but |
hmm, that's interesting. I thought we always generated a default material when none were specified. Can you take a look and let me know what the difference is? I'd like to make sure we're fixing this properly. |
It does seems a bit fishy. I will check it out tomorrow morning no problem. Today is a bit busy on my end. |
Looking at the associations in the gltf object generated from the ThreeGLTFParser, the triangle file has 2 associations (material and mesh) and the vase only has 1 (mesh). Looking at the code, the What would you suggest we do with this? |
Hmm, sounds like the bug might be in the GLTFLoader (since it's supposed to create a default material association, and apparently fails to). I think for now we should go ahead and create our default material also in the case there is no material association at all, for robustness. Separately, it'd be interesting to know why GLTFLoader has weird behavior here. |
I took a deeper look into this and I haven't quite put my finger on exactly what is going on here. |
I wanted to get to this last week so it could be included in the next release, but I have been indisposed by Covid unfortunately. Anyways, it seems like the associations entry to the DefaultMaterial is set in different places which explains the inconsistency. For the Triangle files it is done here, which is called when we load the meshes in the loader. For the Vase(new file) it is done here, which is called when we load a material. The problem that we have in model-viewer with this is that CorrelatedSceneGraph and PrimitiveNode objects are instantiated before I could probably address the issue by adding this block of code, which uses the parser's cached DefaultMaterial to setup the association. The cache attribute is not public in the interface, so I am guessing this snippet is not exactly how we should use the library. I am not sure what direction you want to take with this? Perhaps this should be only fix/addressed three.js? |
No problem! Get well soon.
Indeed, let's not mess with the internals of three.js. You make it sound like something is happening too soon? Might this just be a race condition of some kind on our side? Maybe we just haven't awaited the right thing. |
Ping; did you ever find a deeper cause here? Would love to merge a fix for the root problem. |
I haven't had much time to check this any further. Off memory, I think it was basically that in this particular case three.js is only creating the associations for the default material once loadMaterial is being called which in model viewer happens after the constructors cited above. So the race condition assessment sounds about right, though I find it a bit weird as of why this association is done in different places in the three.js GTLFLoader's code to be honest. I will try to make some time on Friday to try to find a good solution for this. |
I'm still interested in what's going on here. Have you gotten stuck? |
Sorry for the slow response (on vacation for the past few weeks). I didn't put any time into this since March as my plate got really full, but I am interested in finding a good solution here. Let me put this back into my personal task board and come back to you with this. |
It looks like this is actually a three.js bug that needs to be fixed upstream. Should we merge the rest of this PR? |
Fixes #3279