Search Issue Tracker
By Design
Votes
0
Found in
2017.1.1p3
Issue ID
969351
Regression
No
Imported model joints cause incorrect normals
Steps to reproduce:
1. Start a new project
2. Import user provided package
3. Open the test scene
4. Notice that the model with joints has normal issues on the upper eyelids
Expected result: Upper eyelids should display correct normals
Reproduced in: 2018.1.0a6, 2017.3.0b11, 2017.2.0p3, 2017.1.2p3, 5.6.4p3, 5.5.5p1
Add comment
All about bugs
View bugs we have successfully reproduced, and vote for the bugs you want to see fixed most urgently.
Latest issues
- "Shader warning in 'Hidden/Light2D': implicit truncation of vector type" is thrown when building Universal 2D template
- AI Assistant breaks compilation of packages using System.Runtime.CompilerServices.Unsafe via auto-referencing
- Unity Hub checks the "Documentation" module by default on the 6.4 and 6.5 streams despite that it was unchecked with the previous installs
- Shortcut that toggles between Dopesheet and Curves Views in the Animation Window's Timeline is mislabed
- Property List Items Overlap onto the Property List's top edge when scrolling through a long Property List
Resolution Note:
The model is set to calculate normals. These normals are computed in bindpose (when the eye lids are open). Because the eyes are open the triangles in this area is quite compressed. So I bet there are triangles there that are either degenerate or points some funny way. Thereby resulting in odd normals, without being visible because it gets occluded by other geometry.
When skinning is applied to open the eye lids the artifacts become visible. The skinning is a matrix multiplication so the normals are not fixed by this process. As noted none of the artifacts are observed when the model is imported with the eyes closed. In this state normal recalculation provides a much better result. Furthermore, any artifacts would occur when the eyes are open. In this state the eye lid geometry is hardly visible.
To summarize, in order to resolve the artifacts either put the model in a bindpose that makes recalculating normals easier or import the normals from the FBX. In the last case you have to make sure you authored the normals correctly in the DCC tool.