This article's documentation is for anything that uses the Source engine. Click here for more information.

Scripted sequence: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(OnEndSequence doesn't have any method of knowing the entity being targeted because it's just an output. you're having some other kind of issue which i cant diagnose here because your edit is kind of vague and i don't know your situation)
 
(23 intermediate revisions by 18 users not shown)
Line 1: Line 1:
{{hl2 point|scripted_sequence}}
{{LanguageBar}}
== Entity description ==
[[File:scripted_sequence.png|right|300px]]
Grabs an [[NPC]] and makes them play a specified set of animations. The NPC can be told to move to the scripted sequence position or can be told to play the script wherever they currently are. Multiple scripted sequences of the same name will frame-synchronize in the action animation once all the actors have moved to position. This allows tight interaction between actors (one actor grabbing another, hitting them, etc.) The flow is as follows:
{{tabs|scripted_sequence|goldsrc = 1|source = 1|main = source}}
{{this is a|point entity|name=scripted_sequence}} It is used to make an [[NPC]] play scripted animations.
{{CD|CAI_ScriptedSequence|file1=scripted.cpp}}


#Move to position using the specified movement animation. If "Move to Position" is set to "None", skip to step 2.
A {{code|preset=1|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 {{code|preset=1|scripted_sequence}}'s settings.
#If forced to wait for another actor to move to position, play the pre-action idle animation, otherwise skip to step 3. If there is no pre-action idle specified, "ACT_IDLE" is used.
#Fire the "OnBeginSequence" output.
#Play the action animation. If no action animation is specified, skip to step 5.
#Play the post-action idle animation. If none is specified, skip to step 6. If the "Loop in Post Idle" spawnflag is set, keep playing the post-action idle until the script is canceled. If no post-action idle animation is specified, "ACT_IDLE" is used.
#Fire the "OnEndSequence" output.
#If a next script to play is specified, hand the NPC to the next script and repeat this process for that script.


The "MoveToPosition" input runs steps 1 and 2, then waits while playing the pre-action idle animation until the "BeginSequence" input is received.
{{tip|Multiple scripted sequences of the same name will frame-synchronize their animations once all the actors have moved to position. This allows tight interaction between actors (one actor grabbing another, hitting them, etc.)}}
{{tip|Scripted sequences can suppress various AI functions, including using [[Response System|responses]]. The input {{code|preset=1|EnableSpeakWhileScripting}} exists for [[npc_citizen|Citizens]] (and other descendants of {{code|preset=1|CAI_PlayerAlly}} class), allowing to use responses while in a scripted sequence. {{code|preset=1|DisableSpeakWhileScripting}} works the opposite way.}}


== Keyvalues ==
__TOC__
{{KV Targetname}}
{{clr}}


{{KV Parentname}}
== Script flow ==
Whenever a {{code|preset=1|scripted_sequence}} plays with a valid Target NPC, it uses a special flow to make the NPC play its animations in specific, coordinated ways:


{{KV Angles}}
# Unless the "Start on Spawn" flag ticked, the {{code|preset=1|scripted_sequence}} remains inert until it is triggered. It will remain inert until the {{code|preset=1|BeginSequence}} input is received or it is used by a previous {{code|preset=1|scripted_sequence}}.
# Upon being triggered, the {{code|preset=1|scripted_sequence}} will look for the nearest NPC specified in "Target NPC".
# When a NPC is found, it will either move to the {{code|preset=1|scripted_sequence}}'s position or begin standing still depending on the "Move to Position" setting.
# When the NPC reaches the {{code|preset=1|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 {{code|preset=1|scripted_sequence}} fires its {{code|preset=1|OnBeginSequence}} output.
# If the {{code|preset=1|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 {{code|preset=1|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 {{code|preset=1|scripted_sequence}} fires its {{code|preset=1|OnEndSequence}} output.
# If the {{code|preset=1|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.


{{KV DXLevelChoice}}
There are a few external factors which can modify this flow:


{{KV|Target NPC|target_destination|The name or class name (such as 'npc_zombie') of an NPC to use for this script.}}
* If the sequence was triggered by the "Start on Spawn" flag or the {{code|preset=1|MoveToPosition}} input, the NPC will play the Pre-Action Idle Animation until the {{code|preset=1|BeginSequence}} input was received. If {{code|preset=1|BeginSequence}} 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 the {{code|preset=1|Sleep}} input) when it was grabbed, it will awaken automatically without firing {{code|preset=1|OnWake}}.
* 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}}


