Logic choreographed scene: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
 
 
 AltNames: This entity is also tied to
AltNames: This entity is also tied to 
		
	
| m (added link to !Target# info from the appropriate keyvalues entry) | No edit summary | ||
| (47 intermediate revisions by 23 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]] | |||
| [[Category: | |||
Latest revision as of 11:00, 23 September 2025

 
|  Class hierarchy | 
|---|
| CSceneEntity | 
|  sceneentity.cpp | 

logic_choreographed_scene  is a   logical entity  available in all  Source games. It manages a choreographed scene of one or more actors.
 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.
 AltNames: This entity is also tied to
AltNames: 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. parentnameortarget).
 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
- Cancels 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. 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. Tip:The sole instance in which this feature is used in Half-Life 2 is in Kleiner's Lab.
 See - sdk_d1_trainstation_05.vmfprovided in the Source SDK, and see the VCD such as - scenes/k_lab/lab01.vcdfor 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]


























