$lod: Difference between revisions
Jump to navigation
Jump to search

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.
Bug:LOD meshes for Bodygroups defined outside the
Contents of
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 ?]
Bug:If you use
ReverendV92 (talk | contribs) m (Better reading) |
ReverendV92 (talk | contribs) |
||
Line 35: | Line 35: | ||
: Replaces the given reference SMD (can by anything from <code>[[$body]]</code>, <code>[[$bodygroup]]</code> or <code>[[$model]]</code>) with an LOD version.<br> | : Replaces the given reference SMD (can by anything from <code>[[$body]]</code>, <code>[[$bodygroup]]</code> or <code>[[$model]]</code>) with an LOD version.<br> | ||
: <code>Reverse</code> is used to correct reversed normals on the LOD, which can be caused by SMD export problems. <!-- see also [[Talk:$body]]--> | : <code>Reverse</code> is used to correct reversed normals on the LOD, which can be caused by SMD export problems. <!-- see also [[Talk:$body]]--> | ||
{{bug|LOD meshes for [[$bodygroup|Bodygroups]] defined outside the <code>.qc</code> file (i.e. via <code>$include file.qci</code>) will not be correctly assigned.<br> | {{bug|LOD meshes for [[$bodygroup|Bodygroups]] defined outside the <code>.qc</code> file (i.e. via <code>$include file.qci</code>) or inside of [[$pushd]]/[[$popd]] blocks will not be correctly assigned.<br> | ||
Contents of <code>.qci</code> files must be merged into the main <code>.qc</code> file to work. Any usage of <code>$pushd</code> or <code>$popd</code> must be replaced with full relative paths, using <code>..\</code> and forward-slashes to work.|only=}} | |||
; <code>removemodel <Reference smd></code> | ; <code>removemodel <Reference smd></code> | ||
: The specified SMD will not be rendered at all at this level of detail.<br> | : The specified SMD will not be rendered at all at this level of detail.<br> |
Revision as of 19:31, 25 January 2023


$lod
is a QC command describing 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.
Template:ModernTip Template:ModernNote Template:ModernNote Template:ModernWarning
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.

Options

replacemodel <Reference smd> <LOD smd> [reverse]
- Replaces the given reference SMD (can by anything from
$body
,$bodygroup
or$model
) with an LOD version. Reverse
is used to correct reversed normals on the LOD, which can be caused by SMD export problems.

.qc
file (i.e. via $include file.qci
) or inside of $pushd/$popd blocks will not be correctly assigned.Contents of
.qci
files must be merged into the main .qc
file to work. Any usage of $pushd
or $popd
must be replaced with full relative paths, using ..\
and forward-slashes to work. [todo tested in ?]removemodel <Reference smd>
- The specified SMD will not be rendered at all at this level of detail.

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
.

replacemodel
to replace the mesh, and then set replacematerial
's 2nd argument to one of the materials found in the LOD mesh, it will cause the entire mesh to be removed. [todo tested in ?]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 ?]
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!
Note:This don't affect the bones with their parents that have an attachment. This means that if you collapse bonetree from ValveBiped.Bip01_R_UpperArm but ValveBiped.Bip01_R_Hand has an attachment, such bones as ValveBiped.Bip01_R_Hand and ValveBiped.Bip01_R_Forearm will not be deleted.
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"
}