Choreography Tool reference: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(added the start of a debugging section)
(formatting, needs more info / rework, so notes about what to add are written)
 
(35 intermediate revisions by 9 users not shown)
Line 1: Line 1:
==Introduction==
The main tool in {{faceposer|4|nt=0}} is the Choreography tool. This tool is used for sequencing expressions and other acting cues and previewing what the scene will look like in the engine. A scene can refer to multiple actors and thus can be used to block out fairly complicated interactions and dialogue between game characters.
<center>[[image:Faceposer_choreography_tool.jpg]]</center>


== Main interface ==
[[File:Faceposer_choreography_tool.jpg|400px|thumb|right|caption|The main Choreography tool interface.]]


The main tool in FacePoser is the choreography tool. This tool is used for sequencing expressions and other acting cues and previewing what the scene will look like in the engine. A scene can refer to multiple actors and thus can be used to block out fairly complicated interactions and dialogue between game characters.
To access the Choreography scene interface, first load a model and load any expression class files with which you are going to work.


To access the scene User interface, first load a model and load any expression class files with which you are going to work.
If you didn't have a scene file open previously, you'll see a note that no choreography data file (*.[[VCD|vcd]]) has been loaded. To create a new .vcd file, choose '''Choreography | New''' from the menus. To load an existing file, choose '''Choreography | Load…''' from the menus. If you create a new choreography file, you will have to add at least one actor. Just fill in the actor's name to the Create Actor dialog and click OK. If you hit cancel, you can still add a new actor by selecting '''Choreography | New Actor''' from the menus.


If you didn't have a scene file open previously, you'll see a note that no choreography data file (*.VCD) has been loaded. To create a new .VCD file, choose Choreography | New from the menus. To load an existing file, choose Choreography | Load… from the menus. If you create a new choreography file, you will have to add at least one actor. Just fill in the actor's name to the Create Actor dialog and click OK. If you hit cancel, you can still add a new actor by selecting Choreography | New Actor from the menus.
Once you've loaded a scene or created a new actor, you'll see a timeline at the top of the window and a list of actor(s) along the left. Each actor in the scene has one or more channels that contain one or more events that are triggered at some during playback of the scene. Although channels are mostly for convenience in editing, during playback in the engine, if two events occur at the same starting time, then the event with the lower channel (higher in the view) will be applied first.
 
To add a channel to an actor, right-click on the actor's name and choose "New Channel…" Fill in the name of the channel and choose which actor to which to add the channel and click OK. You will now see a channel appear under the specified actor's name. There is an expand/collapse button to the left of each actor's name that will show and hide the actor's channels. When the actor's channels are hidden, there is a display stating the number of channels and events being hidden. In addition, you can double click on a channel or an entire actor name to enable or disable the channels from playback preview. Disabling channels only affects the preview playback.
 
Any channel which contains one or more .WAV events can be made to show [[Closed Captions|close captioning]] (subtitle) information. This information can be shown/hidden by clicking the black triangle marker at the top left corner of the channel. When the triangle is pointed down, then the additional data is shown. The data includes a language selector (which only works if you have the foreign language versions of the game .dll available {{clarify}}). Due to timing issues, some of the dialog of the game was "split" into multiple .wav files. For the foreign versions, these .WAVs are considered "combined" into a single .wav for convenience of playback. Thus, when a .wav is selected, the right mouse menu will contain a few additional options for combining/uncombining the .wav files and disabling captions. If you are not working on a localized single-player mod, you probably won't need to pay attention to these settings.
 
== Actors ==
An actor is an [[NPC]] in your scene ([[VCD|.vcd file]]) which you will direct using Choreography events. A scene can have multiple actors, and requires at least one actor. Each actor has at least one channel into which any number and type of Choreography events can be added. For info on how to create actors and channels, go [[Choreography Tool#Introduction|here]]. For info on how to create Events, go [[Choreography Tool#Creating and editing events|here]].


Once you've loaded a scene or created a new actor, you'll see a timeline at the top of the window and a list of actor(s) along the left. Each actor in the scene has one or more channels that contain one or more events that are triggered at some during playback of the scene. Although channels are mostly for convenience in editing, during playback in the engine, if two events occur at the same starting time, then the event with the lower channel (higher in the view) will be applied first.
[[File:Actor01.jpg|frame|left|An Actor named "Bob" with 2 channels and one event]]{{clr}}


To add a channel to an actor, right-click on the actor's name and choose "New Channel…" Fill in the name of the channel and choose which actor to which to add the channel and click OK. Now you will see a channel appear under the specified actor's name. There is an expand/collapse button to the left of each actor's name. This will show and hide the actor's channels. When the actor's channels are hidden, there is a display stating the number of channels and events being hidden. In addition, you can double click on a channel or an entire actor name to enable or disable the channels from playback preview. Disabling channels only affects the preview playback.
An actor's name is significant in that its events will be applied to the [[Entity|entity]] in your map with the same name. If you name your actor "Bob" in the .vcd, all events you apply to that actor will be assigned to the entity named "Bob" in your map. Alternatively, you can name your actor "[[Choreography Implementation#Using .21Target.23|!Target#]]" (where "#" is a number between 1 and 8), and specify the target entity within the {{ent|Logic_choreographed_scene}}.


Any channel which contains one or more .WAV events can be made to show close captioning information. This information can be shown/hidden by clicking the black triangle marker at the top left corner of the channel. When the triangle is pointed down, then the additional data is shown. The data includes a language selector (which only works if you have the foreign language versions of the game .dll available). Due to timing issues, some of the dialog of the game was "split" into multiple .wav files. For the foreign versions, these .WAVs are considered "combined" into a single .wav for convenience of playback. Thus, when a .wav is selected, the right mouse menu will contain a few additional options for combining/uncombining the .wav files and disabling captions. If you are not working on a localized, single-player MOD, you probably won't need to pay attention to these settings.
An actor corresponds to an [[NPC]] in your map. Actors can be player companions like they can be player enemies; this will not make any difference.
{{note|Issues might arise if the NPCs want to attack the player during the playback of a scene. {{modernConfirm}} }}


==Choreography Events==
== Choreography Events ==


The choreography system can sequence the following types of events:
The choreography system can sequence the following types of events listed below. For how to create and edit events, go [[Choreography Tool#Creating and editing events|here]].


===Expression===
=== Expression ===


The actor blends into the specified expression at the start time of the event, holds the pose for the duration of the event. Note that an actor can play multiple expressions simultaneously (you should consider putting the overlapped expressions in additional actor channels). The weight of the expression can be varied over time using the Ramp Tool (more later).
The actor blends into the specified expression at the start time of the event, holds the pose for the duration of the event. Note that an actor can play multiple expressions simultaneously (you should consider putting the overlapped expressions in additional actor channels). The weight of the expression can be varied over time using the Ramp Tool (more later).


===Gesture===
=== Gesture ===
 
This makes the actor play a specified gesture animation. A gesture is a special type of sequence that can be scaled and altered using internal tags.
 
 
Detailed info about creating and using Gestures can be found here (link forthcoming). 
 
 
You can re-time gestures in the Choreography view by simply moving the tags of the Gesture event. Alternatively, you can use the [[Other FacePoser Tools#Gesture Tool|Gesture Tool]] to retime the tags.
 
You can use the [[Other FacePoser Tools#Ramp Tool|Ramp Tool]] to change the magnitude of the gesture animation over time.
 
By default, multiple gestures within a channel will crossfade between each other, and so the "end" tag of the first gesture event will be locked to the "apex" tag of the second gesture. To override this behavior, place a "NULL Gesture" event in between the two Gesture events. This is shown in the following illustration:
 
{{todo|NULL gestures are deprecated.}}
 
[[File:Choreo GestureEvent01.jpg|frame|left|Multiple Gesture events placed in the same channel will force alignment of the "end" and "apex" tags.  Place a "NULL Gesture" event in between 2 gestures to override this automatic tag alignment.]]
{{clr}}
 
=== Sequence ===
 
Tells the actor to play a specific animation sequence. Gestures are usually preferred because of their ability to be scaled.
 
=== WAV File/Speak event ===
 
The actor plays back a [[Soundscripts|soundcsript]] (it can also refer to raw [[WAV|.wav]] files, but such usage is discouraged) that contains phonemes (and hence visemes) tags created by the phoneme extractor. Click the "Show all sounds" button to see sounds not marked at <code>CHAN_VOICE</code> in the {{path|game_sounds_*|txt|icon=file}} files, otherwise, the list is restricted to such files. You can also choose a raw .wav file using the '''Choose File…''' button or by typing in the relative path into the Speak .WAV combo box text file.
 
=== Look at actor ===
 
The actor looks at another named actor or entity existing in the map. A "Look At" event will only use the eyes, head and neck.
{{tip|Tie a [[BSP_(Source)|.bsp]] to the scene file to access the entity names in the map.}}
 
The [[Other FacePoser Tools#Ramp Tool|Ramp Tool]] can be used to change the magnitude of the event over time. A magnitude of 0% means that only the eyes will try to look at the target (no head/neck rotation). A magnitude of 100% means the actor will try to turn his entire head towards the target.


The actor triggers the named gesture. Gestures have a relative timing curve that can be edited in the Gesture Tool (more later). Multiple gestures within a channel imply a crossfade between each other. "NULL Gesture" events can be used to force a cross fade cutoff.
If the "Look At" target is behind the actor, or outside a certain angle of view, the actor will not attempt to look at the target.
{{todo|Find the threshold value.}}


===Sequence===
Specifying the "Look At target" as <code>!self</code> means that the actor will look at nothing specifically, and the actor's idle look behavior will be disabled for as long as the event is active (the AI wont make the actor look at random positions over time, but rather just look straight ahead). This is useful for when the idle look behavior would be inappropriate and you want to specifically suppress it, such as if the actor is sleeping or knocked out for some time in the scene.


Tells the actor to play a specific animation sequence
=== Move to actor ===


===WAV File/Speak event===
The actor moves to a specified target. The target can be just about any named entity ({{ent|info_target}} is commonly used), including other [[NPC|NPCs]] or the player (with <code>!player</code>).


The actor plays back a sound name as enumerated in the various game_sounds.txt files (this can also refer to raw .wav files, but such usage is discouraged) that contains phoneme (and hence viseme) tags created by the phoneme editor/extractor tool (PhonemeEditor). Click the "Show all sounds" button to see sounds not marked at CHAN_VOICE in the sounds.txt files, otherwise, the list is restricted to such files. You can also choose a raw .wav file using the Choose File… button or by typing in the relative path into the Speak .WAV combo box text file
A "Move To" event can specify what navigation sequence or activity to use while en route to the target; the default is ''Walk'', but you can select ''Run'' or ''CrouchWalk'' from the dropdown menu, or alternatively type in the name of a specific sequence to use.
{{modernConfirm|An earlier iteration of this section says that ''CrouchRun'' is a valid activity, is this true in older branches or is this wrong ?}}


===Look at===
A Stop Distance can be defined for a "Move To" event. The actor will complete his "Move To" when he reaches this distance from the target. The default Stop Distance is 0 units. If the "Move To" target is a player or [[NPC]], you'll want to set the Stop Distance to a large enough value that the Actor doesn't get in the way of the target player/[[NPC]]. The following illustrates the "Move To" event's properties:


The actor looks at another named actor or entity existing in the mapLook ats will only use the eyes, head and neck.
[[File:Choreo MoveToEvent01.jpg|frame|left|Move To event propertiesIn this case, the Actor will run to within 72 units of the Player.]] {{clr}}


===Move to===


The actor moves to another named actor's area of the scene or to a specified target. When editing this event you can place a preview pitch/yaw to use for posing the scene. This is ignored by the engine, but is useful for making sure the actors move their heads as scripted in the .VCD file.
Note that the actor uses the [[AI|Source engine AI system]] to perform the actual move. If the player or obstacles are in the way, then the move can take longer or shorter than originally expected. If the completion of the move is critical to continuing the scene, then you should consider inserting a scene "[[Choreography Tool#Global Pauses .28Interrupts.29|Pause]]" point during the move and marking the move as a "Resume Condition". This will cause the scene to automatically resume playing once the actor finally reaches their mark.


Note that the actor uses the Source engine AI system to perform the actual move. If the player or obstacles are in the way, then the move can take longer or shorter than originally expected. If the completion of the move is critical to continuing the scene, then you should consider inserting a scene "Pause" point during the move and marking the move as a "Resume Condition". This will cause the scene to automatically resume playing once the actor finally reaches his or her mark.
{{todo|document <code>param3</code>}}


===Face===
=== Face actor ===


The actor faces one of the other actors in the scene.
The actor faces one of the other actors in the scene. Unlike for "Look at actor", this will make the actor move its legs (if the "Lock facing" checkbox isn't checked) and its torso to face the target.


===Flex animation===
=== Flex animation ===


Allows for animation of individual flex sliders along splines over the time of the animation (See Expression Tool, below).
Allows for animation of individual flex sliders along splines over the time of the animation. Flex animation events are edited using the [[Other FacePoser Tools#Flex Animation Tool|Flex Animation Tool]].


===Fire Trigger===
=== Fire Trigger ===


Fires an AI trigger.
Fires an AI trigger. For more information, see [[Scene Triggers]].


===Generic===
=== Generic(AI) ===


This is passed to code in CSceneEntity in the game .dll code for processing.
This is passed to code in CSceneEntity in the game .dll code for processing.
{{todo|make this actually helpful.}}


===Sub-scene===
=== Sub-scene ===


A top-level .VCD can drive simulation of one or more "sub-scenes" which are embedded. Note that these sub-scenes themselves cannot have any additional layers of sub-scenes (for now).
A top-level .vcd file can drive simulation of one or more "sub-scenes" which are embedded. Note that these sub-scenes themselves cannot have any additional layers of sub-scenes.
{{todo|example ?}}


===Permit Responses===
=== Permit Responses ===


At certain times during a scene, an actor might not be speaking and if the player is doing something which generates an response from the response system, then if the actor's scene is at a time when a "Permit Responses" event is allowed, then the actor can play the interjected response while continuing to be an actor in the .VCD.
At certain times during a scene, an actor might not be speaking and if the player is doing something which generates a response from the response system, then if the actor's scene is at a time when a "Permit Responses" event is allowed, then the actor can play the interjected response while continuing to be an actor in the .vcd file.


Note that for looking, moving, and facing, it is also possible to have the actor face the "first person player" by selecting the "!player" as the target actor name. Other options are "!self", "!enemy", "!friend", and "!target#" where the targets are defined by the level designer placing an associated <code>logic_choreographed_scene</code> entity in a map.
{{note|For looking, moving, and facing, it is also possible to have the actor face the player by selecting the <code>!player</code> as the target actor name. Other options are <code>!self</code>, <code>!enemy</code>, <code>!friend</code>, and <code>!target#</code> where the targets are defined by the level designer placing an associated {{ent|logic_choreographed_scene}} entity in a map.}}


==Creating and editing events==
== Creating and editing events ==


To create an event, right-click in any channel area of any actor to whom you want to add an event. Note that the mouse click position is the starting time for any event created (the timing can be changed). Choose "New Event | Expression", e.g., from the menu. Here you will be able to choose the expression (from the currently opened expression class), set a name, and alter the start and end time (most events have a start and end time, although some are "fire and forget") for the event. Set the values and choose OK to create the event. Note that start times can be relative to any existing timing tags embedded in relation to other events in the scene, such as SPEAK events. If you move the SPEAK event or the tag within the event, any relatively offset events will be moved along with the SPEAK event. Furthermore, depending on the type of event, there are additional parameters that show up in the various Add/Edit event dialogs.
To create an event, right-click in any channel area of any actor to whom you want to add an event. Note that the mouse click position is the starting time for any event created (the timing can be changed). Choose '''New Event | Expression''' (e.g., from the menu); here you will be able to choose the expression (from the currently opened expression class), set a name, and alter the start and end time (most events have a start and end time, although some are "fire and forget") for the event. Set the values and choose OK to create the event. Note that start times can be relative to any existing timing tags embedded in relation to other events in the scene, such as .WAV events. If you move the .WAV event or the tag within the event, any relatively offset events will be moved along with the .WAV event. Furthermore, depending on the type of event, there are additional parameters that show up in the various Add/Edit event dialogs.


The new event will show up in the channel area of the current actor. Because the above example created an Expression, a face icon will show up under the bar showing the duration of the event. You can drag the bar with the left mouse button to move the event. Hovering the mouse or clicking near the left/right edge will show a sizing cursor allowing you to change the start or end time by clicking and dragging with the mouse button at that point.
The new event will show up in the channel area of the current actor. Because the above example created an expression, a face icon will show up under the bar showing the duration of the event. You can drag the bar with the left mouse button to move the event. Hovering the mouse or clicking near the left/right edge will show a sizing cursor allowing you to change the start or end time by clicking and dragging with the mouse button at that point.


To delete and event, right-click it and choose Delete from the menu or press the "Del" key on your keyboard.
To delete and event, right-click it and choose Delete from the menu or press the {{key|Del}} key.


You can also edit event properties by right-clicking on the event and choosing "Edit | Event <name>". Alternatively, you can press Alt-Enter to edit the selected event.
You can also edit event properties by right-clicking on the event and choosing '''Edit | Event <name>'''. Alternatively, you can press {{key|Alt|Enter}} to edit the selected event{{modernConfirm}}.


Further details about any event under the mouse are shown along the bottom of the Choreography Editor.
Further details about any event under the mouse are shown along the bottom of the Choreography Editor.


==Using the timeline==
== Using the timeline ==


There is some additional information in the time line at the top of the screen. First, (depending on how much of the scene you can see based on your current zoom level) there is a dashed blue line showing the end time of the final event in the scene. In addition, there are typical VCR controls (Play, Pause and Stop) in the top left of the tool window. The Space bar can also be used to play or stop the scene. If you click the play button and have some active events, they will be played back for viewing in the 3d view area. Clicking play will show a green time scrubber at the top as it moves from left to right. If the current playback time is not within the view, the current time is still printed at the top left.
There is some additional information in the time line at the top of the screen. First, (depending on how much of the scene you can see based on your current zoom level) there is a dashed blue line showing the end time of the final event in the scene. In addition, there are typical VCR controls (Play, Pause and Stop) in the top left of the tool window. The Space bar can also be used to play or stop the scene. If you click the play button and have some active events, they will be played back for viewing in the 3d view area. Clicking Play will show a green time scrubber at the top as it moves from left to right. If the current playback time is not within the view, the current time is still printed at the top left.


If you left-click and drag a scrubber, the current scrub position is shown with a vertical bar.
If you left-click and drag a scrubber, the current scrub position is shown with a vertical bar.
Line 91: Line 136:
The Choreography view also has a slider for changing the playback rate, so you can watch the preview in faster or slower than normal speed.
The Choreography view also has a slider for changing the playback rate, so you can watch the preview in faster or slower than normal speed.


If you move the mousewheel in an active tool (or, in a few cases where the mousewheel already performs another function, hold Shift and move the mousewheel) then the tool will zoom in/out based on the movement of the mousewheel.
If you move the mouse wheel in an active tool (or, in a few cases where the mouse wheel already performs another function, hold Shift and move the mouse wheel) then the tool will zoom in/out based on the movement of the mouse wheel.
{{todo|Shorten}}
 
Events that don't have an end time (i.e., which are just triggered at the start time) are shown without a "sizing" bar and can only be moved left or right in time by dragging them around. To specify an end time, right-click on the event and edit the end time and check the checkbox next to "End Time". (Note: the End Time must be after the Start Time). A negative end time (generally of -1.0) is the same as specifying "no end time".


Events that don't have an end time (i.e., which are just triggered at the start time) are shown without a "sizing" bar and can only be moved left or right in time by dragging them around. To specify an end time, right-click on the event and edit the end time and check the checkbox next to End Time. (Note: the End Time must be after the Start Time). An end time of -1.0 is the same as specifying "no end time".
=== Scrubber ===
Various tools in {{faceposer|4|nt=0}} use a scrubber. The scrubbers all match the current playback time. You can click and drag a scrubber to manually play the scene forward or backward. Or you can click in the horizontal tray where the scrubber is drawn to have the scrubber automatically play until the clicked position. Note that all of the scrubbers across all of the tools in {{faceposer|1|nt=0}} are synchronized to each other.


===Scrubber===
=== Global Pauses (Interrupts) ===
Various tools in FacePoser use a scrubber. The scrubbers all match the current playback time. You can click and drag a scrubber to manually play the scene forward or backward. Or you can click in the horizontal tray where the scrubber is drawn to have the scrubber automatically play until the clicked position. Note that all of the scrubbers across all of the tools in FacePoser are synchronized to each other.
A scene can have "global" Pause events placed. To create a Pause event, right-click anywhere in the channel name or channel tray for any actor and choose '''New Section Pause…''' from the menu. You can give the section pause a name, and you can have the section pause optionally perform an automatic action. The need for the section pause events arises out of the need for triggering of certain events that have ambiguous end times. For instance, as noted above, a "move to" event might be triggered which will cause the [[AI]] to start the actor moving to their next position. Due to obstacles, movement speed, etc., it is not possible to exactly determine how long it will take the actor to arrive at the location. This is a good location for a Pause event. In general, you can simply institute a section pause just after issuing the "Move To" event to an actor. The AI system will later notify the scene that the "Resume Condition" for the pause has been satisfied (assuming you checked the "Resume condition" checkbox in the event properties for the events overlapping the Pause point).


===Global Pauses (Interrupts)===
In other words, you would tag the "Move to" event that you are waiting for as a "Resume Condition". To tag an event as a resume condition, you can right-click on the event in the channel tray and edit its properties and click the check box labeled: "Event must complete for paused scene to resume".
A scene can have "global" Pause events placed. To create a Pause event, right-click anywhere in the channel name or channel tray for any actor and choose "New Section Pause…" from the menu. You can give the section pause a name, and you can have the section pause optionally perform an automatic action. The need for the section pause events arises out of the need for triggering of certain events that have ambiguous end times. For instance, as noted above, a "move to" event might be triggered which will cause the AI to start the actor moving to his/her next position. Due to obstacles, movement speed, etc., it is not possible to exactly determine how long it will take the actor to arrive at the location. This is a good location for a Pause event. In general, you can simply institute a section pause just after issuing the "Move To" event to an actor. The AI system will later notify the scene that the "Resume Condition" for the pause has been satisfied (assuming you checked the "Resume condition" checkbox in the event properties for the events overlapping the Pause point).


In other words, you would tag the "move to" event that you are waiting for as a "Resume Condition". To tag an event as a resume condition, you can right-click on the event in the channel tray and edit its properties and click the check box labeled: "Event must complete for paused scene to resume".
This is the most common use of the Pause event; used in conjunction with a "move to" event to ensure the actor reaches his mark before continuing the scene.  Use this technique when there are subsequent scene events that are location specific (e.g. pushing a button, typing on a keyboard, speaking into a microphone, entering a room, etc). During the production of {{hl2|4|nt=0}}, this technique was considered one of the "sledgehammer" methods of directing actors because it effectively guarantees the actor will reach their mark.


It is possible that an actor being told to move to a spot, etc., can fail to arrive in that spot for some reason. In this case, the scene designer can decide to automatically take one of two actions: 1) resume the scene anyway, or 2) cancel playback of the rest of the scene. To set the automatic resume action, right-click on the blue triangle marker for the "Section Pause" event and choose "Edit" from the menu. In the properties dialog, you'll notice a checkbox next to the word "Automatically". If you check this box, then you can choose what action to automatically perform. The drop-down list allows you to choose to either "Resume" or "Cancel" and the final text entry area allows you to specify how long of a delay to allow before automatically taking action.
One of the more subtle (and powerful) aspects of Pause events is in being able to control when the scene will resume with respect to the completion of the "resume condition" event. In other words, you can have it so the scene anticipates the event completion by some specified amount of time, and resumes the scene that much time prior to the actual event completion. This is very useful for having paused scenes resume with a certain natural overlap of events. To specify that the scene resumes some time prior to the event completion, you want to have the event extend that much time past the intersecting Pause event. The following image illustrates this technique:


During playback of the scene in the engine, if any AI event that is marked as a "resume condition" takes less time than the "automatic" action you've specified, the automatic action is skipped since it was not needed.
[[File:Pause01.jpg|frame|left|In this illustration note how the "move to" event extends about 2 seconds past the Pause event. This means the scene will resume about 2 secondss before the actor reaches their mark. Effectively the actor will start speaking their line as they approach their mark.]] {{clr}}


===Loop point===
In the case that the designer doesn't want the scene to remain paused past a certain length of time, the scene designer can decide to automatically take one of two actions: 1) resume the scene anyway, or 2) cancel playback of the rest of the scene. To set the automatic resume action, right-click on the blue triangle marker for the "Section Pause" event and choose "Edit" from the menu. In the properties dialog, you'll notice a checkbox next to the word "Automatically". If you check this box, then you can choose what action to automatically perform. The drop-down list allows you to choose to either "Resume" or "Cancel" and the final text entry area allows you to specify how long of a delay to allow before automatically taking action.
Like the Section Pause event, the "Loop" point event is similarly a global trigger for the scene. Instead of pausing however, the Loop point event allows resetting the .VCD clock backward to the beginning of the .VCD or to a specified time offset. Using this event near the end of your .VCD is useful for making it loop. You can specify that the event should loop a set number of times, maximum, or that it loops forever by editing the Loop point's properties.


==Other Choreography Features==
During playback of the scene in the engine, if any AI event that is marked as a "resume condition" takes less time than the "automatic" action you've specified, the automatic action is skipped since it was not needed.


* In general you cannot accidentally move events between channels. To drag an event from one channel to another, hold down Shift as you are dragging.
=== Loop point ===
* Because multiple events can overlap in a single channel, the right mouse menu on an event has a "Move event <name> to back option" which can make it easier to see and select underlying events. In addition, FacePoser will expand the layout of the channel vertically to accommodate overlapping events.
Like the Section Pause event, the "Loop" point event is similarly a global trigger for the scene. Instead of pausing however, the Loop point event allows resetting the .vcd clock backward to the beginning of the .vcd or to a specified time offset. Using this event near the end of your .vcd is useful for making it loop. You can specify that the event should loop a set number of times, maximum, or that it loops forever by editing the Loop point's properties. If you have a Loop Point that loops forever, you can break that loop by Canceling the scene through the {{ent|logic_choreographed_scene}} entity in {{hammer|4}}.
* Events can be copied to and pasted from the clipboard from the right mouse menu.
* Events can be exported and imported from simple event text files (also from the right mouse menu).
* You can see the Ramp of all events only by choosing "Ramp only" from the right-click menu.
* You can ask the FacePoser to verify that all animation sequences are valid (i.e., non-looping if needed and of correct duration) by choosing "Check sequences"
* You can turn off sequence processing from the preview (keeping the camera mostly on the actors' faces) by un-checking the "Process sequences" menu option.
* Because the FacePoser supports multiple actors you should associate the .VCD actor slots with loaded .MDLs. You can do this from the right-click menu or from the models tab in the main window tool area at the bottom right of the application.
* You can also associate a .BSP or map file with a .VCD, so that the relative positions of targets and the names of other actors/entities can be loaded when browsing in various properties dialogs.


==Debugging==
It is important to note that the loop ''begins'' looping at the Loop Point and jumps ''back'' to the time you have specified in the properties (by default it is set to 0).


'''Useful In-Game Console Commands'''
[[File:Edit_Loop_Point_1.jpg|frame|left|Here is an example of a simple loop.  You will notice that the Start Time is ''after'' the Loop To time in the timeline.]] {{clr}}


''NOTE:'' "developer" must be set to 1 for these to work.
=== Fire Completion ===
Fire Completion events define a custom completion time for a scene. By default, a scene is completed when the last event in a .vcd file finishes, and is denoted by a dark blue dotted line. A Fire Completion event will mark off a scene’s completion by shifting the default completion time to the value specified in said event.


*''scene_flush''
In more practical terms, the Fire Completion event is the point in the scene where the {{ent|logic_choreographed_scene}} entity fires its <code>OnCompletion</code> output. Hence you can use this event to precisely time when that output is fired with respect to other events in your scene.
"scene_flush" will reload all scenes the current map is using. Restarting a map will not automatically reload your changed scenes so if you are actively working in a vcd with the engine open, be sure to use ‘sceneflush’ so your new changes show up.


*''scene_print''
== Other Choreography Features ==
Setting scene_print to 1 will show debug information in the console for the currently playing scenes.


*''scene_showfaceto''
* In general you cannot accidentally move events between channels. To drag an event from one channel to another, hold down {{key|Shift}} as you are dragging.
Setting to 1 will turn on debugging to visually display where an actor is trying to face when a face-to is active for that actor.
* Because multiple events can overlap in a single channel, the right mouse menu on an event has a '''Move event <name> to back option''' which can make it easier to see and select underlying events. In addition, {{faceposer|4|nt=0}} will expand the layout of the channel vertically to accommodate overlapping events.
* Events can be copied to and pasted from the clipboard from the right mouse menu.
* Events can be exported and imported from simple event text files (also from the right mouse menu).
* You can see the Ramp of all events only by choosing "Ramp only" from the right-click menu.
* You can ask the {{faceposer|2|nt=0}} to verify that all animation sequences are valid (i.e., non-looping if needed and of correct duration) by choosing "Check sequences"
* You can turn off sequence processing from the preview (keeping the camera mostly on the actors' faces) by un-checking the "Process sequences" menu option.
* Because {{faceposer|2|nt=0}} supports multiple actors, you should associate the actor slots with loaded [[MDL|.MDLs]]. You can do this from the right-click menu or from the models tab in the main window tool area at the bottom right of the application.
* You can also associate a [[Bsp_(Source)|.BSP]] with a .vcd, so that the relative positions of targets and the names of other actors/entities can be loaded when browsing in various properties dialogs.


*''scene_showlook''
== Debugging ==
Setting to 1 will turn on debugging to visually display where an actor is trying to look when a look-at is active for that actor.


*''scene_showmoveto''
{{note|{{cmd|developer}} must be set to 1 for these to work.}}
Setting to 1 will turn on debugging to visually display where an actor is trying to move to when a move-to is active for that actor.  A box will show at their destination with an arrow being displayed between the actor and the destination.


;<code>scene_flush</code>
:This will reload all scenes the current map is using. Restarting a map will not automatically reload your changed scenes so if you are actively working in a .vcd with the engine open, be sure to use {{cmd|scene_flush}} so your new changes show up.
;<code>scene_print</code>
:Setting to 1 will show debug information in the console about the played events.
;<code>scene_showfaceto</code>
:Setting to 1 will turn on debugging to visually display where an actor is trying to face when a face-to is active for that actor.
;<code>scene_showlook</code>
:Setting to 1 will turn on debugging to visually display where an actor is trying to look when a look-at is active for that actor.
;<code>scene_showmoveto</code>
:Setting to 1 will turn on debugging to visually display where an actor is trying to move to when a move-to is active for that actor. A box will show at their destination with an arrow being displayed between the actor and the destination.


[[category:Choreography]]
[[Category:Choreography]]
[[category:Tools]]
[[Category:Tools]]

Latest revision as of 15:31, 23 May 2025

The main tool in HLFaceposer Faceposer is the Choreography tool. This tool is used for sequencing expressions and other acting cues and previewing what the scene will look like in the engine. A scene can refer to multiple actors and thus can be used to block out fairly complicated interactions and dialogue between game characters.

Main interface

The main Choreography tool interface.

To access the Choreography scene interface, first load a model and load any expression class files with which you are going to work.

If you didn't have a scene file open previously, you'll see a note that no choreography data file (*.vcd) has been loaded. To create a new .vcd file, choose Choreography | New from the menus. To load an existing file, choose Choreography | Load… from the menus. If you create a new choreography file, you will have to add at least one actor. Just fill in the actor's name to the Create Actor dialog and click OK. If you hit cancel, you can still add a new actor by selecting Choreography | New Actor from the menus.

Once you've loaded a scene or created a new actor, you'll see a timeline at the top of the window and a list of actor(s) along the left. Each actor in the scene has one or more channels that contain one or more events that are triggered at some during playback of the scene. Although channels are mostly for convenience in editing, during playback in the engine, if two events occur at the same starting time, then the event with the lower channel (higher in the view) will be applied first.

To add a channel to an actor, right-click on the actor's name and choose "New Channel…" Fill in the name of the channel and choose which actor to which to add the channel and click OK. You will now see a channel appear under the specified actor's name. There is an expand/collapse button to the left of each actor's name that will show and hide the actor's channels. When the actor's channels are hidden, there is a display stating the number of channels and events being hidden. In addition, you can double click on a channel or an entire actor name to enable or disable the channels from playback preview. Disabling channels only affects the preview playback.

Any channel which contains one or more .WAV events can be made to show close captioning (subtitle) information. This information can be shown/hidden by clicking the black triangle marker at the top left corner of the channel. When the triangle is pointed down, then the additional data is shown. The data includes a language selector (which only works if you have the foreign language versions of the game .dll available [Clarify]). Due to timing issues, some of the dialog of the game was "split" into multiple .wav files. For the foreign versions, these .WAVs are considered "combined" into a single .wav for convenience of playback. Thus, when a .wav is selected, the right mouse menu will contain a few additional options for combining/uncombining the .wav files and disabling captions. If you are not working on a localized single-player mod, you probably won't need to pay attention to these settings.

Actors

An actor is an NPC in your scene (.vcd file) which you will direct using Choreography events. A scene can have multiple actors, and requires at least one actor. Each actor has at least one channel into which any number and type of Choreography events can be added. For info on how to create actors and channels, go here. For info on how to create Events, go here.

An Actor named "Bob" with 2 channels and one event


An actor's name is significant in that its events will be applied to the entity in your map with the same name. If you name your actor "Bob" in the .vcd, all events you apply to that actor will be assigned to the entity named "Bob" in your map. Alternatively, you can name your actor "!Target#" (where "#" is a number between 1 and 8), and specify the target entity within the Logic_choreographed_scene.

An actor corresponds to an NPC in your map. Actors can be player companions like they can be player enemies; this will not make any difference.

Note.pngNote:Issues might arise if the NPCs want to attack the player during the playback of a scene. [confirm]

Choreography Events

The choreography system can sequence the following types of events listed below. For how to create and edit events, go here.

Expression

The actor blends into the specified expression at the start time of the event, holds the pose for the duration of the event. Note that an actor can play multiple expressions simultaneously (you should consider putting the overlapped expressions in additional actor channels). The weight of the expression can be varied over time using the Ramp Tool (more later).

Gesture

This makes the actor play a specified gesture animation. A gesture is a special type of sequence that can be scaled and altered using internal tags.


Detailed info about creating and using Gestures can be found here (link forthcoming).


You can re-time gestures in the Choreography view by simply moving the tags of the Gesture event. Alternatively, you can use the Gesture Tool to retime the tags.

You can use the Ramp Tool to change the magnitude of the gesture animation over time.

By default, multiple gestures within a channel will crossfade between each other, and so the "end" tag of the first gesture event will be locked to the "apex" tag of the second gesture. To override this behavior, place a "NULL Gesture" event in between the two Gesture events. This is shown in the following illustration:

Todo: NULL gestures are deprecated.
Multiple Gesture events placed in the same channel will force alignment of the "end" and "apex" tags. Place a "NULL Gesture" event in between 2 gestures to override this automatic tag alignment.

Sequence

Tells the actor to play a specific animation sequence. Gestures are usually preferred because of their ability to be scaled.

WAV File/Speak event

The actor plays back a soundcsript (it can also refer to raw .wav files, but such usage is discouraged) that contains phonemes (and hence visemes) tags created by the phoneme extractor. Click the "Show all sounds" button to see sounds not marked at CHAN_VOICE in the Filegame_sounds_*.txt files, otherwise, the list is restricted to such files. You can also choose a raw .wav file using the Choose File… button or by typing in the relative path into the Speak .WAV combo box text file.

Look at actor

The actor looks at another named actor or entity existing in the map. A "Look At" event will only use the eyes, head and neck.

Tip.pngTip:Tie a .bsp to the scene file to access the entity names in the map.

The Ramp Tool can be used to change the magnitude of the event over time. A magnitude of 0% means that only the eyes will try to look at the target (no head/neck rotation). A magnitude of 100% means the actor will try to turn his entire head towards the target.

If the "Look At" target is behind the actor, or outside a certain angle of view, the actor will not attempt to look at the target.

Todo: Find the threshold value.

Specifying the "Look At target" as !self means that the actor will look at nothing specifically, and the actor's idle look behavior will be disabled for as long as the event is active (the AI wont make the actor look at random positions over time, but rather just look straight ahead). This is useful for when the idle look behavior would be inappropriate and you want to specifically suppress it, such as if the actor is sleeping or knocked out for some time in the scene.

Move to actor

The actor moves to a specified target. The target can be just about any named entity (info_target is commonly used), including other NPCs or the player (with !player).

A "Move To" event can specify what navigation sequence or activity to use while en route to the target; the default is Walk, but you can select Run or CrouchWalk from the dropdown menu, or alternatively type in the name of a specific sequence to use.

Confirm:An earlier iteration of this section says that CrouchRun is a valid activity, is this true in older branches or is this wrong ?

A Stop Distance can be defined for a "Move To" event. The actor will complete his "Move To" when he reaches this distance from the target. The default Stop Distance is 0 units. If the "Move To" target is a player or NPC, you'll want to set the Stop Distance to a large enough value that the Actor doesn't get in the way of the target player/NPC. The following illustrates the "Move To" event's properties:

Move To event properties. In this case, the Actor will run to within 72 units of the Player.


Note that the actor uses the Source engine AI system to perform the actual move. If the player or obstacles are in the way, then the move can take longer or shorter than originally expected. If the completion of the move is critical to continuing the scene, then you should consider inserting a scene "Pause" point during the move and marking the move as a "Resume Condition". This will cause the scene to automatically resume playing once the actor finally reaches their mark.

Todo: document param3

Face actor

The actor faces one of the other actors in the scene. Unlike for "Look at actor", this will make the actor move its legs (if the "Lock facing" checkbox isn't checked) and its torso to face the target.

Flex animation

Allows for animation of individual flex sliders along splines over the time of the animation. Flex animation events are edited using the Flex Animation Tool.

Fire Trigger

Fires an AI trigger. For more information, see Scene Triggers.

Generic(AI)

This is passed to code in CSceneEntity in the game .dll code for processing.

Todo: make this actually helpful.

Sub-scene

A top-level .vcd file can drive simulation of one or more "sub-scenes" which are embedded. Note that these sub-scenes themselves cannot have any additional layers of sub-scenes.

Todo: example ?

Permit Responses

At certain times during a scene, an actor might not be speaking and if the player is doing something which generates a response from the response system, then if the actor's scene is at a time when a "Permit Responses" event is allowed, then the actor can play the interjected response while continuing to be an actor in the .vcd file.

Note.pngNote:For looking, moving, and facing, it is also possible to have the actor face the player by selecting the !player as the target actor name. Other options are !self, !enemy, !friend, and !target# where the targets are defined by the level designer placing an associated logic_choreographed_scene entity in a map.

Creating and editing events

To create an event, right-click in any channel area of any actor to whom you want to add an event. Note that the mouse click position is the starting time for any event created (the timing can be changed). Choose New Event | Expression (e.g., from the menu); here you will be able to choose the expression (from the currently opened expression class), set a name, and alter the start and end time (most events have a start and end time, although some are "fire and forget") for the event. Set the values and choose OK to create the event. Note that start times can be relative to any existing timing tags embedded in relation to other events in the scene, such as .WAV events. If you move the .WAV event or the tag within the event, any relatively offset events will be moved along with the .WAV event. Furthermore, depending on the type of event, there are additional parameters that show up in the various Add/Edit event dialogs.

The new event will show up in the channel area of the current actor. Because the above example created an expression, a face icon will show up under the bar showing the duration of the event. You can drag the bar with the left mouse button to move the event. Hovering the mouse or clicking near the left/right edge will show a sizing cursor allowing you to change the start or end time by clicking and dragging with the mouse button at that point.

To delete and event, right-click it and choose Delete from the menu or press the Del key.

You can also edit event properties by right-clicking on the event and choosing Edit | Event <name>. Alternatively, you can press Alt+ Enter to edit the selected event[confirm].

Further details about any event under the mouse are shown along the bottom of the Choreography Editor.

Using the timeline

There is some additional information in the time line at the top of the screen. First, (depending on how much of the scene you can see based on your current zoom level) there is a dashed blue line showing the end time of the final event in the scene. In addition, there are typical VCR controls (Play, Pause and Stop) in the top left of the tool window. The Space bar can also be used to play or stop the scene. If you click the play button and have some active events, they will be played back for viewing in the 3d view area. Clicking Play will show a green time scrubber at the top as it moves from left to right. If the current playback time is not within the view, the current time is still printed at the top left.

If you left-click and drag a scrubber, the current scrub position is shown with a vertical bar.

The Choreography view also has a slider for changing the playback rate, so you can watch the preview in faster or slower than normal speed.

If you move the mouse wheel in an active tool (or, in a few cases where the mouse wheel already performs another function, hold Shift and move the mouse wheel) then the tool will zoom in/out based on the movement of the mouse wheel.

Todo: Shorten

Events that don't have an end time (i.e., which are just triggered at the start time) are shown without a "sizing" bar and can only be moved left or right in time by dragging them around. To specify an end time, right-click on the event and edit the end time and check the checkbox next to "End Time". (Note: the End Time must be after the Start Time). A negative end time (generally of -1.0) is the same as specifying "no end time".

Scrubber

Various tools in HLFaceposer Faceposer use a scrubber. The scrubbers all match the current playback time. You can click and drag a scrubber to manually play the scene forward or backward. Or you can click in the horizontal tray where the scrubber is drawn to have the scrubber automatically play until the clicked position. Note that all of the scrubbers across all of the tools in Faceposer are synchronized to each other.

Global Pauses (Interrupts)

A scene can have "global" Pause events placed. To create a Pause event, right-click anywhere in the channel name or channel tray for any actor and choose New Section Pause… from the menu. You can give the section pause a name, and you can have the section pause optionally perform an automatic action. The need for the section pause events arises out of the need for triggering of certain events that have ambiguous end times. For instance, as noted above, a "move to" event might be triggered which will cause the AI to start the actor moving to their next position. Due to obstacles, movement speed, etc., it is not possible to exactly determine how long it will take the actor to arrive at the location. This is a good location for a Pause event. In general, you can simply institute a section pause just after issuing the "Move To" event to an actor. The AI system will later notify the scene that the "Resume Condition" for the pause has been satisfied (assuming you checked the "Resume condition" checkbox in the event properties for the events overlapping the Pause point).

In other words, you would tag the "Move to" event that you are waiting for as a "Resume Condition". To tag an event as a resume condition, you can right-click on the event in the channel tray and edit its properties and click the check box labeled: "Event must complete for paused scene to resume".

This is the most common use of the Pause event; used in conjunction with a "move to" event to ensure the actor reaches his mark before continuing the scene. Use this technique when there are subsequent scene events that are location specific (e.g. pushing a button, typing on a keyboard, speaking into a microphone, entering a room, etc). During the production of Half-Life 2 HL2, this technique was considered one of the "sledgehammer" methods of directing actors because it effectively guarantees the actor will reach their mark.

One of the more subtle (and powerful) aspects of Pause events is in being able to control when the scene will resume with respect to the completion of the "resume condition" event. In other words, you can have it so the scene anticipates the event completion by some specified amount of time, and resumes the scene that much time prior to the actual event completion. This is very useful for having paused scenes resume with a certain natural overlap of events. To specify that the scene resumes some time prior to the event completion, you want to have the event extend that much time past the intersecting Pause event. The following image illustrates this technique:

In this illustration note how the "move to" event extends about 2 seconds past the Pause event. This means the scene will resume about 2 secondss before the actor reaches their mark. Effectively the actor will start speaking their line as they approach their mark.

In the case that the designer doesn't want the scene to remain paused past a certain length of time, the scene designer can decide to automatically take one of two actions: 1) resume the scene anyway, or 2) cancel playback of the rest of the scene. To set the automatic resume action, right-click on the blue triangle marker for the "Section Pause" event and choose "Edit" from the menu. In the properties dialog, you'll notice a checkbox next to the word "Automatically". If you check this box, then you can choose what action to automatically perform. The drop-down list allows you to choose to either "Resume" or "Cancel" and the final text entry area allows you to specify how long of a delay to allow before automatically taking action.

During playback of the scene in the engine, if any AI event that is marked as a "resume condition" takes less time than the "automatic" action you've specified, the automatic action is skipped since it was not needed.

Loop point

Like the Section Pause event, the "Loop" point event is similarly a global trigger for the scene. Instead of pausing however, the Loop point event allows resetting the .vcd clock backward to the beginning of the .vcd or to a specified time offset. Using this event near the end of your .vcd is useful for making it loop. You can specify that the event should loop a set number of times, maximum, or that it loops forever by editing the Loop point's properties. If you have a Loop Point that loops forever, you can break that loop by Canceling the scene through the logic_choreographed_scene entity in Hammer Hammer.

It is important to note that the loop begins looping at the Loop Point and jumps back to the time you have specified in the properties (by default it is set to 0).

Here is an example of a simple loop. You will notice that the Start Time is after the Loop To time in the timeline.

Fire Completion

Fire Completion events define a custom completion time for a scene. By default, a scene is completed when the last event in a .vcd file finishes, and is denoted by a dark blue dotted line. A Fire Completion event will mark off a scene’s completion by shifting the default completion time to the value specified in said event.

In more practical terms, the Fire Completion event is the point in the scene where the logic_choreographed_scene entity fires its OnCompletion output. Hence you can use this event to precisely time when that output is fired with respect to other events in your scene.

Other Choreography Features

  • In general you cannot accidentally move events between channels. To drag an event from one channel to another, hold down Shift as you are dragging.
  • Because multiple events can overlap in a single channel, the right mouse menu on an event has a Move event <name> to back option which can make it easier to see and select underlying events. In addition, HLFaceposer Faceposer will expand the layout of the channel vertically to accommodate overlapping events.
  • Events can be copied to and pasted from the clipboard from the right mouse menu.
  • Events can be exported and imported from simple event text files (also from the right mouse menu).
  • You can see the Ramp of all events only by choosing "Ramp only" from the right-click menu.
  • You can ask the HLFaceposer Faceposer to verify that all animation sequences are valid (i.e., non-looping if needed and of correct duration) by choosing "Check sequences"
  • You can turn off sequence processing from the preview (keeping the camera mostly on the actors' faces) by un-checking the "Process sequences" menu option.
  • Because HLFaceposer Faceposer supports multiple actors, you should associate the actor slots with loaded .MDLs. You can do this from the right-click menu or from the models tab in the main window tool area at the bottom right of the application.
  • You can also associate a .BSP with a .vcd, so that the relative positions of targets and the names of other actors/entities can be loaded when browsing in various properties dialogs.

Debugging

Note.pngNote:developer must be set to 1 for these to work.
scene_flush
This will reload all scenes the current map is using. Restarting a map will not automatically reload your changed scenes so if you are actively working in a .vcd with the engine open, be sure to use scene_flush so your new changes show up.
scene_print
Setting to 1 will show debug information in the console about the played events.
scene_showfaceto
Setting to 1 will turn on debugging to visually display where an actor is trying to face when a face-to is active for that actor.
scene_showlook
Setting to 1 will turn on debugging to visually display where an actor is trying to look when a look-at is active for that actor.
scene_showmoveto
Setting to 1 will turn on debugging to visually display where an actor is trying to move to when a move-to is active for that actor. A box will show at their destination with an arrow being displayed between the actor and the destination.