{{KV|Pre Action Idle Animation|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.}}
== Keyvalues ==
 
{{KV Targetname}}
{{KV|Entry Animation|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.}}
{{KV DXLevelChoice}}
 
{{KV|Target NPC|intn=m_iszEntity|target_destination|The name or class name (such as '{{ent|npc_zombie}}') of an NPC to use for this script.}}
{{KV|Action Animation|string|The name of the main sequence (such as 'reload02') or activity (such as 'ACT_RELOAD') to play.}}
{{KV|Pre Action Idle Animation|intn=m_iszIdle|string|The name of the sequence (such as {{mono|'idle01'}}) or activity (such as {{mono|'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 {{code|preset=1|MoveToPosition}} input to play this idle animation.}}
 
{{KV|Entry Animation|intn=m_iszEntry|string|The name of the sequence (such as {{mono|'reload02'}}) or activity (such as {{mono|'ACT_RELOAD'}}) to play when the sequence starts, before transitioning to play the main action sequence.}}
{{KV|Post Action Idle Animation|string|The name of the sequence (such as 'idle01') or activity (such as 'ACT_IDLE') to play after the action animation.}}
{{KV|Action Animation|intn=m_iszPlay|string|The name of the main sequence (such as {{mono|'reload02'}}) or activity (such as {{mono|'ACT_RELOAD'}}) to play.}}
 
{{KV|Post Action Idle Animation|intn=m_iszPostIdle|string|The name of the sequence (such as {{mono|'idle01'}}) or activity (such as {{mono|'ACT_IDLE'}}) to play after the action animation.}}
{{KV|Custom Move Animation|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.}}
{{KV|Custom Move Animation|intn=m_iszCustomMove|string|Used in conjunction with the 'Custom movement' setting for the 'Move to Position' property, specifies the sequence (such as {{mono|'crouch_run01'}}) or activity (such as {{mono|'ACT_RUN'}}) to use while moving to the scripted position.}}
 
{{KV|Loop Action Animation?|intn=m_bLoopActionSequence|bool|Repeat permamently "Action animation"? See "Action Animation."}}
{{KV|Loop Action Animation?|bool|Repeat permamently "Action animation"? See "Action Animation."}}
{{KV|Synch Post Idles|intn=m_bSynchPostIdles|bool|}}
 
{{KV|Search Radius|intn=m_flRadius|float|Radius to search within for an NPC to use. 0 searches everywhere.}}
{{KV|Synch Post Idles|bool|}}
{{KV|Repeat Rate ms|intn=m_flRepeat|bool|How long NPC will repeat "Action Animation". See "Action Animation". Useless with "Loop Action Animation?"}}
 
{{KV|Move to Position|intn=m_fMoveTo|choices|How the NPC will walk to this {{code|preset=1|scripted_sequence}}.}}
{{KV|Search Radius|radius|Radius to search within for an NPC to use. 0 searches everywhere.}}
 
{{KV|Repeat Rate ms|bool|How long NPC will repeat "Action Animation". See "Action Animation". Useless with "Loop Action Animation?"}}
 
{{KV|Move to Position|choices|How the NPC will walk to this scripted_sequence.}}
:{| class=standard-table
:{| class=standard-table
! Literal Value || Description
! Literal Value || Description
Line 58: Line 63:
| 5 || No - Turn to Face
| 5 || No - Turn to Face
|}
|}
 
{{note|Despite the name, "Turn to Face" actually means turning to ''match'' scripted_sequence's ''own'' facing direction, and not the actor turning to face ''it''.}}
{{KV|Next Script|target_destination|The name of the script to run immediately after this script completes. The NPC will not return to AI between the two scripts.}}
{{note|Does not seem to do anything in {{hla|1}}, actors will simply walk}} <!-- Should be moved to the Source 2 variant of the page-->
 
{{KV|Next Script|intn=m_iszNextScript|target_destination|The name of the script to run immediately after this script completes. The NPC will not return to AI between the two scripts.}}
{{KV|Ignore Gravity on NPC during Script|bool|If this is set to 'Yes', the NPC will not be subject to gravity while playing this script}}
{{KV|Ignore Gravity on NPC during Script|intn=m_bIgnoreGravity|bool|If this is set to 'Yes', the NPC will not be subject to gravity while playing this script}}
 
{{KV|Disable NPC collisions during Script|intn=m_bDisableNPCCollisions|bool|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 {{code|preset=1|scripted_sequences}}.}}
{{KV|Disable NPC collisions during Script|bool|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.}}
{{KV|On Player death|intn=onplayerdeath|bool|If set, NPC will cancel script and return to AI.}}
 
{{KV|Post Yaw|intn=m_flPostYaw|float|The yaw direction of the target after finishing the sequence (-1 for none).|only={{bms}}}}
{{KV|On Player death|bool|If set, NPC will cancel script and return to AI.}}


== Flags ==
== Flags ==
* 4 : Repeatable
{{Fl|4|Repeatable}}
* 8 : Leave Corpse ('''Forces NPC corpse to remain rather than fade out''')
{{Fl|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|1}}-era NPCs)}}}}
* 16 : Start on Spawn - Note: this activates the "MoveTo" action only. Action Animation will occur only after the <code>scripted_sequence</code> has been otherwise triggered.
{{Fl|16|Start on Spawn|Makes the script search for a NPC and move to its position upon spawning, playing the Pre-Action Idle Animation until {{code|preset=1|BeginSequence}} is received.}}
* 32: No Interruptions ('''NPC sequence isn't allowed to be interrupted''')
{{Fl|32|No Interruptions|Prevents the NPC from being interrupted by damage, etc.}}
* 64: Override AI ('''NPC will be overridden regardless of current state''')
{{Fl|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 ('''Don't fixup end position with a teleport when the SS is finished''')
{{Fl|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 ('''Loop in the post idle animation after playing the action animation''')
{{Fl|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 spot in queue''')
{{Fl|512|Priority Script|Stops other scripts from stealing this script's spot in a NPC's queue.}}
* 1024 : Search Cyclically ('''Start search from last entity found''')
{{Fl|1024|Search Cyclically|Searches for the next entity from the last one found.|nofgd=1}}
* 2048 : No Complaints ('''Skip developer warnings''')
{{Fl|2048|No Complaints|Suppresses developer warnings.|nofgd=1}}
* 4096 : Allow NPC Death ('''The NPC using this scripted sequence may die without interrupting the scene (used for scripted deaths)''')
{{Fl|4096|Allow NPC Death|The NPC using this scripted sequence may die without interrupting the scene. (used for scripted deaths)}}


== Inputs ==
== Inputs ==
{{I Targetname}}
{{I Targetname}}
{{I Parentname}}
{{I Parentname}}
 
{{I|BeginSequence|Summons an NPC to act out the scripted sequence.|}}
{{IO|BeginSequence|Summons an NPC to act out the scripted sequence.|}}
{{I|MoveToPosition|Summons an NPC to the script location. They will play their scripted idle (or {{mono|'ACT_IDLE'}} if none is specified) until {{code|preset=1|BeginSequence}} is triggered.|}}
 
{{bug|Don't use it for {{ent|npc_antlion}}! Seems it's overriding ai behaviour, when NPC try to fly from high ground to lower as the result we have instance flying stuck with looped animation. (at least with {{src06|2}}), better use {{code|preset=1|BeginSequence}}. Also set a delay before executing this, around 0.5 or other, depends on height and how many you spawn, don't move them all at same time from window (they will stuck), set a delay!}}
{{IO|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.|}}
{{I|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.}}
 
{{I|ScriptPlayerDeath|Pretends that the player died.|since={{src06}} }}
{{IO|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 ==
== Outputs ==
{{O Targetname}}
{{O Targetname}}
 
{{O|OnBeginSequence|Fires when the action animation begins playing.|}}
{{IO|OnBeginSequence|Fires when the action animation begins playing.|}}
{{O|OnEndSequence|Fires when the action animation completes.|}}
 
{{O|OnScriptEvent01|to=OnScriptEvent08|Fires when a 'trigger' anim event occurs while playing the script. Use { event 1003 framenum ''(1-8)'' } in the QC.|}}
{{IO|OnEndSequence|Fires when the action animation completes.|}}
{{O|OnFoundNPC|only=mapbase|Fires when a target NPC is found and begins moving to play the script.|}}
 
{{IO|OnScriptEvent''(01-08)''|Fires when a 'trigger' anim event occurs while playing the script. Use { event 1003 framenum ''(1-8)'' } in the QC.|}}


== Locating animations ==
== Locating animations ==
Line 106: Line 106:
''Or''
''Or''


You can use the [http://developer.valvesoftware.com/wiki/Model_Viewer Half-life Model Viewer] tool to see all the available sequences(Animations) for the model you're using.
You can use {{hlmv|4}} 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.
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.


'''What it looks like:'''
'''What it looks like:'''
[[Image:Hlmw.jpg|500px]]
[[File:Hlmw.jpg|500px|left]] {{clr}}
<!--This screenshot is pretty useless as the HLMV page should already explain it-->


== See also ==
== See also ==
* The [[npc_zombie_prone]] and [[npc_zombie_slump]] prefabs, providing examples of use.
* The [[npc_zombie_prone]] and [[npc_zombie_slump]] prefabs, providing examples of use.
* [[Activity List]] - a list of activities for use with this entity.
* [[Activity List]] - a list of activities for use with this entity.
* [[aiscripted_schedule]] - a similar entity.
* {{ent|aiscripted_schedule}} - a similar entity.
* [[falling headcrab tutorial]] - A tutorial for how to make a headcrab fall, using this entity.
* [[Choreography Tool reference]] (mainly the "Gesture" / "Sequence" and "Move to actor" events) - choreography events that can achieve the same functionalities
* [[Falling Headcrab tutorial]] - A tutorial for how to make a headcrab fall, using this entity.
* [[Actbusy]] - An alternative to {{code|preset=1|scripted_sequence}} which doesn't involve setting a NPC in a scripted state.


[[Category:Entities]]
[[Category:Entities]]

Latest revision as of 00:04, 8 October 2025

English (en)Translate (Translate)
Scripted sequence.png

scripted_sequence is a point entity available in all Source Source games. It is used to make an NPC play scripted animations.

C++ Class hierarchy
CAI_ScriptedSequence
CBaseEntity
C++ scripted.cpp

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.

Tip.pngTip:Multiple scripted sequences of the same name will frame-synchronize their animations once all the actors have moved to position. This allows tight interaction between actors (one actor grabbing another, hitting them, etc.)
Tip.pngTip:Scripted sequences can suppress various AI functions, including using responses. The input EnableSpeakWhileScripting exists for Citizens (and other descendants of CAI_PlayerAlly class), allowing to use responses while in a scripted sequence. DisableSpeakWhileScripting works the opposite way.

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:

  1. Unless the "Start on Spawn" flag ticked, the scripted_sequence remains inert until it is triggered. It will remain inert until the BeginSequence input is received or it is used by a previous scripted_sequence.
  2. Upon being triggered, the scripted_sequence will look for the nearest NPC specified in "Target NPC".
  3. 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.
  4. 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.
  5. The scripted_sequence fires its OnBeginSequence output.
  6. 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.
  7. The NPC plays the Action Animation. If no action animation is specified in the script, it will skip this step.
  8. 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.
  9. The scripted_sequence fires its OnEndSequence output.
  10. 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 the BeginSequence input was received. If BeginSequence 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 the Sleep input) when it was grabbed, it will awaken automatically without firing OnWake.
  • 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

Name (targetname) <string>[ Edit ]
The name that other entities refer to this entity by, via Inputs/Outputs or other keyvalues (e.g. parentname or target).
Also displayed in Hammer's 2D views and Entity Report.
See also:  Generic Keyvalues, Inputs and Outputs available to all entities

Minimum / Maximum DX Level (mindxlevel / maxdxlevel) <integer choices> (removed since Left 4 Dead)
The entity will not exist if the engine is running outside the given range of DirectX Versions.
Choices
Warning.pngWarning:If these are used, the object may break when the user switches their DirectX settings.[missing string]
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? (m_bLoopActionSequence) <boolean>
Repeat permamently "Action animation"? See "Action Animation."
Synch Post Idles (m_bSynchPostIdles) <boolean>
Search Radius (m_flRadius) <float>
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
Note.pngNote:Despite the name, "Turn to Face" actually means turning to match scripted_sequence's own facing direction, and not the actor turning to face it.
Note.pngNote:Does not seem to do anything in Half-Life: Alyx, actors will simply walk
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.
Post Yaw (m_flPostYaw) <float> (only in Black Mesa)
The yaw direction of the target after finishing the sequence (-1 for none).

Flags

Repeatable : [4]
Leave Corpse : [8]
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)
Start on Spawn : [16]
Makes the script search for a NPC and move to its position upon spawning, playing the Pre-Action Idle Animation until BeginSequence is received.
No Interruptions : [32]
Prevents the NPC from being interrupted by damage, etc.
Override AI : [64]
Overrides the NPC's current state to play the script, regardless of whether they're in combat or otherwise.
Don't Teleport NPC at End : [128]
Prevents the script from teleporting the NPC to the last animation's end position when the script is finished.
Loop in Post Idle : [256]
Makes the NPC loop the Post-Action Idle Animation after it finishes playing the Action Animation.
Priority Script : [512]
Stops other scripts from stealing this script's spot in a NPC's queue.
Search Cyclically : [1024] !FGD
Searches for the next entity from the last one found.
No Complaints : [2048] !FGD
Suppresses developer warnings.
Allow NPC Death : [4096]
The NPC using this scripted sequence may die without interrupting the scene. (used for scripted deaths)

Inputs

Parentname:
SetParent <stringRedirectInput/string>
Move with this entity. See Entity Hierarchy (parenting).
SetParentAttachment <stringRedirectInput/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 <stringRedirectInput/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.
Icon-Bug.pngBug:Don't use it for npc_antlion! Seems it's overriding ai behaviour, when NPC try to fly from high ground to lower as the result we have instance flying stuck with looped animation. (at least with Source 2006 Source 2006), better use BeginSequence. Also set a delay before executing this, around 0.5 or other, depends on height and how many you spawn, don't move them all at same time from window (they will stuck), set a delay!  [todo tested in ?]
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.
ScriptPlayerDeath  (in all games since Source 2006)
Pretends that the player died.

Outputs

OnBeginSequence
Fires when the action animation begins playing.
OnEndSequence
Fires when the action animation completes.
OnScriptEvent01 to OnScriptEvent08
Fires when a 'trigger' anim event occurs while playing the script. Use { event 1003 framenum (1-8) } in the QC.
OnFoundNPC  (only in Mapbase)
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 HLMV HLMV to see all the available sequences (animations) for the model you're using.

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.

What it looks like:

Hlmw.jpg

See also