-
Notifications
You must be signed in to change notification settings - Fork 3.5k
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
Make position morph binding as optional in renderers + enable other attrib type morph #16024
Conversation
Please make sure to label your PR with "bug", "new feature" or "breaking change" label(s). |
Snapshot stored with reference name: Test environment: To test a playground add it to the URL, for example: https://snapshots-cvgtc2eugrd3cgfd.z01.azurefd.net/refs/pull/16024/merge/index.html#WGZLGJ#4600 Links to test babylon tools with this snapshot: https://playground.babylonjs.com/?snapshot=refs/pull/16024/merge To test the snapshot in the playground with a playground ID add it after the snapshot query string: https://playground.babylonjs.com/?snapshot=refs/pull/16024/merge#BCU1XR#0 |
Visualization tests for WebGPU (Experimental) |
WebGL2 visualization test reporter: |
Thanks, I'd forgotten that we can have data in the morph texture that we don't use in the shader code if the user decides to disable them! However, I don't think your code is right yet.
if (manager.supportsPositions) {
defines.push("#define MORPHTARGETS_SUPPORTPOSITIONS");
defines.push("#define MORPHTARGETS_POSITION");
} We should push if (manager._supportsPositions) {
defines.push("#define MORPHTARGETS_SUPPORTPOSITIONS");
}
if (manager.supportsPositions) {
defines.push("#define MORPHTARGETS_POSITION");
} However, this property is private, and I think we should make the code clearer. I suggest renaming all the if (manager.hasPositions) {
defines.push("#define MORPHTARGETTEXTURE_HASPOSITIONS");
}
if (manager.supportsPositions) {
defines.push("#define MORPHTARGETS_POSITION");
} Note that I've also changed the name of the first define, for greater clarity. Also, How does it look like? Note: of course, these changes should also be done for the other targets (normals, tangents, etc)! [EDIT] I forgot to comment on one thing. Some of the renderers didn't push certain morph targets because the shader code doesn't use them (uv for the depth renderer, for example). However, I guess there's no problem keeping your changes, as the corresponding shader code will be dead code and will be removed by the compiler. |
Thank you for your response on the weekend.
The reason I set this condition is because of backwards compatibility.
The depth renderer uses UV morphs. If you look at the shader code, you can see that the alpha test uses a uv with a UV morph applied. When modifying the other renderers, I referenced the shader code to make sure that only the morph types used are added to the defines. If there's anything else wrong, please let me know. I'm applying what you requested. |
Yes, I think we can keep the simplified code, and see if anyone complains that we've broken their code.
My bad, I even checked the code of the depth renderer before replying... |
packages/dev/core/src/Culling/Helper/transformFeedbackBoundingHelper.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.
Should we factor the value 0 in PrepareDefinesAndAttributesForMorphTargets
?
It looks like we almost always use it like this:
mesh.morphTargetManager ? PrepareDefinesAndAttributesForMorphTargets(...) : 0 ?
It would be a performance benefit to run |
Just one conflict to solve and good to go |
The conflict has been resolved. |
In #16014 it is now possible to disable position morphs, but since we changed all renderers that use morph targets to unconditionally add the
MORPHTARGETS_POSITION
define, I tried to use those renderers with meshes that don't have position morphs and found that it caused problems.This PR fixes the issue mentioned above and enables normal, tangent, uv, and uv2 morphing, which were present in the renderers' shader code but not working in practice. (This is an additional issue I discovered while editing the code)
This is a list of fixed renderers Each of the morph types supported by these renderers existed in the shader but were not actually working because the isReady function did not add the appropriate attributes and define:
This is a list of fixed renderers that had code that did not account for the case where the Morph Target Manager does not support Position Morph:
The following defines have been added to handle cases where the list of morph data types that the MorphTargetManager has on the texture does not match the list of morph data types required by the shader.
See morphTargetsVertex.fx for more details