Logic choreographed scene: Difference between revisions
Jump to navigation
Jump to search

AltNames: This entity is also tied to
No edit summary |
No edit summary |
||
(53 intermediate revisions by 27 users not shown) | |||
Line 1: | Line 1: | ||
== | {{LanguageBar}} | ||
{{CD|CSceneEntity|file1=sceneentity.cpp}} | |||
{{this is a|logical entity|name=logic_choreographed_scene|sprite=choreo_scene.png}} It manages a [[:Category:Choreography|choreographed scene]] of one or more [[NPC|actors]]. | |||
For an example on how this entity can be used, see the [[npc_gman_overwatch]] prefab. | |||
__NOTOC__ | |||
{{bug|In multiplayer, the actor must be within a player's [[PVS]] in order for lines to be heard. This does not apply in {{portal2|1}}}} | |||
== | {{AltNames|name1=scripted_scene|misc=There are lines in code searching for "logic_choreographed_scene". {{todo|document side effects of using scripted_scene as classname}}}} | ||
== Keyvalues == | |||
{{KV Targetname}} | |||
{{KV|Scene file|intn=SceneFile|scene|The [[VCD]] scene file to use.}} | |||
{{KV|Target 1|intn=target1|to=Target 8|intn2=target8|target_destination|Use these keyvalues to specify the resolution of Actor or Event Target names that are using a [[Choreography_Implementation#Using_.21Target.23_Names|!Target#]] name in the VCD.}} | |||
{{KV|If an Actor is talking...|intn=busyactor|choices|What to do if an actor this scene needs is already talking when this scene is told to start.}} | |||
:* 0 : Start immediately | |||
:* 1 : Wait for actor to finish | |||
:* 2 : Interrupt at next interrupt event | |||
:* 3 : Cancel at next interrupt event | |||
{{KV|On player death|intn=onplayerdeath|choices|What should this entity do if the player dies}} | |||
:* 0 : Do Nothing | |||
:* 1 : Cancel Script and return to AI | |||
== Inputs == | |||
{{I|Start|Starts playback of the scene file}} | |||
{{I|Pause|Pauses playback of the scene file}} | |||
{{I|Resume|Resumes playback of the scene if it has been paused}} | |||
{{I|Cancel|Cancels playback of the scene}} | |||
{{I|CancelAtNextInterrupt|<code>Cancel</code>s playback of the scene at the next interrupt event in the scene.}} | |||
{{I|PitchShift|Multiplies the pitch|param=float}} | |||
{{I|InterjectResponse|Finds an actor who can respond to the specified concept string while the scene continues playing.|param=string}} | |||
:{{note|In order to use the interjection, the target actor needs to have a "Permit Responses" event (or multiple) added on the choreo timeline, and the playback needs to be within the span of those events.<br>The input parameter here is the name of the response '''concept''', ''not'' the response itself.}} | |||
:{{tip|The sole instance in which this feature is used in {{hl2|1}} is in [[A Red Letter Day|Kleiner's Lab]].<br>See {{path|sdk_d1_trainstation_05|vmf}} provided in the [[Source SDK]], and see the [[VCD]] such as {{path|<nowiki>scenes/k_lab/lab01</nowiki>|vcd}} for the Permit Responses usage.}} | |||
{{I|StopWaitingForActor|Stop waiting on an actor to stop talking.}} | |||
{{I|SetTarget1|to=SetTarget4|since=CSGO|Sets <code>target1</code> to <code>target4</code> keyvalues.|param=string}} | |||
{{I|Trigger|Triggers the given <code>OnTrigger</code> output.|param=integer|nofgd=1}} | |||
=== | == Outputs == | ||
{{O|OnStart|ac-is-this=1|The scene has started}} | |||
{{O|OnCompletion|ac-is-this=1|The scene has completed}} | |||
{{O|OnCanceled|ac-is-this=1|The scene has been canceled}} | |||
{{O|OnTrigger1|to=OnTrigger16|activator = the activator{{clarify}}|Scene trigger 1.{{clarify}}}} | |||
== See Also == | |||
* {{ent|instanced_scripted_scene}} | |||
* {{ent|logic_scene_list_manager}} | |||
* {{ent|scene_manager}} | |||
* | |||
* | |||
* | |||
[[Category:Choreography]] | |||
Latest revision as of 11:00, 23 September 2025


![]() |
---|
CSceneEntity |
![]() |

logic_choreographed_scene
is a logical entity available in all Source games. It manages a choreographed scene of one or more actors.
For an example on how this entity can be used, see the npc_gman_overwatch prefab.

scripted_scene
. There are lines in code searching for "logic_choreographed_scene". Todo: document side effects of using scripted_scene as classname
Keyvalues
- Name (targetname) <string>[ Edit ]
- The name that other entities refer to this entity by, via Inputs/Outputs or other keyvalues (e.g.
parentname
ortarget
).
Also displayed in Hammer's 2D views and Entity Report.See also: Generic Keyvalues, Inputs and Outputs available to all entities
- Target 1 (target1) to Target 8 (target8) <targetname>
- Use these keyvalues to specify the resolution of Actor or Event Target names that are using a !Target# name in the VCD.
- If an Actor is talking... (busyactor) <choices>
- What to do if an actor this scene needs is already talking when this scene is told to start.
- 0 : Start immediately
- 1 : Wait for actor to finish
- 2 : Interrupt at next interrupt event
- 3 : Cancel at next interrupt event
- On player death (onplayerdeath) <choices>
- What should this entity do if the player dies
- 0 : Do Nothing
- 1 : Cancel Script and return to AI
Inputs
- Start
- Starts playback of the scene file
- Pause
- Pauses playback of the scene file
- Resume
- Resumes playback of the scene if it has been paused
- Cancel
- Cancels playback of the scene
- CancelAtNextInterrupt
Cancel
s playback of the scene at the next interrupt event in the scene.
- PitchShift <float >
- Multiplies the pitch
- InterjectResponse <string >
- Finds an actor who can respond to the specified concept string while the scene continues playing.
Note:In order to use the interjection, the target actor needs to have a "Permit Responses" event (or multiple) added on the choreo timeline, and the playback needs to be within the span of those events.
The input parameter here is the name of the response concept, not the response itself.Tip:The sole instance in which this feature is used in Half-Life 2 is in Kleiner's Lab.
Seesdk_d1_trainstation_05.vmf
provided in the Source SDK, and see the VCD such asscenes/k_lab/lab01.vcd
for the Permit Responses usage.
- StopWaitingForActor
- Stop waiting on an actor to stop talking.
Outputs
- OnStart
- !activator = !caller = this entity
The scene has started
- OnCompletion
- !activator = !caller = this entity
The scene has completed
- OnCanceled
- !activator = !caller = this entity
The scene has been canceled
- OnTrigger1 to OnTrigger16
- !activator = the activator[Clarify]
!caller = this entity
Scene trigger 1.[Clarify]