Open
Description
Problem description:
MeshReflectorMaterial
works fine for a planeGeometry created from ThreeJS, however it doesn't work out of the box for a plane geometry exported from Blender.
What I noticed is that it produces wrong reflections by default:
data:image/s3,"s3://crabby-images/a782a/a782a623264f41e695d65bd9ad3b97e4271948a7" alt="Image"
Workarounds
There are 2 workaorunds: one from Blender and one from JS (but requires patching the material source code).
In Blender:
- add a Plane
- enter in edit mode
- rotate all the vertices by 90° on the X axis
- enter object mode
- rotate the object by -90° on the X axis
- export the GLB
In JS:
- Change this line https://github.com/pmndrs/drei/blob/master/src/core/MeshReflectorMaterial.tsx#L99
fromnormal.set(0, 0, 1)
tonormal.set(0,1,0)
.
I'm not sure if it's possible to derive a normal from a GLB plane programmatically though.
Relevant code:
In this codesanbox:
- model1.glb is a Plane exported directly from Blender
- model2.glb is a Plane exported with the workaround applied
Activity