MDL (GoldSrc)
Jump to navigation
Jump to search
data:image/s3,"s3://crabby-images/c11a4/c11a47fbdd67c86c0654a6749553203216e9f32a" alt="English (en) English (en)"
Important:Older versions of StudioMDL, including the version found in the
Half-Life SDK on Steam, do not support tiling UVs, clamping them to the edge of the texture. This is not a limitation of the HLMDL file format; the Sven Co-op StudioMDL can create MDLs compatible with vanilla
GoldSrc which have tiled UVs.
Bug:The latest version of the Sven Co-op StudioMDL (from December 2020), as found in the Sven Co-op SDK, has some bugs with bounding boxes; use the version linked above instead (from November 2018). [todo tested in ?]
Tip:To create a model or submodel with more than 4080 tris, split the model into multiple SMD meshes, with a separate $body or $bodygroup entry for each mesh in the QC file.
Warning:Avoid going over 9000 tris!
While the HLMDL format can handle over 100K tris, the old OpenGL renderer struggles with such "high-poly" models, even on high-end GPUs.[1]
Note:Third party games that upgrade the renderer (ex:
,
or
) can handle higher polygon MDLs better. This does not include
Sven Co-op, which uses a mostly vanilla renderer.
This is obviously not a problem for games on engines much newer than
GoldSrc that use the HLMDL format, such as
Codename: Loop (
) or
FreeCS (
).
Confirm:Is this soft limit 9000 total, or 9000 being displayed simultaneously?
Confirm:Can custom renderers without engine access, such as Trinity Engine, improve performance for higher-poly MDLs?
Code:While MDL does not natively support animated textures, a model's skin can be quickly switched between in game code to animate between them. For example, monster_houndeye uses skin switching to blink.
Confirm:Max textures, max skins, and other limits?
data:image/s3,"s3://crabby-images/c11a4/c11a47fbdd67c86c0654a6749553203216e9f32a" alt="English (en) English (en)"
data:image/s3,"s3://crabby-images/16006/16006d9c63abe81d8662479879d7470840570429" alt="Translate (Translate) Translate (Translate)"
MDL (sometimes referred to as Half-Life MDL or HLMDL) is a model format used by GoldSrc to store dynamically lit models which can be animated using skeletal animation, along with their associated textures. It is a heavily modified version of the Quake MDL format.
Overview
Limits
HLMDL has the following limits per input SMD:
- 1 mesh
- 2048 vertices (and vertex normals) per mesh
- 4080 triangles per mesh
- 1 animation sequence
- 512 keyframes per sequence
- 128 bones
Additionally, the following limits apply to the whole MDL:
- 4 bone attachments
- 8 bone controllers
- 32 meshes across all submodels
- 256 animation sequences.
Textures must:
- Be 8-bit uncompressed BMP files.
- Have a resolution which is a multiple of 8 (multiples of 16 are preferred).
- Have a resolution which does not exceed 512x512 (soft limit; raised to 1024x1024 in
Sven Co-op and other engines like
FTE).
- Have a file name which is not longer than 64 characters (including the .bmp extension).
data:image/s3,"s3://crabby-images/c2af1/c2af13cb5d4b56f60dc9e9d8750a04a4bd31e177" alt="Icon-Important.png"
data:image/s3,"s3://crabby-images/a80ce/a80ced1ca1d1e55d3641d82bc6a42e4607a6e38c" alt="Half-Life SDK"
data:image/s3,"s3://crabby-images/a80ce/a80ced1ca1d1e55d3641d82bc6a42e4607a6e38c" alt="GoldSrc"
data:image/s3,"s3://crabby-images/4e64f/4e64f653e2f1c7713ef47159ae91666383cb25c9" alt="Icon-Bug.png"
data:image/s3,"s3://crabby-images/06ca0/06ca078143e9912365c2a7384ff18d8a671c92b0" alt="Tip.png"
data:image/s3,"s3://crabby-images/f9b91/f9b91dfd0d6b4f0aaec9bbbd3fbccd922d053cb0" alt="Warning.png"
While the HLMDL format can handle over 100K tris, the old OpenGL renderer struggles with such "high-poly" models, even on high-end GPUs.[1]
data:image/s3,"s3://crabby-images/3b146/3b14644f090b0c55edd7944e6fffcfad4fb40302" alt="Note.png"
data:image/s3,"s3://crabby-images/59e0d/59e0dd50d8b0148561545127e3c0e9e4e6c59059" alt="Paranoia"
data:image/s3,"s3://crabby-images/def07/def070c3649bbe601b5b539606b316565cd21f5f" alt="Cry of Fear"
data:image/s3,"s3://crabby-images/86713/867132e1dbd90a97d48057f48e6d03334c672a7a" alt="Counter-Strike Nexon"
data:image/s3,"s3://crabby-images/e52f4/e52f4c3aeec5ddc3133a59f1cb110ee30bdc3488" alt="Sven Co-op"
This is obviously not a problem for games on engines much newer than
data:image/s3,"s3://crabby-images/a80ce/a80ced1ca1d1e55d3641d82bc6a42e4607a6e38c" alt="GoldSrc"
data:image/s3,"s3://crabby-images/568b9/568b91586b912e80381c57f3fd02e363344a0f8e" alt="Codename: Loop"
data:image/s3,"s3://crabby-images/d97fd/d97fd339c5ec873d3ea1cd77b70810cc3bce8e21" alt="Unity"
data:image/s3,"s3://crabby-images/d1bce/d1bce241e8bb6b4d7881f749c28abf6b8c8e3864" alt="FreeCS"
data:image/s3,"s3://crabby-images/3d179/3d1796be8cd868c92d27c5a8c2639fd137f8c1e7" alt="FTE"
data:image/s3,"s3://crabby-images/1d621/1d621bb2032727485fa42a774a512afe2ae70ad2" alt=""
data:image/s3,"s3://crabby-images/1d621/1d621bb2032727485fa42a774a512afe2ae70ad2" alt=""
data:image/s3,"s3://crabby-images/f2263/f2263e41cfab681f3282f7fbb2808b2a43969b15" alt="Cpp.png"
data:image/s3,"s3://crabby-images/1d621/1d621bb2032727485fa42a774a512afe2ae70ad2" alt=""
Flags
Model flags
Particle effects cannot be combined, but all others can.[Clarify]
Bit | Flag name | Particle effect? | Description |
---|---|---|---|
1 | EF_ROCKET | Yes | ![]() |
2 | EF_GRENADE | Yes | ![]() |
4 | EF_GIB | Yes | ![]() |
8 | EF_ROTATE | No | Rotate this model around its origin, like the weapon pickups in ![]() |
16 | EF_TRACER | Yes | ![]() |
32 | EF_ZOMGIB | Yes | ![]() |
64 | EF_TRACER2 | Yes | ![]() |
128 | EF_TRACER3 | Yes | Like EF_GRENADE, but only has one trail |
256 | EF_NOSHADELIGHT | No | Reduces intensity of shadows on the model, without making the model flat ![]() |
512 | EF_HITBOXCOLLISIONS | No | Use hitbox for collision instead of bounding box |
1024 | EF_FORCESKYLIGHT | No | Always use skybox lighting, regardless of model location |
Texture flags
Bit | Flag name | Description |
---|---|---|
1 | STUDIO_NF_FLATSHADE | Shade the model a single tint, without any shadowing, resulting in the model looking "flat" like a cartoon character. |
2 | STUDIO_NF_CHROME | Use matcap environment mapping to render the texture as a sphere map.
![]() ![]() ![]() ![]() ![]() |
4 | STUDIO_NF_FULLBRIGHT | Display texture at maximum brightness, ignoring lighting.
![]() ![]() ![]() |
8 | STUDIO_NF_MIPMAPS | Generates mipmaps for the texture, greatly reducing texture aliasing at a distance. No effect in ![]() ![]() ![]() ![]() |
16 | STUDIO_NF_ALPHA | Unused? |
32 | STUDIO_NF_ADDITIVE | Use additive translucency. Still affected by entity lighting; use the Additive rendermode on an entity to ignore lighting.
![]() ![]() ![]() ![]() |
64 | STUDIO_NF_MASKED | Use binary alphatest transparency, wherein the last palette entry of the texture is transparent. |
In other engines
Half-Life MDLs are supported by FTE and the
Unity game
Codename: Loop.
External links
References
- From the GoldSrc Model Export Tutorial by The303:
In order to compile models with more than 4080 triangles, you must break up your SMD's into parts and give them their own $body lines for compiling. Also, FOR THE LOVE OF ALL THAT IS HOLY PLEASE DO NOT GO CRAZY ON YOUR TRIANGLE COUNT; remember this is goldsrc, not source engine. Going any higher than 9000 tris is excessive and direct ports from source/other games are inefficent, wasteful, and cause performance issues for the old renderer.— The303