$lod: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
 Tip:Studiomdl will transfer  weightmapping and flexes from the reference mesh.
Tip:Studiomdl will transfer  weightmapping and flexes from the reference mesh.
 Note:New materials cannot be introduced in an LOD SMD, they will render invisible. Use
Note:New materials cannot be introduced in an LOD SMD, they will render invisible. Use 
 Note:CS:GO currently does not support LOD. As a result, $lod should be avoided in custom models for CS:GO.
Note:CS:GO currently does not support LOD. As a result, $lod should be avoided in custom models for CS:GO.
 Bug:If a model has very short edges (~0.01 units or less), the next LOD may not render at all in that spot.  [todo tested in ?]
Bug:If a model has very short edges (~0.01 units or less), the next LOD may not render at all in that spot.  [todo tested in ?]
 Note:Floating point values can be used if wrapped in quotes. i.e. $lod "10.5"
Note:Floating point values can be used if wrapped in quotes. i.e. $lod "10.5"
 Note:LOD blocks do not inherit from previous blocks. They always modify the reference mesh.
Note:LOD blocks do not inherit from previous blocks. They always modify the reference mesh.
 Bug:Causes compiles to fail with an EXCEPTION_ACCESS_VIOLATION error in studiomdl builds later than 2006.
Bug:Causes compiles to fail with an EXCEPTION_ACCESS_VIOLATION error in studiomdl builds later than 2006.
Instead, use "replacemodel" to swap the specified model for one that is a single tiny triangle hidden inside the mesh. Invisible textures can be used hide it better, should the little triangle ever be seen. [todo tested in ?]
		
	
|  (→Options:  added note about possible workaround for the "Removemodel" command on post-2006 studiomdl.) |  (added bugnote about LOD not rendering at all if the previous model has very short edge lengths.) | ||
| Line 4: | Line 4: | ||
| {{tip|[[Studiomdl]] will transfer  weightmapping and flexes from the reference mesh.}} | {{tip|[[Studiomdl]] will transfer  weightmapping and flexes from the reference mesh.}} | ||
| {{note|New [[material]]s cannot be introduced in an LOD SMD, they will render invisible. Use <code>replacematerial</code> instead.}} | {{note|New [[material]]s cannot be introduced in an LOD SMD, they will render invisible. Use <code>replacematerial</code> instead.}} | ||
| {{note|CS:GO currently does not support LOD. As a result, $lod should be avoided in custom models for CS:GO.}} | {{note|CS:GO currently does not support LOD. As a result, $lod should be avoided in custom models for CS:GO.}} | ||
| {{bug|If a model has very short edges (~0.01 units or less), the next LOD may not render at all in that spot.}} | |||
| == See also == | == See also == | ||
Revision as of 08:49, 23 May 2022
The $lod QC command describes how to reduce the level of detail when rendering the model at a given size. It handles the removal or replacement of expensive parts of the model so it can be rendered more efficiently. There can be up to 8 levels.
 Tip:Studiomdl will transfer  weightmapping and flexes from the reference mesh.
Tip:Studiomdl will transfer  weightmapping and flexes from the reference mesh. Note:New materials cannot be introduced in an LOD SMD, they will render invisible. Use
Note:New materials cannot be introduced in an LOD SMD, they will render invisible. Use replacematerial instead. Note:CS:GO currently does not support LOD. As a result, $lod should be avoided in custom models for CS:GO.
Note:CS:GO currently does not support LOD. As a result, $lod should be avoided in custom models for CS:GO. Bug:If a model has very short edges (~0.01 units or less), the next LOD may not render at all in that spot.  [todo tested in ?]
Bug:If a model has very short edges (~0.01 units or less), the next LOD may not render at all in that spot.  [todo tested in ?]See also
Syntax
$lod <threshold>
{
	<options>
}
$shadowlod // Used to generate cheap render-to-texture shadows (not shadow maps)
{
	<options>
}
- threshold
- Defines when the LOD takes effect. Its value is (100 / screen pixels per unit) [1], which means that distance at which the transition happens depends on the size of the user's monitor and their FOV, not simply the model's distance from the camera. Someone with a truly massive screen may never see an LOD!
- The threshold formula makes it difficult to determine what values to use, however. The best way of working things out is to load your model into HLMV, switch to the Model tab, enable Auto LOD, and use  to zoom in and out. to zoom in and out.
 Note:Floating point values can be used if wrapped in quotes. i.e. $lod "10.5"
Note:Floating point values can be used if wrapped in quotes. i.e. $lod "10.5"Options
 Note:LOD blocks do not inherit from previous blocks. They always modify the reference mesh.
Note:LOD blocks do not inherit from previous blocks. They always modify the reference mesh.- replacemodel <Reference smd> <LOD smd> [reverse]
- Replaces the given reference SMD (can by anything from $body,$bodygroupor$model) with an LOD version.
- Reverseis used to correct reversed normals on the LOD, which can be caused by SMD export problems.
- removemodel <Reference smd>
- The specified SMD will not be rendered at all at this level of detail.
 Bug:Causes compiles to fail with an EXCEPTION_ACCESS_VIOLATION error in studiomdl builds later than 2006.
Bug:Causes compiles to fail with an EXCEPTION_ACCESS_VIOLATION error in studiomdl builds later than 2006.Instead, use "replacemodel" to swap the specified model for one that is a single tiny triangle hidden inside the mesh. Invisible textures can be used hide it better, should the little triangle ever be seen. [todo tested in ?]
- replacematerial <Reference material> <LOD material>
- Replaces all instances of the reference material with another. Useful for removing expensive processes like $bumpmap and disabling the Eye shader. Paths are relative to $cdmaterials.
- removemesh <Reference material>
- Removes all triangles attached to the named material. Unlike in replacematerial, paths are relative to the root materials folder. Bug:If a material's VMT is not present in the game's folder, studiomdl sees a material named "__error" instead; the compiler does not detect VMTs from mounted GCFs/games.  [todo tested in ?] Bug:If a material's VMT is not present in the game's folder, studiomdl sees a material named "__error" instead; the compiler does not detect VMTs from mounted GCFs/games.  [todo tested in ?]
- nofacial
- Disables facial animation.
- bonetreecollapse <Reference bone>
- Causes children of the specified bone to be removed. Their attached vertices return to the reference position. This is commonly used on fingers. Remember that it only applies to clients!
- replacebone <Reference bone> <LOD bone>
- The precursor of bonetreecollapse. Replacing bones is much more complex, but allows all kinds of unusual bone optimisations that a simple collapse wouldn't achieve.
Example
$lod 12
{
	replacemodel "Police_reference.smd" "lod1_Police_reference.smd"
	replacemodel "Manhack_reference.smd" "lod1_Manhack_reference.smd"
}
$lod 18
{
	replacemodel "Police_reference.smd" "lod2_Police_reference.smd"
	replacemodel "Manhack_reference.smd" "lod2_Manhack_reference.smd"
	bonetreecollapse "ValveBiped.Bip01_R_Hand"
	bonetreecollapse "ValveBiped.Bip01_L_Hand"
}
$lod 42
{
	replacemodel "Police_reference.smd" "lod3_Police_reference.smd"
	replacemodel "Manhack_reference.smd" "lod3_Manhack_reference.smd"
	bonetreecollapse "ValveBiped.Bip01_R_Hand"
	bonetreecollapse "ValveBiped.Bip01_L_Hand"
}