Prop static: Difference between revisions
| SirYodaJedi (talk | contribs)  (→Keyvalues:  move screenspacefade next to the other fading-related KVs, and remove dupe lightingorigin KV) |  (don't think there is any confusion between this and qc commands. Moving keyvalues to the top) | ||
| (35 intermediate revisions by 7 users not shown) | |||
| Line 1: | Line 1: | ||
| {{LanguageBar}} | {{LanguageBar}} | ||
| {{ | {{TabsBar|main=s2|base=Prop_static}} {{toc-right}} | ||
| {{ | {{CD|CStaticProp|base=IClientUnknown|file1=staticpropmgr.cpp}} | ||
| {{this is a| | {{this is a|model entity|internal=1|name=prop_static}} | ||
| It is used to [[cheap]]ly add a [[model]] to the world. It cannot move, animate, or  | It is used to [[cheap]]ly add a [[model]] to the world. It cannot move, animate, or take part in [[I/O]]. In fact, it doesn't exist as a regular entity after the map has been compiled. The vast majority of models in a typical map are <code>prop_static</code> entities. | ||
| Other objects will collide with a <code>prop_static</code> provided it has a [[collision mesh]], and, unlike all other model entities, can be lit per-vertex and cast shadows onto [[lightmap]]s. | |||
| {{altnames|name1=static_prop}} | {{altnames|name1=static_prop}} | ||
| == Keyvalues == | |||
| {{KV|Collisions|intn=solid|integer choices|How the prop should interact with other objects. | |||
| :* 0 -  Not solid | |||
| :* 2 - Use bounding box | |||
| :* 6 - Use [[VPhysics]] (default) {{note|Using VPhysics collision on models without a [[collision mesh]] will cause the engine to throw a warning upon loading the map and reset the collision to nonsolid. If you see such a warning, reset the collision of all props using the noted model to one of the other two choices.<br>Likewise, using an invalid value (such as 1) will also throw a warning and disable collision.}}}} | |||
| {{KV|Disable per-vertex lighting|since={{src06}}|intn=disablevertexlighting|bool|Prop will be vertex lit more similarly to dynamic props: in real-time, based on its [[origin]] or [[$illumposition]]. This can significantly reduce VRAD compile times if the prop does not benefit from complex lighting, is unlit, and/or is using an explicitly defined {{cmd|$lightmap}}. | |||
| : {{Important|Enabling this overrides {{code|generatelightmaps}}!}} | |||
| }} | |||
| {{KV|Disable Self-Shadowing with vertex lighting|since={{src06}}|intn=disableselfshadowing|bool|When vertex lighting is enabled, prevent the geometry from self-shadowing (casting shadows onto itself).}} | |||
| {{KV|Ignore surface normal for computing vertex lighting|since={{src07}}|intn=ignorenormals|bool|When vertex lighting is enabled, ignore the surface normal of faces when calculating the vertex lighting, resulting in more uniform shading. | |||
| : {{tip|Useful for thin, translucent objects such as leaves on foliage props.}}}} | |||
| {{KV|Alpha|intn=renderamt|int|Alpha of the fade, where 0 is fully transparent and 255 is fully opaque.|since=L4D}} | |||
| {{KV|Render Color (R G B)|intn=rendercolor|color255|Tint the model with this color.|since=L4D}} | |||
| : {{Note|For games before L4D like Source 2013, you can use this [https://github.com/Ambiabstract/props_scaling_recompiler tool] as a alternate}} | |||
| {{KV|Generate (and use) lightmaps for this static prop|intn=generatelightmaps|bool|Generate a lightmap for this prop, in addition to fallback per-vertex lighting. Requires <code>-StaticPropLighting</code> to be enabled in VRAD. For more information, visit [https://tf2maps.net/threads/guide-prop-lightmaps.24682/ tf2maps.net]. | |||
| :{{note|Lightmapping can be also faked on static props using [[$detailblendmode]] 8 or the [[Modulate]] shader in all games, although syncing the lighting can be difficult.}} | |||
| :{{warning|Several caveats and limitations; see explanation [[#Lightmaps_on_static_props|above]].}}  | |||
| :{{note|{{bms|not}} While this KV does exist in Black Mesa's FGD, it is unused; [[Xengine]] does not support [[$lightmap|lightmapped props]].}}|since=2013MP|also={{gmod}}}} | |||
| {{KV|Lightmap Resolution X|intn=lightmapresolutionx|int||since=2013MP|also={{gmod}}}} | |||
| {{KV|Lightmap Resolution Y|intn=lightmapresolutiony|int|The resolution of the generated lightmap in the X (or U) and Y (or V) direction. (Only used if Generate Lightmaps is enabled.) | |||
| :{{important|Setting a high resolution will significantly slow down VRAD compile times and may look out of place compared to the much lower resolution brush and displacement lightmaps.}} | |||
| |since=2013MP|also={{gmod}}}} | |||
| {{KV|Enable Bounced Lighting|intn=enablelightbounce|bool|Whether VRAD should create indirect lighting from this prop.|since={{csgobranch}}|also={{gmod}}}} | |||
| {{KV|Disable Prop Combine|intn=preventpropcombine|bool|Prevent this static prop from combining with any other static props in VBSP.|since={{csgobranch}}}} | |||
| {{KV|Uniform Scaling|intn=uniformscale|float|A multiplier for the size of the static prop model. | |||
| : {{bug|In Hammer, undoing/redoing any changes (whether they are slight unit movements or scale changes) will result in the prop appearing "normal" sized in the 3D Textured Viewport (the model only appears normal sized and the value given is still shown upon reload of the VMF).}}|since={{csgobranch}}}} | |||
| {{todo|add scaling kvs from p2ce}} | |||
| {{KV|Name|intn=targetname|target_source|The name that {{ent|ship_base_interaction}}{{ship}} entities refer to this entity by{{how}}. Also useful regardless of game for being able to recognize specific prop_static entities in [[Entity Report]]. The name will not be in the compiled BSP.|only={{ship}}}} | |||
| {{minititle|Studiomodel}} | |||
| {{KV|World Model|intn=model|model|The [[model]] this entity should appear as. 128-character limit.}} | |||
| {{KV|Skin|intn=skin|int|Some models have multiple [[$texturegroup|skins]]. This value selects from the index, starting with 0. {{tip|Hammer's model browser automatically updates this value if you use it to view different skins.}}{{bug|Static props with multiple [[skin]]s will always calculate [[texture shadows]] based upon the alpha channel(s) from the default skin's texture(s), even though the alternative skins' alpha textures are loaded by VRAD.}}|tested={{dods}}}}  | |||
| {{KV|Lighting Origin|intn=LightingOrigin|target_destination|Select an entity (preferably {{ent|info_lighting}}) from which to sample lighting instead of the entity's [[$illumposition]], if per-vertex lighting is disabled on this prop. Also used, regardless of how model is lit, to dictate where to grab the nearest env_cubemap from.}} | |||
| {{minititle|{{KV Shadow/strings|Title}}}} | |||
| {{KV|{{KV Shadow/strings|DisableShadows}}|intn=disableshadows|boolean|Prevents the prop from casting shadows onto lightmaps and other static props. Does not affect shadow mapping.}} | |||
| {{KV|{{KV Shadow/strings|DisableShadowDepth}}|intn=disableshadowdepth|boolean|{{KV Shadow/strings|DisableShadowDepthDesc}}|since=csgo}} | |||
| {{KV|{{KV Shadow/strings|DisableFlashlight}}|intn=disableflashlight|boolean|{{KV Shadow/strings|DisableFlashlightDesc}}|since=P2}} | |||
| {{KV Reflection}} | |||
| {{KV BaseFadeProp}} | |||
| {{KV|Screen space fade|intn=screenspacefade|boolean|removed={{portal2}}|nofgd={{{nofgd|}}}|The method by which the fading distance should be determined. If disabled, the fade distances is the distance from the player's view to the object, in inches. If enabled, the fade distance is the size of the object onscreen, in pixels.}} | |||
| {{KV DXLevelChoice}} | |||
| :{{tip|Set {{code|maxdxlevel}} to lower nonzero number such as 1 or 50 (along with {{code|disablevertexlighting}} set to 1) to create a prop that can cast shadows, but isn't rendered in-game. This is [[cheap]]er than using [[blocklight]] brushes, as it does not count towards brush and [[brushside]] limits.}} | |||
| {{KV SystemLevelChoice}} | |||
| :{{tip|Set {{code|mingpulevel}} or {{code|mincpulevel}} to a very large number such as 20 (along with {{code|disablevertexlighting}} set to 1) to create a prop that can cast shadows, but isn't rendered in-game. This is [[cheap]]er than using [[blocklight]] brushes, as it does not count towards brush and [[brushside]] limits.}} | |||
| == Known limitations == | == Known limitations == | ||
| === Vertex lighting === | === Vertex lighting === | ||
| [[File:Static prop bumpmaps.png|thumb|Demonstration of static prop lighting with and without {{ent|$bumpmap}} in {{src13| | [[File:Static prop bumpmaps.png|thumb|Demonstration of static prop lighting with and without {{ent|$bumpmap}} in {{src13|2}}, on a vanilla jeep model from {{dods|2}}. Note the differences in lighting accuracy on the jeep which is partially underneath the bridge.]] | ||
| [[Lighting]] can behave differently on a particular static prop depending on its settings and how its model and materials were authored. | [[Lighting]] can behave differently on a particular static prop depending on its settings and how its model and materials were authored. | ||
| A prop with disabled per-vertex lighting will be vertex-lit based on its origin ({{ent|$illumposition}}, if one is defined in the model, or '''Lighting origin''', if defined in [[Hammer]]) and appear similar to [[prop_dynamic|dynamic props]]. This is the only behavior available in  | A prop with disabled per-vertex lighting will be vertex-lit based on its origin ({{ent|$illumposition}}, if one is defined in the model, or '''Lighting origin''', if defined in [[Hammer]]) and appear similar to [[prop_dynamic|dynamic props]]. This is the only behavior available in {{src04}}. | ||
| With per-vertex lighting enabled (available since {{ | With per-vertex lighting enabled (available since {{src06}} via {{code|-StaticPropLighting}}), [[VRAD]] will calculate and bake lighting and color information for each vertex of the model, typically resulting in a better, more realistic in-game look. | ||
| However, sometimes it can lead to undesireable stretches of shadow or highlights, especially on low-poly models or props with elongated proportions, like trees. The higher the poly count, the more accurate per-vertex lighting can be. It can become [[expensive]] on very high-poly models, so creating [[LOD]]s is advisable. | However, sometimes it can lead to undesireable stretches of shadow or highlights, especially on low-poly models or props with elongated proportions, like trees. The higher the poly count, the more accurate per-vertex lighting can be. It can become [[expensive]] on very high-poly models, so creating [[LOD]]s is advisable. | ||
| Line 21: | Line 69: | ||
| In engine versions prior to {{csgobranch}}[[CSGO]] and {{strata|2}}, if any material on the prop's model uses normal mapping ({{ent|$bumpmap}}, {{ent|$normalmap}} or {{ent|$phong}}), per-vertex lighting <span style="font-weight:bold; color:white">will be forcibly disabled</span>. This happens if any of the skins use $bumpmap or $phong, even if it's not the selected active skin. | In engine versions prior to {{csgobranch}}[[CSGO]] and {{strata|2}}, if any material on the prop's model uses normal mapping ({{ent|$bumpmap}}, {{ent|$normalmap}} or {{ent|$phong}}), per-vertex lighting <span style="font-weight:bold; color:white">will be forcibly disabled</span>. This happens if any of the skins use $bumpmap or $phong, even if it's not the selected active skin. | ||
| The {{csgobranch|2}} and  | The {{csgobranch|2}} and derivatives support per-vertex lighting on normal-mapped and $phong materials, and do not suffer from this limitation. | ||
| === Lightmaps on static props === | === Lightmaps on static props === | ||
| In {{src13mp}} and {{gmod}} | In {{src13mp|2}}, {{tf2branch|2|nt=0}}, and {{gmod|2}}, VRAD can apply [[lightmap]]s onto static props, allowing for better blending between [[brush]] geometry and models. However, just like with per-vertex lighting, this feature cannot be used together with {{ent|$bumpmap}}, {{ent|$phong}} or {{ent|$normalmap}}. | ||
| When baking a lightmap for a model, VRAD will use the same UV and scaling as the {{ent|$basetexture}} of the model's first material of its first skin (taking {{ent|$basetexturetransform}} into account, if present).   | When baking a lightmap for a model, VRAD will use the same UV and scaling as the {{ent|$basetexture}} of the model's first material of its first skin (taking {{ent|$basetexturetransform}} into account, if present).   | ||
| Line 32: | Line 80: | ||
| * Models created with overlapping UV islands will get bad lightmaps, as they'll also be overlapping; | * Models created with overlapping UV islands will get bad lightmaps, as they'll also be overlapping; | ||
| * If the model has multiple [[skin]]s and or [[materials]], only the first one will be used to lay down the lightmaps, potentially making overlapping worse; | * If the model has multiple [[skin]]s and or [[materials]], only the first one will be used to lay down the lightmaps, potentially making overlapping worse; | ||
| * The lightmap will be cropped by the UV edges; | * The lightmap will be cropped by the UV edges (tiling UVs are not supported); | ||
| * Low-res lightmaps can bleed over the edges of the UV. | * Low-res lightmaps can bleed over the edges of the UV. | ||
| To make matters worse, the lightmap generated for props by vanilla VRAD comes as RGB888 (24-bit SDR) in a special [[PPL]] format, which can make color banding noticeable in [[HDR]] mode (especially if a light source is close to the prop). | To make matters worse, the lightmap generated for props by vanilla VRAD comes as RGB888 (24-bit SDR) in a special [[PPL]] format, which can make color banding noticeable in [[HDR]] mode (especially if a light source is close to the prop). {{gmod|2}} generates and uses separate RGBA16161616f lightmaps for HDR mode. | ||
| {{ | |||
| Finally, models with [[LoD]]s will have a lightmap generated for each LoD, which can greatly increase the amount of VRAM used by an individual prop, making level of detail models potentially more [[expensive]] than always using the highest quality model. | |||
| }} | See the [[$lightmap#Limitations_and_caveats|$lightmap]] page for a full list of caveats with lightmapped props. | ||
| {{workaround|A modified VRAD can generate HDR lightmaps for static props, at the expense of additional VRAM usage; see [[PPL]] for more information.}} | |||
| {{tip| | {{tip| | ||
| * {{Propper++|2}} can bake a model's [[$basetexture]] into a non-overlapping non-tiling atlas, mitigating some of these issues at a minor quality loss. | * {{Propper++|2}} can bake a model's [[$basetexture]] into a non-overlapping non-tiling atlas, mitigating some of these issues at a minor quality loss. | ||
| Line 54: | Line 103: | ||
| === Forced consistency === | === Forced consistency === | ||
| In order to enforce consistency of behavior, models with [[prop_data|embedded physics data]] cannot be <code>prop_static</code>. Use the Hammer Model Browser's info tab to check for support. | In order to enforce consistency of behavior, models with [[prop_data|embedded physics data]] cannot be <code>prop_static</code>, unless {{mono|allowstatic}} is used. Use the Hammer Model Browser's info tab to check for support. | ||
| {{workaround|This is not an engine limitation; the check is performed by the compiler. A modified [[VBSP]] can avoid it. See [[#VBSP deletes model|below]].}} | {{workaround|This is not an engine limitation; the check is performed by the compiler. A modified [[VBSP]] can avoid it. See [[#VBSP deletes model|below]].}} | ||
| === Models with bodygroups === | === Models with bodygroups === | ||
| {{code|Prop_static}} does not support selectable {{ent|$bodygroup}} submodels; if there's any, only the first one will be used by the game. Despite this, VRAD will generate lightmap shadows from ''all submodels'' present in the MDL! (tested in {{dods}}) | {{code|Prop_static}} does not support selectable {{ent|$bodygroup}} submodels; if there's any, only the first one will be used by the game. Despite this, VRAD will generate lightmap shadows from ''all submodels'' present in the MDL! <sub>(tested in {{dods}}<!-- easily demonstrated with models/mapmodels/barbed_wire.mdl -->)</sub> | ||
| {{workaround|Either compile a separate model for each desired variation (doesn't use up an [[edict]], better lighting), or use {{ent|prop_dynamic}} (easier, less file duplication).}} | {{workaround|Either compile a separate model for each desired variation (doesn't use up an [[edict]], better lighting), or use {{ent|prop_dynamic}} (easier, less file duplication).}} | ||
| ==  | === Models with skin groups === | ||
| While {{code|prop_static}} does support selectable {{ent|$texturegroup}} skins, VRAD does not properly load the appropriate skin. Since VRAD only cares about the alpha channel of the textures, this is only an issue for materials that would cast [[texture shadows]]. Texture shadows will be cast based upon the first skin, even though the alpha textures for the other skins are loaded into memory. <sub>(tested in {{dods}})</sub> | |||
| {{ | |||
| ==Common Mistakes== | ==Common Mistakes== | ||
| Line 123: | Line 139: | ||
| * If {{src13}}, use the VBSP from {{slammin|4}} ({{src13sp}} or {{src13mp}}), [https://hl2-beta.ru/index.php?action=downloads;sa=view;down=155;language=english VBSP prop_static fix] ({{src13sp}} only), {{mapbase|4}} ({{src13sp}} only), or {{gmod|4}} ({{src13mp}} only). | * If {{src13}}, use the VBSP from {{slammin|4}} ({{src13sp}} or {{src13mp}}), [https://hl2-beta.ru/index.php?action=downloads;sa=view;down=155;language=english VBSP prop_static fix] ({{src13sp}} only), {{mapbase|4}} ({{src13sp}} only), or {{gmod|4}} ({{src13mp}} only). | ||
| * Otherwise, use {{srcskineditor|4}} to add {{code|"allowstatic" "1"}} to the [[MDL (Source)|MDL]]'s {{cmd|prop_data}}, then ''revert to the original MDL after the map is compiled''. | * Otherwise, use {{srcskineditor|4}} to add {{code|"allowstatic" "1"}} to the [[MDL (Source)|MDL]]'s {{cmd|prop_data}}, then ''revert to the original MDL after the map is compiled''. | ||
| {{todo|Provide an option that works with {{tf2branch}}.}} | |||
| === Model is off-center === | === Model is off-center === | ||
| Line 128: | Line 145: | ||
| == See also == | == See also == | ||
| * [[$treesway]] | |||
| * [[Prop Types Overview]] | * [[Prop Types Overview]] | ||
| ** {{ent|prop_dynamic}} | ** {{ent|prop_dynamic}} | ||
Latest revision as of 08:23, 3 June 2025
|  Class hierarchy | 
|---|
| CStaticProp | 
|  staticpropmgr.cpp | 
prop_static  is an  internal model entity  available in all  Source games.
It is used to cheaply add a model to the world. It cannot move, animate, or take part in I/O. In fact, it doesn't exist as a regular entity after the map has been compiled. The vast majority of models in a typical map are
 Source games.
It is used to cheaply add a model to the world. It cannot move, animate, or take part in I/O. In fact, it doesn't exist as a regular entity after the map has been compiled. The vast majority of models in a typical map are prop_static entities.
Other objects will collide with a prop_static provided it has a collision mesh, and, unlike all other model entities, can be lit per-vertex and cast shadows onto lightmaps.
 AltNames: This entity is also tied to
AltNames: This entity is also tied to static_prop.  Keyvalues
- Collisions (solid) <integer choices>
- How the prop should interact with other objects.
- 0 - Not solid
- 2 - Use bounding box
- 6 - Use VPhysics (default)  Note:Using VPhysics collision on models without a collision mesh will cause the engine to throw a warning upon loading the map and reset the collision to nonsolid. If you see such a warning, reset the collision of all props using the noted model to one of the other two choices. Note:Using VPhysics collision on models without a collision mesh will cause the engine to throw a warning upon loading the map and reset the collision to nonsolid. If you see such a warning, reset the collision of all props using the noted model to one of the other two choices.
 Likewise, using an invalid value (such as 1) will also throw a warning and disable collision.
 
- Disable per-vertex lighting (disablevertexlighting)  <boolean> (in all games since  ) )
- Prop will be vertex lit more similarly to dynamic props: in real-time, based on its origin or $illumposition. This can significantly reduce VRAD compile times if the prop does not benefit from complex lighting, is unlit, and/or is using an explicitly defined $lightmap.
 Important:Enabling this overrides Important:Enabling this overrides- generatelightmaps!
- Disable Self-Shadowing with vertex lighting (disableselfshadowing)  <boolean> (in all games since  ) )
- When vertex lighting is enabled, prevent the geometry from self-shadowing (casting shadows onto itself).
- Ignore surface normal for computing vertex lighting (ignorenormals)  <boolean> (in all games since  ) )
- When vertex lighting is enabled, ignore the surface normal of faces when calculating the vertex lighting, resulting in more uniform shading.
 Tip:Useful for thin, translucent objects such as leaves on foliage props. Tip:Useful for thin, translucent objects such as leaves on foliage props.
- Alpha (renderamt)  <integer> (in all games since  ) )
- Alpha of the fade, where 0 is fully transparent and 255 is fully opaque.
- Render Color (R G B) (rendercolor)  <color255> (in all games since  ) )
- Tint the model with this color.
 Note:For games before L4D like Source 2013, you can use this tool as a alternate Note:For games before L4D like Source 2013, you can use this tool as a alternate
- Generate (and use) lightmaps for this static prop (generatelightmaps)  <boolean> (in all games since  ) (also in ) (also in ) )
- Generate a lightmap for this prop, in addition to fallback per-vertex lighting. Requires -StaticPropLightingto be enabled in VRAD. For more information, visit tf2maps.net.
 Note:Lightmapping can be also faked on static props using $detailblendmode 8 or the Modulate shader in all games, although syncing the lighting can be difficult. Note:Lightmapping can be also faked on static props using $detailblendmode 8 or the Modulate shader in all games, although syncing the lighting can be difficult.
 Warning:Several caveats and limitations; see explanation above. Warning:Several caveats and limitations; see explanation above.
 Note:(not in Note:(not in ) While this KV does exist in Black Mesa's FGD, it is unused; Xengine does not support lightmapped props. ) While this KV does exist in Black Mesa's FGD, it is unused; Xengine does not support lightmapped props.
- Lightmap Resolution Y (lightmapresolutiony)  <integer> (in all games since  ) (also in ) (also in ) )
- The resolution of the generated lightmap in the X (or U) and Y (or V) direction. (Only used if Generate Lightmaps is enabled.)
 Important:Setting a high resolution will significantly slow down VRAD compile times and may look out of place compared to the much lower resolution brush and displacement lightmaps. Important:Setting a high resolution will significantly slow down VRAD compile times and may look out of place compared to the much lower resolution brush and displacement lightmaps.
- Enable Bounced Lighting (enablelightbounce)  <boolean> (in all games since  ) (also in ) (also in ) )
- Whether VRAD should create indirect lighting from this prop.
- Disable Prop Combine (preventpropcombine)  <boolean> (in all games since  ) )
- Prevent this static prop from combining with any other static props in VBSP.
- Uniform Scaling (uniformscale)  <float> (in all games since  ) )
- A multiplier for the size of the static prop model.
 Bug:In Hammer, undoing/redoing any changes (whether they are slight unit movements or scale changes) will result in the prop appearing "normal" sized in the 3D Textured Viewport (the model only appears normal sized and the value given is still shown upon reload of the VMF).  [todo tested in ?] Bug:In Hammer, undoing/redoing any changes (whether they are slight unit movements or scale changes) will result in the prop appearing "normal" sized in the 3D Textured Viewport (the model only appears normal sized and the value given is still shown upon reload of the VMF).  [todo tested in ?]
- Name (targetname)  <string> (only in  ) )
- The name that ship_base_interaction entities refer to this entity by[How?]. Also useful regardless of game for being able to recognize specific prop_static entities in Entity Report. The name will not be in the compiled BSP. entities refer to this entity by[How?]. Also useful regardless of game for being able to recognize specific prop_static entities in Entity Report. The name will not be in the compiled BSP.
Studiomodel:
- World Model (model) <model path>
- The model this entity should appear as. 128-character limit.
- Skin (skin) <integer>
- Some models have multiple skins. This value selects from the index, starting with 0.  Tip:Hammer's model browser automatically updates this value if you use it to view different skins. Tip:Hammer's model browser automatically updates this value if you use it to view different skins. Bug:Static props with multiple skins will always calculate texture shadows based upon the alpha channel(s) from the default skin's texture(s), even though the alternative skins' alpha textures are loaded by VRAD.  [todo tested in ?] Bug:Static props with multiple skins will always calculate texture shadows based upon the alpha channel(s) from the default skin's texture(s), even though the alternative skins' alpha textures are loaded by VRAD.  [todo tested in ?]
- Lighting Origin (LightingOrigin) <targetname>
- Select an entity (preferably info_lighting) from which to sample lighting instead of the entity's $illumposition, if per-vertex lighting is disabled on this prop. Also used, regardless of how model is lit, to dictate where to grab the nearest env_cubemap from.
Shadow:
- Disable Shadows (disableshadows) <boolean>
- Prevents the prop from casting shadows onto lightmaps and other static props. Does not affect shadow mapping.
- Disable Shadow Depth (disableshadowdepth)  <boolean> (in all games since  ) )
- Used to disable rendering into shadow depth (for projected textures) for this entity.
- Disable flashlight (disableflashlight)  <boolean> (in all games since  ) )
- Used to disable projected texture lighting and shadows on this entity.
- Render in Fast Reflections (drawinfastreflection)  <boolean> (in all games since  ) )
- If enabled, this entity will render in fast water reflections (i.e. when a water material specifies $reflectonlymarkedentities) and in the world impostor pass.
BaseFadeProp:
- Start Fade Dist (fademindist) <float>
- Distance at which the entity starts to fade.
- End Fade Dist (fademaxdist) <float>
- Max fade distance at which the entity is visible.
- If start fade is <0, the entity will disappear instantly when end fade is hit.
- If end fade is <0, the entity won't disappear at all. (This is the default behavior.)
 
- The values will scale appropriately if the entity is in a 3D Skybox.
- Fade Scale (fadescale) <float>
- If you specify so in worldspawn, or if the engine is running below DirectX 8 (DX7 in  ), props will fade out even if the fade distances above aren't specified. This value gives you some control over when this happens: numbers smaller than 1 cause the prop to fade out at further distances, while those greater than 1 cause it to fade out at closer distances. Using 0 turns off the forced fade altogether. See also the QC command $noforcedfade. ), props will fade out even if the fade distances above aren't specified. This value gives you some control over when this happens: numbers smaller than 1 cause the prop to fade out at further distances, while those greater than 1 cause it to fade out at closer distances. Using 0 turns off the forced fade altogether. See also the QC command $noforcedfade.
- Screen space fade (screenspacefade)  <boolean> (removed since  ) )
- The method by which the fading distance should be determined. If disabled, the fade distances is the distance from the player's view to the object, in inches. If enabled, the fade distance is the size of the object onscreen, in pixels.
- Minimum / Maximum DX Level (mindxlevel / maxdxlevel)  <integer choices> (removed since  ) )
- The entity will not exist if the engine is running outside the given range of DirectX Versions.
- Choices  Warning:If these are used, the object may break when the user switches their DirectX settings.[missing string] Warning:If these are used, the object may break when the user switches their DirectX settings.[missing string]- 0 - Default (no bounding)
- 60 - DirectX 6 (!FGD for mindxlevel)
- 70 - DirectX 7
- 80 - DirectX 8 (GeForce4 Ti & FX 5000 series)
- 81 - DirectX 8.1 (GeForce FX 5800, 5900 & Radeon 8500/9100 and 9000/9200)
- 90 - DirectX 9 Shader Model 2
- 92 - OpenGL аналогичен DirectX 9 Shader Model 2 (using ToGL;   only) !FGD only) !FGD
- 95 - DirectX 9 Shader Model 3 (in all games since  ) )
- 98 - DirectX 9 Shader Model 3 on Xbox 360 ( only) !FGD only) !FGD
 
 Tip:Set Tip:Set- maxdxlevelto lower nonzero number such as 1 or 50 (along with- disablevertexlightingset to 1) to create a prop that can cast shadows, but isn't rendered in-game. This is cheaper than using blocklight brushes, as it does not count towards brush and brushside limits.
- Minimum / Maximum Effect Details Level (mincpulevel / maxcpulevel)  <integer choices> (in all games since  ) )
- Don't render for players with Effect Details levels that exceed the minimum or maximum.
- Choices - 0: Default ("Low" for mincpulevel, "High" formaxcpulevel)
- 1: Low
- 2: Medium
- 3: High
 
- 0: Default ("Low" for 
- Minimum / Maximum Shader Details Level (mingpulevel / maxgpulevel)  <integer choices> (in all games since  ) )
- Don't render for players with Shader Details levels that exceed the minimum or maximum.
- Choices - 0: Default ("Low" for mingpulevel, "Very High" formaxgpulevel)
- 1: Low
- 2: Medium
- 3: High
- 4: Very High
 See also: cpu_level / gpu_level convars
- 0: Default ("Low" for 
 Tip:Set Tip:Set- mingpulevelor- mincpulevelto a very large number such as 20 (along with- disablevertexlightingset to 1) to create a prop that can cast shadows, but isn't rendered in-game. This is cheaper than using blocklight brushes, as it does not count towards brush and brushside limits.
Known limitations
Vertex lighting
 
   Source 2013, on a vanilla jeep model from
 Source 2013, on a vanilla jeep model from  Day of Defeat: Source. Note the differences in lighting accuracy on the jeep which is partially underneath the bridge.
 Day of Defeat: Source. Note the differences in lighting accuracy on the jeep which is partially underneath the bridge.Lighting can behave differently on a particular static prop depending on its settings and how its model and materials were authored.
A prop with disabled per-vertex lighting will be vertex-lit based on its origin ($illumposition, if one is defined in the model, or Lighting origin, if defined in Hammer) and appear similar to dynamic props. This is the only behavior available in  .
.
With per-vertex lighting enabled (available since  via
 via -StaticPropLighting), VRAD will calculate and bake lighting and color information for each vertex of the model, typically resulting in a better, more realistic in-game look.
However, sometimes it can lead to undesireable stretches of shadow or highlights, especially on low-poly models or props with elongated proportions, like trees. The higher the poly count, the more accurate per-vertex lighting can be. It can become expensive on very high-poly models, so creating LODs is advisable.
In engine versions prior to  CSGO and
CSGO and  Strata Source, if any material on the prop's model uses normal mapping ($bumpmap, $normalmap or $phong), per-vertex lighting will be forcibly disabled. This happens if any of the skins use $bumpmap or $phong, even if it's not the selected active skin.
 Strata Source, if any material on the prop's model uses normal mapping ($bumpmap, $normalmap or $phong), per-vertex lighting will be forcibly disabled. This happens if any of the skins use $bumpmap or $phong, even if it's not the selected active skin.
The  CS:GO engine branch and derivatives support per-vertex lighting on normal-mapped and $phong materials, and do not suffer from this limitation.
 CS:GO engine branch and derivatives support per-vertex lighting on normal-mapped and $phong materials, and do not suffer from this limitation.
Lightmaps on static props
In  Source 2013 Multiplayer,
 Source 2013 Multiplayer,  TF2 branch, and
 TF2 branch, and  Garry's Mod, VRAD can apply lightmaps onto static props, allowing for better blending between brush geometry and models. However, just like with per-vertex lighting, this feature cannot be used together with $bumpmap, $phong or $normalmap.
 Garry's Mod, VRAD can apply lightmaps onto static props, allowing for better blending between brush geometry and models. However, just like with per-vertex lighting, this feature cannot be used together with $bumpmap, $phong or $normalmap.
When baking a lightmap for a model, VRAD will use the same UV and scaling as the $basetexture of the model's first material of its first skin (taking $basetexturetransform into account, if present).
This means that:
- Models created with overlapping UV islands will get bad lightmaps, as they'll also be overlapping;
- If the model has multiple skins and or materials, only the first one will be used to lay down the lightmaps, potentially making overlapping worse;
- The lightmap will be cropped by the UV edges (tiling UVs are not supported);
- Low-res lightmaps can bleed over the edges of the UV.
To make matters worse, the lightmap generated for props by vanilla VRAD comes as RGB888 (24-bit SDR) in a special PPL format, which can make color banding noticeable in HDR mode (especially if a light source is close to the prop).  Garry's Mod generates and uses separate RGBA16161616f lightmaps for HDR mode.
 Garry's Mod generates and uses separate RGBA16161616f lightmaps for HDR mode.
Finally, models with LoDs will have a lightmap generated for each LoD, which can greatly increase the amount of VRAM used by an individual prop, making level of detail models potentially more expensive than always using the highest quality model.
See the $lightmap page for a full list of caveats with lightmapped props.
 Workaround:A modified VRAD can generate HDR lightmaps for static props, at the expense of additional VRAM usage; see PPL for more information.
Workaround:A modified VRAD can generate HDR lightmaps for static props, at the expense of additional VRAM usage; see PPL for more information. Tip:
Tip:
 Propper++ can bake a model's $basetexture into a non-overlapping non-tiling atlas, mitigating some of these issues at a minor quality loss. Propper++ can bake a model's $basetexture into a non-overlapping non-tiling atlas, mitigating some of these issues at a minor quality loss.
- Use the QC command $checkuv 0to1 overlapto prevent a model from compiling if it has incompatible UVs.
Compile limits for static props
VBSP limits the max number of entities on a map, including internal entities, and because prop_static count toward that limit, having too many can make the compile fail.
- In    there can be up to 8192 entities (counting static props); there can be up to 8192 entities (counting static props);
- In   up to 16384; up to 16384;
- In  up to 20480; up to 20480;
- In  up to 65536 (works with any up to 65536 (works with any game). game).
Because, again, that limit concerns all map entities, the realistic maximum amount of static props will be lower.
 Tip:This is a soft limit, and a modified VBSP can change it (MAX_MAP_ENTITIES in
Tip:This is a soft limit, and a modified VBSP can change it (MAX_MAP_ENTITIES in public/bspfile.h). A BSP file can theoretically contain over 4 billion static props.Forced consistency
In order to enforce consistency of behavior, models with embedded physics data cannot be prop_static, unless allowstatic is used. Use the Hammer Model Browser's info tab to check for support.
 Workaround:This is not an engine limitation; the check is performed by the compiler. A modified VBSP can avoid it. See below.
Workaround:This is not an engine limitation; the check is performed by the compiler. A modified VBSP can avoid it. See below.Models with bodygroups
Prop_static does not support selectable $bodygroup submodels; if there's any, only the first one will be used by the game. Despite this, VRAD will generate lightmap shadows from all submodels present in the MDL! (tested in  )
)
 Workaround:Either compile a separate model for each desired variation (doesn't use up an edict, better lighting), or use prop_dynamic (easier, less file duplication).
Workaround:Either compile a separate model for each desired variation (doesn't use up an edict, better lighting), or use prop_dynamic (easier, less file duplication).Models with skin groups
While prop_static does support selectable $texturegroup skins, VRAD does not properly load the appropriate skin. Since VRAD only cares about the alpha channel of the textures, this is only an issue for materials that would cast texture shadows. Texture shadows will be cast based upon the first skin, even though the alpha textures for the other skins are loaded into memory. (tested in  )
)
Common Mistakes
VBSP deletes model
The prop is not currently compatible to be used as prop_static. Note that this does not necessarily mean the model cannot be used with prop_static.
If the model does not have "static" flag in the model viewer (as in, was not compiled with $staticprop):
- You need to use prop_dynamic instead, or prop_physics_override if you want it to have physics.
If the model is your custom model:
- Either your model's QC file is missing $staticprop or there is no allowstatic 1in theprop_data. Example:
- $KeyValues { prop_data { "base" "Metal.Medium" "allowstatic" "1" } } 
 
If it is not your custom model, but has the "static" flag in the model viewer (was compiled with $staticprop:
- If  , add -allowdynamicpropsasstatic to the VBSP compile options. , add -allowdynamicpropsasstatic to the VBSP compile options.
- If  , use the VBSP from , use the VBSP from Slammin' Source Map Tools ( Slammin' Source Map Tools ( or or ), VBSP prop_static fix ( ), VBSP prop_static fix ( only), only), Mapbase ( Mapbase ( only), or only), or Garry's Mod ( Garry's Mod ( only). only).
- Otherwise, use  Source Model Skin Editor to add Source Model Skin Editor to add"allowstatic" "1"to the MDL'sprop_data, then revert to the original MDL after the map is compiled.
Model is off-center
If for some reason your model located incorrectly, check declared bone name in $definebone of a model; it should be without any slashes. Also check position there, values should be zeroed.


























