$boneflexdriver: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(Document for Source 2013)
(Updated with new testing)
Line 3: Line 3:
This command is available in the [[Source 2013]] branch and further.
This command is available in the [[Source 2013]] branch and further.


{{note|Bone flex drivers will only work in-game in [[Alien Swarm]] and further. In earlier games, they will never simulated in-game as the code is never called, but it will only be simulated in HLMV. To fix this in a mod, run the <code>Studio_RunBoneFlexDrivers</code> function on the client when building transformations.}}
{{note|Bone flex drivers will only work in-game on entities that support flex animation. E.g. [[generic_actor]], [[cycler_flex]], [[player]] or other NPCs.}}


== Syntax ==
== Syntax ==
Line 21: Line 21:
: One of three values:
: One of three values:
:; <code>tx</code>  
:; <code>tx</code>  
:: Links the target flex controller to the weight of the animation (much like a [[skeletal animation]]'s). Controlled by the X-axis animation of the host bone.
:: Source 2013: Controls the flex controller by the X-axis animation of the bone.
:: Alien Swarm and Later: Also links the target flex controller to the weight of the animation (much like a [[skeletal animation]]'s).
:; <code>ty</code>
:; <code>ty</code>
:: Links the target flex controller to the current frame of vertex animation. Controlled by the Y-axis animation of the host bone.
:: Source 2013: Controls the flex controller by the Y-axis animation of the bone.
:: Alien Swarm and Later: Also links the target flex controller to the current frame of vertex animation.
:; <code>tz</code>
:; <code>tz</code>
:: Unknown function.
:: Source 2013: Controls the flex controller by the Z-axis animation of the bone.
:: Alien Swarm and Later: Unknown function.
; flex_name
; flex_name
: The name of the flex controller this command operates on. There are two sensible options:
: The name of the flex controller this command operates on.  
: In Alien Swarm and later, there are two sensible options:
:* <code><vca_name></code> (for tx)
:* <code><vca_name></code> (for tx)
:* <code>multi_<vca_name></code> (for ty)
:* <code>multi_<vca_name></code> (for ty)

Revision as of 12:09, 27 May 2021

$boneflexdriver is a QC command which enables driving a flex with a bone's animation. This is particularly useful in multiplayer games where you can't pack VDC files into the map, as you can still use flex animation. It is also critical to vertex animation.

This command is available in the Source 2013 branch and further.

Note.pngNote:Bone flex drivers will only work in-game on entities that support flex animation. E.g. generic_actor, cycler_flex, player or other NPCs.

Syntax

Source 2013:

$boneflexdriver <bone_name> <graph_axis> <flex_name> <min> <max>

Alien Swarm and later:

$boneflexdriver <bone_name> <graph_axis> <flex_name> <start_offset> <time_factor>
bone_name
The name of an existing bone that will host vertex animation for this model.
graph_axis
One of three values:
tx
Source 2013: Controls the flex controller by the X-axis animation of the bone.
Alien Swarm and Later: Also links the target flex controller to the weight of the animation (much like a skeletal animation's).
ty
Source 2013: Controls the flex controller by the Y-axis animation of the bone.
Alien Swarm and Later: Also links the target flex controller to the current frame of vertex animation.
tz
Source 2013: Controls the flex controller by the Z-axis animation of the bone.
Alien Swarm and Later: Unknown function.
flex_name
The name of the flex controller this command operates on.
In Alien Swarm and later, there are two sensible options:
  • <vca_name> (for tx)
  • multi_<vca_name> (for ty)
In both cases, <vca_name> is the name of the model's vcafile minus any file extension.
min
Minimum weight value of the controller.
max
Maximum weight value of the controller.
start_offset
Adds a delay before the vertex animation starts.
time_factor
The keyframe rate of the animation is multiplied by this value. It doesn't actually change the animation's duration however, making it of little use.

Example

For vertex animation:

$boneflexdriver "flexAnimBone" tx "my_vca_name" 0 1
$boneflexdriver "flexAnimBone" ty "multi_my_vca_name" 0 1