studiomdl

studiomdl is the MDL compiler shipped with all branches of Source. In Strata, mdlcompile's functionality was merged into studiomdl. It is available for Windows and Linux.

The following input model formats are supported:

  • SMD

  • DMX

  • FBX

  • OBJ

Help Text

Usage: studiomdl.exe [options] <file.qc> Options: [-a <normal_blend_angle>] [-checklengths] [-d] - dump glview files [-definebones] [-f] - flip all triangles [-fullcollide] - don't truncate really big collisionmodels [-game <gamedir>] [-h] - dump hboxes [-i] - ignore warnings [-minlod <lod>] - truncate to highest detail <lod> [-n] - tag bad normals [-perf] report perf info upon compiling model [-printbones] [-printgraph] [-quiet] - operate silently [-r] - tag reversed [-t <texture>] [-fastbuild] - write a single vertex windings file [-nowarnings] - disable warnings [-dumpmaterials] - dump out material names [-mdlreport] model.mdl - report perf info [-mdlreportspreadsheet] - report perf info as a comma-delimited spreadsheet [-striplods] - use only lod0 [-overridedefinebones] - equivalent to specifying $unlockdefinebones in qc file [-stripmodel] - process binary model files and strip extra lod data [-stripvhv] - strip hardware verts to match the stripped model [-vsi] - generate stripping information .vsi file - can be used on .mdl files too [-allowdebug] [-overridedefinebones] [-verbose] [-makefile] [-verify] [-fastbuild] [-maxwarnings] [-preview] [-dumpmaterials] [-basedir] [-tempcontent] [-outdir <dir>] - directory to place the resultant model into. ie, /some/path will create the model /some/path/mymdl.mdl

List of StudioMDL commands (.qc scripts)

Command Parameters Description
$cd string directory Directory to change to
$modelname string modelName Set the name of the model, relative to the models/ directory, including the .mdl extension
$internalname string internalName Set the internal name of the model. This will be used as the name of the .ani file
$cdmaterials string materialsPath Set the materials path
$pushd string directory Same as $cd but pushes the current directory to a stack before doing the cd
$popd none Return to the directory previous to the last $pushd call
$scale float flScale Scale the model on all axes by a scalar value
$root string boneName Set the name of the root bone
$controller
$screenalign string boneName, string type = ["sphere", "cylinder", "billboard"] Align bone with screen
$worldalign string boneName Align bone with world
$keepupright string boneName Keeps a bone upright
$model
$collisionmodel string modelName, [optional block] Set the collision model for the mesh
$collisionjoints string modelName, [optional block] Set the collision model for the mesh, with separate joints
$collisiontext
$appendsource
$body
$prefer_fbx
$bodygroup
$appendblankbodygroup
$bodygrouppreset
$animation
$autocenter
$sequence
$append
$prepend
$continue
$declaresequence
$declareanimation
$cmdlist
$animblocksize
$weightlist
$defaultweightlist
$ikchain
$ikautoplaylock
$eyeposition
$illumposition
$origin
$originbones
$upaxis
$bbox
$bboxonlyverts
$cbox
$gamma
$texturegroup
$hgroup
$hbox
$hboxset
$surfaceprop
$jointsurfaceprop
$contents string contents = ["grate", "ladder", "solid", "monster", "notsolid"]
$jointcontents string jointName, string contents = ["grate", "ladder", "solid", "monster", "notsolid"]
$attachment
$redefineattachment
$bonemerge
$bonealwayssetup
$externaltextures
$cliptotextures
$skinnedLODs
$renamebone
$stripboneprefix
$renamebonesubstr
$collapsebones
$collapsebonesaggressive
$alwayscollapse
$proceduralbones
$skiptransition
$calctransitions
$staticprop none Mark this model as a static prop
$zbrush none Enable some special processing for zbrush authored models. Models marked with this have their texcoords smoothed. This is very expensive!
$realignbones
$forcerealign
$lod
$shadowlod
$poseparameter
$heirarchy Lol, lmao
$hierarchy
$insertbone
$limitrotation
$definebone
$jigglebone
$includemodel
$opaque none Force this model to be opaque. Removes any transparency flags
$mostlyopaque
$keyvalues block Defines a block of key-value pairs. These will be embedded into the model
$obsolete none Marks this model as obsolete. It will show the obsolete material in-game
$renamematerial
$renamematerialsubstr
$overridematerial
$stripmaterialpaths
$fakevta
$noforcedfade
$skipboneinbbox
$forcephonemecrossfade
$lockbonelengths
$unlockdefinebones
$constantdirectionallight float flDirLightDot Set the constant directional light dot product. Must be between 0 and 1, floating point number
$minlod int minLod Set the min lod
$allowrootlods
$bonesaveframe
$ambientboost none Indicate that the model should be rendered with an ambient boost
$centerbonesonverts
$donotcastshadows none Indicate that the model should not cast any shadows
$casttextureshadows none Indicate that this model should cast texture-based shadows in vrad, only applies to prop_static
$motionrollback
$sectionframes
$clampworldspace
$maxeyedeflection
$addsearchdir
$phyname
$subd none Indicate that we have a quad-only catmull-clark subd mesh in the model
$boneflexdriver
$maxverts int maxVerts Set the max verts on the model. Must be in range [1024, 65536]
$preservetriangleorder
$qcassert
$lcaseallsequences
$defaultfadein
$defaultfadeout
$cloth
$clothplanecollision
$allowactivityname
$collisionprecision
$erroronsequenceremappingfailure
$erroronsequenceremappingfailure_disable
$modelhasnosequences
$contentrootrelative
$adduvmapchannelto
$section
$sectionenable
$sectiondisable