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

Logic choreographed scene: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
mNo edit summary
No edit summary
 
(46 intermediate revisions by 23 users not shown)
Line 1: Line 1:
#REDIRECT [[scripted_scene]]
{{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

English (en)Translate (Translate)
C++ Class hierarchy
CSceneEntity
CPointEntity
CBaseEntity
C++ sceneentity.cpp
Choreo scene.png

logic_choreographed_scene is a logical entity available in all Source 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.


Icon-Bug.pngBug:In multiplayer, the actor must be within a player's PVS in order for lines to be heard. This does not apply in Portal 2  [todo tested in ?]
AltNames.pngAltNames: This entity is also tied to 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 or target).
Also displayed in Hammer's 2D views and Entity Report.
See also:  Generic Keyvalues, Inputs and Outputs available to all entities

Scene file (SceneFile) <scene>
The VCD scene file to use.
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
Cancels playback of the scene at the next interrupt event in the scene.
PitchShift <floatRedirectInput/float>
Multiplies the pitch
InterjectResponse <stringRedirectInput/string>
Finds an actor who can respond to the specified concept string while the scene continues playing.
Note.pngNote: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.pngTip:The sole instance in which this feature is used in Half-Life 2 is in Kleiner's Lab.
See 🖿sdk_d1_trainstation_05.vmf provided in the Source SDK, and see the VCD such as 🖿scenes/k_lab/lab01.vcd for the Permit Responses usage.
StopWaitingForActor
Stop waiting on an actor to stop talking.
SetTarget1 to SetTarget4 <stringRedirectInput/string> (in all games since Counter-Strike: Global Offensive)
Sets target1 to target4 keyvalues.
Trigger <integerRedirectInput/integer> !FGD
Triggers the given OnTrigger output.

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]

See Also