Difference between revisions of "Shading"

From OrbiterWiki
Jump to navigation Jump to search
(Added category.)
(Corrected category.)
Line 20: Line 20:
 
[[Category:Glossary]]
 
[[Category:Glossary]]
 
[[Category: Tutorials]]
 
[[Category: Tutorials]]
[[Category:Addon tutorials]]
+
[[Category:Add-on tutorials]]

Revision as of 03:29, 13 October 2022

Direct3D Gouraud shading

Orbiter uses the vertex normals for Gouraud shading: The information on how to shade is provided by the normals of every vertex in the msh file. (see 3DModel.pdf). If no normals are provided, Direct3D calculates them in realtime by taking the mean of the normals form the surrounding triangles (faces). This results in a smaller msh file, but the shading is smooth for every angle, that means, no sharp edges at all (a cube looks quite odd then). Now, if we want a sharp edge, we have to double the vertex and give it two different normals. This results in a larger filesize. These infos are from here: MSDN library, Getting Started with Direct3D > 3-D Coordinate Systems and Geometry

MeshMaker tool

download MeshMaker from Orbithangar

Msh_MakerV21.exe (see the MshMaker.pdf) solves this problem by assigning a "Material Tension" to each material. Normally this is set to 1 (in radians). This is the max angle between two faces where shading is still aplied. Is the angle higher, Mshmaker generates two vertices resulting in a sharp edge. (->and higher file size) The parameter can be set in the debug.txt.

Just apply different materials for groups that need different shading angles.

Summary

If the shading is done correct, a model can look much smoother without much more work. Shading is the primary tool when modelling to reduce polycount!