Vertex animation: Difference between revisions
| m (Wording and clarity) | mNo edit summary | ||
| Line 1: | Line 1: | ||
| {{lang|Vertex animation}} | |||
| '''Vertex animation''' is the keyframed animation of the individual [[vertex|vertices]] of a mesh. It is useful for complex motion, such as that of cloth, hair, or water. Each frame of the vertex animation is stored as a unique flex, and a special flex controller bone drives the animation by progressing through the flexes. This approach allows vertex animation to be combined with typical skeletal animation. | '''Vertex animation''' is the keyframed animation of the individual [[vertex|vertices]] of a mesh. It is useful for complex motion, such as that of cloth, hair, or water. Each frame of the vertex animation is stored as a unique flex, and a special flex controller bone drives the animation by progressing through the flexes. This approach allows vertex animation to be combined with typical skeletal animation. | ||
| Vertex animation was added in {{ | Vertex animation was added in {{Game name|as|name=Alien Swarm}} and is available in all games that branch from it, including {{Game name|portal2|name=Portal 2}}, {{Game name|csgo|name=Counter-Strike: Global Offensive}}, {{Game name|sfm|name=Source Filmmaker}}, and {{Game name|dota2|name=Dota 2}}. | ||
| Some games on older engine branches may support vertex animation through backported or custom implementations. Such games include: | Some games on older engine branches may support vertex animation through backported or custom implementations. Such games include: | ||
| * {{ | * {{Game name|GMOD|name=Garry's Mod}} supports vertex animation (since update 2021.06.09) on its own modified v48 MDLs and on v49 MDLs compiled with SFM, Alien Swarm, or similar. | ||
| :{{Note|Gmod's studiomdl creates models that extend the {{src13}} MDL v48 format with additional features, including vertex animation. These modified v48 MDLs are '''not''' compatible with other games. This studiomdl does '''not''' create v49 MDLs.}} | :{{Note|Gmod's studiomdl creates models that extend the {{Game name|src13|name=Source 2013}} MDL v48 format with additional features, including vertex animation. These modified v48 MDLs are '''not''' compatible with other games. This studiomdl does '''not''' create v49 MDLs.}} | ||
| Line 11: | Line 12: | ||
| {{bug|Using the [[$scale]] command breaks vertex animation. {{TODO|In what way?}}}} | {{bug|Using the [[$scale]] command breaks vertex animation. {{TODO|In what way?}}}} | ||
| == Compiling Models with Vertex Animation == | == Compiling Models with Vertex Animation == | ||
| === Using SMD === | ===Using SMD=== | ||
| * Create a vertex animation with your modeling package. | * Create a vertex animation with your modeling package. | ||
| * Export a Vertex Cache file. Currently, only the official Maya exporter can do this. | * Export a Vertex Cache file. Currently, only the official Maya exporter can do this. | ||
| Line 28: | Line 28: | ||
| A programmer can now control your vertex animation. If you want to use your vertex animation like an ordinary <code>[[$sequence]]</code>, you must define and animate a special driver bone. See the next section, '''Driving Vertex Animations'''. | A programmer can now control your vertex animation. If you want to use your vertex animation like an ordinary <code>[[$sequence]]</code>, you must define and animate a special driver bone. See the next section, '''Driving Vertex Animations'''. | ||
| === Using DMX === | ===Using DMX=== | ||
| * The DMX format can store vertex animations with the reference mesh and does not require an additional VCA file. | * The DMX format can store vertex animations with the reference mesh and does not require an additional VCA file. | ||
| * Configure your modeling package to include your vertex animation in the DMX export. You can include multiple vertex animations in a single DMX file. | * Configure your modeling package to include your vertex animation in the DMX export. You can include multiple vertex animations in a single DMX file. | ||
| Line 37: | Line 37: | ||
| </syntaxhighlight> | </syntaxhighlight> | ||
| == Driving Vertex Animations == | ==Driving Vertex Animations== | ||
| A standard <code>[[$sequence]]</code> can drive a vertex animation without the need for a programmer. The position of a special driver bone in your model's skeleton is used to specify the frame and intensity of the vertex animation. By animating the driver bone, you can play the vertex animation, as well as combine it with regular skeletal animation. | A standard <code>[[$sequence]]</code> can drive a vertex animation without the need for a programmer. The position of a special driver bone in your model's skeleton is used to specify the frame and intensity of the vertex animation. By animating the driver bone, you can play the vertex animation, as well as combine it with regular skeletal animation. | ||
| Line 53: | Line 53: | ||
| {{bug|Currently the flex driver sequence '''must''' be defined with [[$upaxis|$upaxis Y]]. This doesn't affect the rest of the model.}} | {{bug|Currently the flex driver sequence '''must''' be defined with [[$upaxis|$upaxis Y]]. This doesn't affect the rest of the model.}} | ||
| === QC Example === | ===QC Example=== | ||
| <syntaxhighlight lang=php> | <syntaxhighlight lang=php> | ||
| $model "body" "reference_mesh.smd" { | $model "body" "reference_mesh.smd" { | ||
| Line 75: | Line 74: | ||
| </syntaxhighlight> | </syntaxhighlight> | ||
| == Example Videos == | ==Example Videos== | ||
| * [http://www.youtube.com/watch?v=O2iZZHwDcZg A simple video showing the use of Vertex animation for hair.] | * [http://www.youtube.com/watch?v=O2iZZHwDcZg A simple video showing the use of Vertex animation for hair.] | ||
| * [http://www.youtube.com/watch?v=0ZZ8xH_nvX0 A simple video showing the use of Vertex animation for cloth.] | * [http://www.youtube.com/watch?v=0ZZ8xH_nvX0 A simple video showing the use of Vertex animation for cloth.] | ||
| * [http://www.youtube.com/watch?v=r5aV5C6kryU Example of vertex animation in Source Filmmaker.] | * [http://www.youtube.com/watch?v=r5aV5C6kryU Example of vertex animation in Source Filmmaker.] | ||
| * [https://www.youtube.com/watch?v=cP3M0Vu-_7I&feature=youtu.be Example of vertex animation in Portal 2's HLMV.]   | * [https://www.youtube.com/watch?v=cP3M0Vu-_7I&feature=youtu.be Example of vertex animation in Portal 2's HLMV.]   | ||
| ==See also== | |||
| * <code>[[$boneflexdriver]]</code> | * <code>[[$boneflexdriver]]</code> | ||
| * [[Flex animation]] | * [[Flex animation]] | ||
Revision as of 12:12, 11 September 2021

 
Vertex animation is the keyframed animation of the individual vertices of a mesh. It is useful for complex motion, such as that of cloth, hair, or water. Each frame of the vertex animation is stored as a unique flex, and a special flex controller bone drives the animation by progressing through the flexes. This approach allows vertex animation to be combined with typical skeletal animation.
Vertex animation was added in Template:Game name and is available in all games that branch from it, including Template:Game name, Template:Game name, Template:Game name, and Template:Game name.
Some games on older engine branches may support vertex animation through backported or custom implementations. Such games include:
- Template:Game name supports vertex animation (since update 2021.06.09) on its own modified v48 MDLs and on v49 MDLs compiled with SFM, Alien Swarm, or similar.
 Note:Gmod's studiomdl creates models that extend the Template:Game name MDL v48 format with additional features, including vertex animation. These modified v48 MDLs are not compatible with other games. This studiomdl does not create v49 MDLs. Note:Gmod's studiomdl creates models that extend the Template:Game name MDL v48 format with additional features, including vertex animation. These modified v48 MDLs are not compatible with other games. This studiomdl does not create v49 MDLs.
Compiling Models with Vertex Animation
Using SMD
- Create a vertex animation with your modeling package.
- Export a Vertex Cache file. Currently, only the official Maya exporter can do this.
- Include the vertex cache file in your $modelblock with thevcafilecommand (see example below).
$model "body" "reference_mesh.smd" {
	vcafile "my_vertex_animation.vta"
}
This produces two flex controllers named after your VCA file. The first defines the blend weight of the animation, the second (prefixed with multi_) defines the active frame.
A programmer can now control your vertex animation. If you want to use your vertex animation like an ordinary $sequence, you must define and animate a special driver bone. See the next section, Driving Vertex Animations.
Using DMX
- The DMX format can store vertex animations with the reference mesh and does not require an additional VCA file.
- Configure your modeling package to include your vertex animation in the DMX export. You can include multiple vertex animations in a single DMX file.
- In Blender Source Tools, use the Vertex Animation options under Scene > Source Engine Exportables.
 
- The exported DMX file contains both the reference mesh and one or more vertex animation(s). Use $model to include the DMX file (see example below).
$model "body" "reference_mesh_animated.dmx"
Driving Vertex Animations
A standard $sequence can drive a vertex animation without the need for a programmer. The position of a special driver bone in your model's skeleton is used to specify the frame and intensity of the vertex animation. By animating the driver bone, you can play the vertex animation, as well as combine it with regular skeletal animation.
- In your modeling package, create a bone at the origin (0,0,0). You do not have to weight any vertices to it.
- Alternatively, you can use $definebonein your QC file.
 
- Alternatively, you can use 
- Add two $boneflexdrivercommands to bind your vertex animation to the driver bone. Each command requires specific names and parameters. Refer to the QC example below.
- The first $boneflexdrivermust use axistxand the name of your vcafile (or, if using DMX, the name of the vertex animation block inside the DMX).
- The second $boneflexdrivermust use axistyand the name of the your vcafile with "multi_" prepended.
 
- The first 
- Add at least one $sequencein which the driver bone is animated on its X and Y axes.
- The driver bone's X position sets the blend weight (i.e. intensity) of the vertex animation, from 0.0 to 1.0.
- Its Y position sets the progress of vertex animation, from 0.0 to 1.0.
 - For example, if your vertex animation is 120 frames long, frame 90 will be displayed when the driver bone's Y position is 0.75.
- If your modeling package is a Z-up world (like Blender or 3ds Max), you may need to translate the driver bone along its Z axis instead of Y. See the bug note below.
 
 
QC Example
$model "body" "reference_mesh.smd" {
	vcafile "my_vertex_animation.vta"
}
// If using DMX instead:
// 	$model "body" "reference_mesh_animated.dmx"
$definebone "vertexAnimDriver" "" 0 0 0 0 0 0
$boneflexdriver "vertexAnimDriver" tx "my_vertex_animation" 0 1
$boneflexdriver "vertexAnimDriver" ty "multi_my_vertex_animation" 0 1
// "my_vertex_animation" is the name of the vcafile when using SMD (or name of the vertex animation block embedded in the DMX when using DMX)
$upaxis Y // currently flex driver sequences must be Y-up
$sequence "idle" {
	"vertexAnimDriver_anim.smd"	// SMD animation which moves the "vertexAnimDriver" bone
	fps 30
}
Example Videos
- A simple video showing the use of Vertex animation for hair.
- A simple video showing the use of Vertex animation for cloth.
- Example of vertex animation in Source Filmmaker.
- Example of vertex animation in Portal 2's HLMV.
























