scripted_sequence
scripted_sequence
is a point entity available in all Source games. It is used to make an NPC play scripted animations.
A scripted_sequence
typically takes a Target NPC which can be set to either move to the sequence's position or play the sequence's animation at the NPC's current position. When the NPC is ready to begin the sequence, it will play the specified animation(s) in a special scripted state which may or may not be interrupted depending on the scripted_sequence
's settings.
Script flow
Whenever a scripted_sequence
plays with a valid Target NPC, it uses a special flow to make the NPC play its animations in specific, coordinated ways:
- Unless the "Start on Spawn" flag ticked, the
scripted_sequence
remains inert until it is triggered. It will remain inert until theBeginSequence
input is received or it is used by a previousscripted_sequence
. - Upon being triggered, the
scripted_sequence
will look for the nearest NPC specified in "Target NPC". - When a NPC is found, it will either move to the
scripted_sequence
's position or begin standing still depending on the "Move to Position" setting. - When the NPC reaches the
scripted_sequence
, it will play the "Pre-Action Idle Animation" if it is set to wait (see below). It will play the animation until all conditions are satisfied. If the script is not set to wait for anything, it will skip this step. - The
scripted_sequence
fires itsOnBeginSequence
output. - If the
scripted_sequence
has an Entry Animation, the NPC will play it. If the script does not have an entry animation, it will skip this step. - The NPC plays the Action Animation. If no action animation is specified in the script, it will skip this step.
- If the
scripted_sequence
has a Post-Action Idle Animation, the NPC will play it. If no post-action idle animation is specified in the script, it will skip this step. If the "Loop in Post Idle" spawnflag is set, the NPC will continue to play the post-action idle animation until the script is canceled. - The
scripted_sequence
fires itsOnEndSequence
output. - If the
scripted_sequence
has a Next Script, the NPC is handed to the target script and this process is repeated automatically. If not, the NPC returns to regular behavior.
There are a few external factors which can modify this flow:
- If the sequence was triggered by the "Start on Spawn" flag or the
MoveToPosition
input, the NPC will play the Pre-Action Idle Animation until theBeginSequence
input was received. IfBeginSequence
was used to begin with, it will proceed as normal. - If the sequence shares its name with other sequences, it will wait for other NPCs to get into position before starting, playing the Pre-Action Idle Animation until all actors are in position. When the script has no remaining dependencies, it will proceed as normal.
- If the Target NPC was asleep (via "Sleep State" or
Sleep
) when it was grabbed, it will awaken automatically without firingOnWake
. - If the Pre-Idle Idle Animation is the same as the Action Animation, the pre-action idle animation will freeze on its first frame, waiting for the script to start to play the full animation. [confirm]
Keyvalues
Targetname:
- Name
(targetname)
<string> - The targetname that other entities refer to this entity by.
Parentname:
- Parent
(parentname)
<targetname> - Specifies a movement parent. An entity will maintain its initial offset from its parent. An attachment point can be added to the end of the name, separated by a comma.
Angles:
- Pitch Yaw Roll (Y Z X)
(angles)
<angle> - This entity's orientation in the world. Pitch is rotation around the Y axis, yaw is the rotation around the Z axis, roll is the rotation around the X axis.
DXLevelChoice:
- Minimum / Maximum DX Level
(mindxlevel / maxdxlevel)
<choices> (removed since ) - The entity will not exist if the engine is running outside the given range of DirectX Versions.
Warning:If these are used, the object may break when the user switches their DirectX settings.
|
- Target NPC
(m_iszEntity)
<targetname> - The name or class name (such as 'npc_zombie') of an NPC to use for this script.
- Pre Action Idle Animation
(m_iszIdle)
<string> - The name of the sequence (such as "idle01") or activity (such as 'ACT_IDLE') to play before the action animation if the NPC must wait for the script to be triggered. Use "Start on Spawn" flag or "MoveToPosition" input to play this idle animation.
- Entry Animation
(m_iszEntry)
<string> - The name of the sequence (such as 'reload02') or activity (such as 'ACT_RELOAD') to play when the sequence starts, before transitioning to play the main action sequence.
- Action Animation
(m_iszPlay)
<string> - The name of the main sequence (such as 'reload02') or activity (such as 'ACT_RELOAD') to play.
- Post Action Idle Animation
(m_iszPostIdle)
<string> - The name of the sequence (such as 'idle01') or activity (such as 'ACT_IDLE') to play after the action animation.
- Custom Move Animation
(m_iszCustomMove)
<string> - Used in conjunction with the 'Custom movement' setting for the 'Move to Position' property, specifies the sequence (such as 'crouch_run01') or activity (such as 'ACT_RUN') to use while moving to the scripted position.
- Loop Action Animation? <boolean>
- Repeat permamently "Action animation"? See "Action Animation."
- Synch Post Idles
(m_bSynchPostIdles)
<boolean>
- Search Radius
(m_flRadius)
<radius> - Radius to search within for an NPC to use. 0 searches everywhere.
- Repeat Rate ms
(m_flRepeat)
<boolean> - How long NPC will repeat "Action Animation". See "Action Animation". Useless with "Loop Action Animation?"
- Move to Position
(m_fMoveTo)
<choices> - How the NPC will walk to this scripted_sequence.
Literal Value Description 0 No 1 Walk 2 Run 3 Custom movement 4 Instantaneous 5 No - Turn to Face
- Next Script
(m_iszNextScript)
<targetname> - The name of the script to run immediately after this script completes. The NPC will not return to AI between the two scripts.
- Ignore Gravity on NPC during Script
(m_bIgnoreGravity)
<boolean> - If this is set to 'Yes', the NPC will not be subject to gravity while playing this script
- Disable NPC collisions during Script
(m_bDisableNPCCollisions)
<boolean> - Useful for when NPCs playing scripts must interpenetrate while riding on trains, elevators, etc. This only disables collisions between the NPCs in the script and must be enabled on BOTH scripted_sequences.
- On Player death
(onplayerdeath)
<boolean> - If set, NPC will cancel script and return to AI.
Flags
- [
4
] : Repeatable
- [
8
] : Leave Corpse
Forces NPC corpse to remain rather than fade out.Confirm:This only seems to be valid for NPCs which don't ragdoll on death (e.g. GoldSrc-era NPCs)
- [
16
] : Start on Spawn
Makes the script search for a NPC and move to its position upon spawning, playing the Pre-Action Idle Animation untilBeginSequence
is received.
- [
32
] : No Interruptions
Prevents the NPC from being interrupted by damage, etc.
- [
64
] : Override AI
Overrides the NPC's current state to play the script, regardless of whether they're in combat or otherwise.
- [
128
] : Don't Teleport NPC at End
Prevents the script from teleporting the NPC to the last animation's end position when the script is finished.
- [
256
] : Loop in Post Idle
Makes the NPC loop the Post-Action Idle Animation after it finishes playing the Action Animation.
- [
512
] : Priority Script
Stops other scripts from stealing this script's spot in a NPC's queue.
- [
1024
] : Search Cyclically !FGD
Searches for the next entity from the last one found.
- [
2048
] : No Complaints !FGD
Suppresses developer warnings.
- [
4096
] : Allow NPC Death
The NPC using this scripted sequence may die without interrupting the scene. (used for scripted deaths)
Inputs
Base:
AddContext
<string>- Adds to the entity's list of response contexts. See Context.
AddOutput
<string>- Assigns a new keyvalue/output on this entity. For keyvalues, some rely on extra necessary code to be ran and won't work if its simply just changed through this input. There is a strict format that must be followed:
// Format of changing KeyValues: "AddOutput [key] [value]"
//// Raw text:
"OnUser1" "!self,AddOutput,targetname new_name"
// Format of adding an Output: "AddOutput {targetname}:{inputname}:{parameter}:{delay}:{max times to fire, -1 means infinite}"
//// Raw text:
"OnUser1" "!self,AddOutput,OnUser1:SetParent:!activator:0.0:-1"
// Arguments can be left blank, but the empty blank should still be contained.
//// Raw text:
"OnUser1" "!self,AddOutput,OnUser1:ClearParent::0.0:-1"
|
ClearContext
- Removes all contexts from this entity's list.
ClearParent
- Removes this entity from the the movement hierarchy, leaving it free to move independently.
FireUser1
toFireUser4
- Fires the respective
OnUser
outputs; see User Inputs and Outputs.
Kill
- Removes this entity and any entities parented to it from the world.
KillHierarchy
- Functions the same as
Kill
, although this entity and any entities parented to it are killed on the same frame, being marginally faster thanKill
input.
RemoveContext
<string>- Remove a context from this entity's list. The name should match the key of an existing context.
SetParent
<string>- Move with this entity. See Entity Hierarchy (parenting).
SetParentAttachment
<string>- Change this entity to attach to a specific attachment point on its parent. The entity will teleport so that the position of its root bone matches that of the attachment. Entities must be parented before being sent this input.
SetParentAttachmentMaintainOffset
<string>- As above, but without teleporting. The entity retains its position relative to the attachment at the time of the input being received.
DispatchResponse
<string> !FGD- Dispatches a response to the entity. See Response and Concept.
DispatchEffect
<string> (removed since ) !FGD- Dispatches a special effect from the entity's origin; See also List of Client Effects. Replaced by the particle system since .
RunScriptFile
<script> (in all games since ) (also in )- Execute a VScript file from disk, without file extension. The script contents are merged with the script scope of the receiving entity.
RunScriptCode
<string> (in all games since ) (also in )- Execute a string of VScript source code in the scope of the entity receiving the input. String quotation may be needed when fired via console. Bug:In Hammer, using string arguments will corrupt the VMF file's structure, making the file unviewable for the next Hammer session.Fix:Remove the string argument manually with a text editor.
CallScriptFunction
<string> (in all games since ) (also in ) !FGD- Calls a VScript function defined in the scope of the receiving entity.
TerminateScriptScope
(only in ) !FGD- Destroys the script scope of the receving entity.
SetLocalOrigin
<coordinates> (in all games since ) !FGD- Send this entity to a spot in the map. If the entity is parented to something, it will be offset from the parent by this amount.
Parentname:
SetParent
<string>- Move with this entity. See Entity Hierarchy (parenting).
SetParentAttachment
<string>- Change this entity to attach to a specific attachment point on its parent. The entity will teleport so that the position of its root bone matches that of the attachment. Entities must be parented before being sent this input.
SetParentAttachmentMaintainOffset
<string>- As above, but without teleporting. The entity retains its position relative to the attachment at the time of the input being received.
ClearParent
- Removes this entity from the the movement hierarchy, leaving it free to move independently.
BeginSequence
- Summons an NPC to act out the scripted sequence.
MoveToPosition
- Summons an NPC to the script location. They will play their scripted idle (or "ACT_IDLE" if none is specified) until "BeginSequence" is triggered.
CancelSequence
- Stops the scripted sequence. If fired after a sequence starts, this input will not take effect until the NPC finishes playing the scripted action animation.
Outputs
Targetname:
OnUser1
toOnUser4
- These outputs each fire in response to the firing of the like-numbered
FireUser1
toFireUser4
Input; see User Inputs and Outputs.
OnBeginSequence
- Fires when the action animation begins playing.
OnEndSequence
- Fires when the action animation completes.
OnScriptEvent01
toOnScriptEvent08
- Fires when a 'trigger' anim event occurs while playing the script. Use { event 1003 framenum (1-8) } in the QC.
OnFoundNPC
(in all games since )- Fires when a target NPC is found and begins moving to play the script.
Locating animations
You can use the model tab in the entity window.
Or
You can use the Half-life Model Viewer tool to see all the available sequences(Animations) for the model you're using. You can find the application in the Source SDK.
When you've launched the tool go to File and load the model you want. Then go to the Sequence tab and select an animation from the dropdown menu to get the model you've select to play that animation or sequence.
See also
- The npc_zombie_prone and npc_zombie_slump prefabs, providing examples of use.
- Activity List - a list of activities for use with this entity.
- aiscripted_schedule - a similar entity.
- falling headcrab tutorial - A tutorial for how to make a headcrab fall, using this entity.
- Actbusy - An alternative to
scripted_sequence
which doesn't involve setting a NPC in a scripted state.