Script intro: Difference between revisions
| m (Corrected a stray typo) | Le Glaconus (talk | contribs)   (formatting) | ||
| (29 intermediate revisions by 18 users not shown) | |||
| Line 1: | Line 1: | ||
| {{ | {{LanguageBar}} | ||
| {{CD|CScriptIntro|file1=1}} | |||
| {{this is a|logical entity|name=script_intro|game=Half-Life 2 series}} | |||
| == Entity description == | == Entity description == | ||
| The  | The {{code|script_intro}} entity is a singleplayer only entity that is used extensively in the intro sequence for {{hl2|4}}. It makes use of [[Direct3D|DirectX]]'s render-to-texture capabilities to overlay a second camera onto the main camera, i.e., the player's view, and to blend between the two views using various effects. This is also useful for doing traditional A-B camera exposition sequences. | ||
| Some of the possible uses for this entity include hallucination effects and dream sequences, traditional A-B camera work for  | Some of the possible uses for this entity include hallucination effects and dream sequences, traditional A-B camera work for {{wiki|machinima}}, and so on. | ||
| The main issue with understanding this entity is the workflow isn't the same as other entities, in that it's highly time based. You don't just set keys and it works, but rather you'll have to trigger it at intervals using inputs, so a good working knowledge of Source's entity I/O system is required. | The main issue with understanding this entity is the workflow isn't the same as other entities, in that it's highly time based. You don't just set keys and it works, but rather you'll have to trigger it at intervals using inputs, so a good working knowledge of Source's entity I/O system is required. | ||
| === Using script_intro === | === Using script_intro === | ||
| There's only one key that you have to deal with on this entity, and that's it's targetname. Once you have a name to refer to the entity by, all the work is done by sending it inputs. The blended view (with the currently configured parameters) is enabled by firing the  | There's only one key that you have to deal with on this entity, and that's it's [[Targetname|targetname]]. Once you have a name to refer to the entity by, all the work is done by sending it inputs. The blended view (with the currently configured parameters) is enabled by firing the {{code|Activate}} input. Before you trigger {{code|Activate}}, there are several inputs you should send to initialize the entity, so that the transition from the normal player view to the blended view is seamless. They are {{code|SetCameraViewEntity}}, {{code|SetFOV}}, {{code|FadeTo}}, {{code|SetFadeColor}}, and {{code|SetBlendMode}}. | ||
| Start by sending the  | Start by sending the {{code|SetCameraViewEntity}} input, with the name of the {{ent|point_camera}} entity that you'll be using as the second view as a parameter. The camera will be automatically activated once the {{code|Activate}} input is fired on {{code|script_intro}}. Remember, the player's viewpoint is the first camera, so in traditional film terms, the player is the A camera, and the {{ent|point_camera}} that {{code|script_intro}} is using is the B camera. A subsequent optional {{code|SetFOV}} input will set the desired field of view for the B camera. If you want to control the FOV of the A camera as well, you can use the {{ent|env_zoom}} entity. Note that you don't have to ever trigger {{code|SetCameraViewEntity}}; in that case, the input for the B camera will be totally black, and you can still use the entity for its post-processing effects applied to the player's view. | ||
| Next, you can use the  | Next, you can use the {{code|SetFadeColor}} and {{code|FadeTo}} inputs to optionally apply an additional blend of solid color to the two cameras once the entity is activated. {{code|SetFadeColor}} (default is {{code|0 0 0}}) defines the color that is added to the mix, and {{code|FadeTo}} defines how opaque this color will be when blended. You use the input by sending a parameter with it with two values separated by a space. The first value is an integer with a range of 0-255, where 255 is completely opaque, and 0 (default) is completely transparent (resulting in no solid color being mixed into the view). The second value is a number in seconds that the fade will occur over; when initially configuring the entity, use the value of 0 for the second parameter to apply the change instantly. | ||
| Finally, you may want to change the default blend mode by firing  | Finally, you may want to change the default blend mode by firing {{code|SetBlendMode}}. A good choice for a starting value is 8 (see the list below), as it displays only the player (A) camera and ignores the B camera, allowing for a seamless transition. If you are not using the B camera, you are fine with the default 0. | ||
| At this point, you can fire the  | At this point, you can fire the {{code|Activate}} input to enable the blended view on the fully configured entity. Next you'll want to use the {{code|SetNextBlendMode}}, {{code|SetNextBlendTime}}, {{code|SetNextFOV}}, {{code|SetFOVBlendTime}}, and {{code|FadeTo}} to accompish transition effects. | ||
| {{code|SetNextBlendMode}} with a parameter of 6 is the most natural of blend modes. It will produce a straight additive blend between the two cameras when complete. The other blend modes will produce special effects, such as the black and white and inversion effects seen in HL2's intro. Send a {{code|SetNextBlendMode}} input with a integer parameter of 0 through 9, each produces a different effect. This sets up the blend; you next send an input of {{code|SetNextBlendTime}} to execute the blend, with a parameter that equals the time value that you want the blend effect to occur over, in seconds. The blend mode will cause the camera to change effects when executed; so it will blend from one effect to the next. | |||
| {{code|SetNextFOV}} and {{code|SetFOVBlendTime}} work to smoothly transition camera B FOV from one value (the default, or the last executed {{code|SetFOV}}) to the next; otherwise, they work analogously to {{code|SetNextBlendMode}} and {{code|SetNextBlendTime}}. | |||
| Finally, the  | Finally, the {{code|SetFadeColor}} and {{code|FadeTo}} inputs can be used to smoothly blend a solid color into the view (similarly to {{ent|env_fade}}). In order to avoid sharp changes in color, make sure to only fire {{code|SetFadeColor}} while the {{code|FadeTo}} alpha is set to 0. Once you've set the desired fade color, execute a {{code|FadeTo}} input with the desired fade amount and the number of seconds to accomplish the fade. For example, setting the fade color to {{code|255 255 255}} and then executing {{code|FadeTo}} with values of {{code|127 5}} will fade the player's view to a milky white over 5 seconds. Of note, the {{code|FadeTo}} input is used in a hacky way in the intro sequence to fade out the player's view. This is because the {{ent|env_fade}} entity can't be iterated, i.e. you can't have two {{ent|env_fade}}s, and fade from one to the other. | ||
| Once you are done toying with the player's view, you can fire the  | Once you are done toying with the player's view, you can fire the {{code|Deactivate}} input to return it to normal, followed by {{code|SetOff}} inputs to any cameras you've been using. | ||
| === Blend modes === | === Blend modes === | ||
| This is a list of the apparent function of the blend modes. These can be set in the entity by sending it a  | This is a list of the apparent function of the blend modes. These can be set in the entity by sending it a {{code|SetNextBlendMode}} and {{code|SetNextBlendTime}}, or just {{code|SetBlendMode}}. | ||
| * 0: Camera A is normal color, camera B is inverted grayscale, multiplicatively blended (each pixel value in the resulting view is determined by multiplying the values of the corresponding pixels in A and B views). Note that if no camera B is used, this just renders the player view normally. This is the default value. | * 0: Camera A is normal color, camera B is inverted grayscale, multiplicatively blended (each pixel value in the resulting view is determined by multiplying the values of the corresponding pixels in A and B views). Note that if no camera B is used, this just renders the player view normally. This is the default value. | ||
| Line 36: | Line 37: | ||
| * 3: Camera A is normal grayscale, camera B is normal color. Camera B is masked with the inverse of camera A's luminosity, which becomes the latter's alpha channel. That is, darker pixels in A do not allow much light from B, whereas brighter pixels in A render almost completely as B. | * 3: Camera A is normal grayscale, camera B is normal color. Camera B is masked with the inverse of camera A's luminosity, which becomes the latter's alpha channel. That is, darker pixels in A do not allow much light from B, whereas brighter pixels in A render almost completely as B. | ||
| * 4: Both A and B are normal color, otherwise the same as 3. | * 4: Both A and B are normal color, otherwise the same as 3. | ||
| * 5: Camera A is  | * 5: Camera A is posterized color, camera B is normal color, but B's low values (absolute black) serve as an alpha mask for A (are transparent to A). B camera is drawn everywhere except where its pixels would have been black; A camera is drawn for those pixels instead. | ||
| * 6: Both A and B are normal color, additively blended. This appears to be the most straightforward mix between the two screenbuffers, applying a straight blend. | * 6: Both A and B are normal color, additively blended. This appears to be the most straightforward mix between the two screenbuffers, applying a straight blend. | ||
| * 7:  | * 7: Camera A is blank, camera B is normal. This can be used to take control of the player's view, similar to the {{ent|point_viewcontrol}} entity. However, the player can still move around and act, they just won't see what's going on around them. | ||
| * 8: Camera A is normal, camera B is blank. This is the opposite of  | * 8: Camera A is normal, camera B is blank. This is the opposite of 7 and equivalent to the player's regular view. | ||
| * {{ | * {{ep2|only}} 9: Both A and B are normal color. Camera A is masked with camera B's luminosity, which becomes the latter's alpha channel. That is, brighter pixels in B do not allow much light from A, whereas darker pixels in B render almost completely as A. | ||
| {{Note|The above descriptions are valid only in DX9. Earlier [[DirectX Versions|DirectX versions]] may not have the features to implement all of these modes, and consequently will either use simplified modes (0, 1, 3, and 5) or forget blending altogether, displaying only one of the inputs (2 and 4). If you make extensive use of these modes, you should test your scripts with all applicable rendering modes (by supplying the appropriate value of {{cmd|mat_dxlevel}} to the engine command line).}} | |||
| === Examples of use === | === Examples of use === | ||
| See the following  | See the following maps from the {{hl2series|4}} for various uses of this entity: | ||
| *  | *{{ent|d1_trainstation_01}} (intro sequence) | ||
| *  | *{{ent|d1_trainstation_05}} (teleport sequences) | ||
| *  | *{{ent|d3_breen_01}} (outro sequence) | ||
| *{{ent|ep1_citadel_00}} (Ep1 intro) | |||
| *{{ent|ep2_outland_02}} (G-Man heart-to-heart sequence) | |||
| Straight fade from player's view to the camera view and back over 10 seconds (assuming you have a  | Straight fade from player's view to the camera view and back over 10 seconds (assuming you have a {{code|script_intro}} entity with the name "{{mono|fxintro}}" on the map and a camera named "{{mono|b_camera}}", fired from (repeatable) {{code|OnTrigger}} outputs): | ||
| :{| border=1 cellpadding="2" cellspacing="1" | |||
| |- align=left style="background:#DCDCDC; color:black" | |||
| ! | |||
| ! My Output > !! Target Entity !! Target Input !! Parameter !! Delay !! Only Once | |||
| |- | |||
| | [[File:Io11.png]] || OnTrigger || {{mono|fxintro}} || SetCameraViewEntity || b_camera || 0 || No | |||
| |- | |||
| | [[File:Io11.png]] || OnTrigger || {{mono|fxintro}} || SetBlendMode || 8 || 0.01 || No | |||
| |- | |||
| | [[File:Io11.png]] || OnTrigger || {{mono|fxintro}} || Activate ||   || 0.02 || No | |||
| |- | |||
| | [[File:Io11.png]] || OnTrigger || {{mono|fxintro}} || SetNextBlendMode || 7 || 0.03 || No | |||
| |- | |||
| | [[File:Io11.png]] || OnTrigger || {{mono|fxintro}} || SetNextBlendTime || 5 || 0.04 || No | |||
| |- | |||
| | [[File:Io11.png]] || OnTrigger || {{mono|fxintro}} || SetNextBlendMode || 8 || 5.05 || No | |||
| |- | |||
| | [[File:Io11.png]] || OnTrigger || {{mono|fxintro}} || SetNextBlendTime || 5 || 5.06 || No | |||
| |- | |||
| | [[File:Io11.png]] || OnTrigger || {{mono|fxintro}} || Deactivate ||   || 10.06 || No | |||
| |- | |||
| | [[File:Io11.png]] || OnTrigger || {{mono|b_camera}} || SetOff ||   || 10.07 || No | |||
| |} | |||
| === Bugs === | === Bugs === | ||
| *  | * {{code|script_intro}} does not work properly on the maps that contain [[3D Skybox|3D skyboxes]]. Depending on the engine version, they either won't be rendered at all (even in the player view), or worse, result in clipping of the 2D skyboxes, leaving the sky totally or partially black. To work around this problem, either don't use 3D skyboxes on the affected maps, or make sure the sky is not visible from the places where you intend to use this entity. | ||
| * [[viewmodel|Viewmodels]], if present in the player view, are not rendered properly while  | * [[viewmodel|Viewmodels]], if present in the player view, are not rendered properly while {{code|script_intro}} is active (only the 2D parts are visible). One should make sure the player either does not possess any weapons, or is forced to hide them for the duration of the blend sequence. | ||
| Both issues  | Both issues are caused by when the skybox and viewmodels are rendered in the scene composition. | ||
| {{fix|The skybox bug can be fixed by moving {{code|CSkyboxView}}'s setup in {{code|CViewRender::RenderView()}} to occur after the secondary camera would be drawn in the intro scene, meaning it would be separated into one instance directly before {{code|CViewRender::ViewDrawScene()}} and another instance of the setup in {{code|CViewRender::ViewDrawScene_Intro()}} shortly after the {{code|m_bDrawPrimary}} block. Putting it right before {{code|g_pClientShadowMgr->PreRender()}} works. The clear color background should be removed as well, at least while the skybox is calculated to be visible.|code}} | |||
| : {{confirm|Does removing {{code|VIEW_CLEAR_COLOR}} cause [[VortWarp]] to stop working correctly?}} | |||
| {{fix|The viewmodel bug can be fixed by disabling the regular call to {{code|CViewRender::DrawViewModels()}} in {{code|CViewRender::RenderView()}} when the intro code is active and adding a separate call to {{code|CViewRender::ViewDrawScene_Intro()}} before intro_screenspaceeffect is composed. Putting it right after the main {{code|DrawWorldAndEntities}} works.|code}} | |||
| :  | |||
| * This entity doesn't work properly with Gbuffer in {{bms|4}}. When activated, all [[NewLight Point|new lights]], [[Newxog global|xog]] and other {{xe|4}} features will not be displayed. While it is activated, it spams an error message in the [[Developer console|developer console]]: '''ERROR!! - Secondary View NewLights RT SIZE MISMATCH VIEWSIZE - 1920 : 1080 : 6 GBUFFER SIZE - 1024 : 1024'''. All the resolution values depends on current resolution settings. | |||
| * {{ | |||
| == Keyvalues == | |||
| {{KV Targetname}} | |||
| {{KV|Match env_zoom's FOV transition|intn=alternatefovchange|boolean|Whether the script should match {{ent|env_zoom}}'s FOV transition.}} | |||
| == Inputs == | |||
| {{I|Activate|Take control of the player's view and start blending the two scenes.}} | |||
| {{I|Deactivate|Stop controlling the view.}} | |||
| {{I|SetCameraViewEntity|param=targetname|special targets=supports !activator / !caller|Set the viewpoint to blend with the player's viewpoint.}} | |||
| {{I|SetBlendMode|Set the blending mode to use.|param=integer}} | |||
| {{I|SetFOV|Set the fov for the second camera.|param=integer}} | |||
| {{I|SetNextFOV|Set the FOV to blend to over time. Follow this with a {{code|SetFOVBlendTime}} input to start the fov blend.|param=integer}} | |||
| {{I|SetFOVBlendTime|Set the amount of time it should take to blend to the next fov target, and start blending.|param=float}} | |||
| {{I|SetNextBlendMode|Set the blending mode to blend to over time. Follow this with a {{code|SetNextBlendTime}} input to start the mode blend.|param=integer}} | |||
| {{I|SetNextBlendTime|Set the amount of time it should take to blend to the next mode, and start blending.|param=float}} | |||
| {{I|FadeTo|Fade to a specific alpha amount of an amount of time. Parameters: <alpha> <duration>|param=string}} | |||
| {{I|SetFadeColor|Set the fade color. Parameters: <Red> <Green> <Blue>|param=string}} | |||
| {{ | |||
| {{ | |||
| [[Category:GUI Entities]] | |||
| [[Category:Camera]] | |||
Latest revision as of 08:23, 28 May 2025
|  Class hierarchy | 
|---|
| CScriptIntro | 
|  script_intro.cpp | 
script_intro  is a   logical entity  available in  Half-Life 2 series.
 Half-Life 2 series.
Entity description
The script_intro entity is a singleplayer only entity that is used extensively in the intro sequence for  Half-Life 2. It makes use of DirectX's render-to-texture capabilities to overlay a second camera onto the main camera, i.e., the player's view, and to blend between the two views using various effects. This is also useful for doing traditional A-B camera exposition sequences.
 Half-Life 2. It makes use of DirectX's render-to-texture capabilities to overlay a second camera onto the main camera, i.e., the player's view, and to blend between the two views using various effects. This is also useful for doing traditional A-B camera exposition sequences.
Some of the possible uses for this entity include hallucination effects and dream sequences, traditional A-B camera work for  machinima, and so on.
 machinima, and so on.
The main issue with understanding this entity is the workflow isn't the same as other entities, in that it's highly time based. You don't just set keys and it works, but rather you'll have to trigger it at intervals using inputs, so a good working knowledge of Source's entity I/O system is required.
Using script_intro
There's only one key that you have to deal with on this entity, and that's it's targetname. Once you have a name to refer to the entity by, all the work is done by sending it inputs. The blended view (with the currently configured parameters) is enabled by firing the Activate input. Before you trigger Activate, there are several inputs you should send to initialize the entity, so that the transition from the normal player view to the blended view is seamless. They are SetCameraViewEntity, SetFOV, FadeTo, SetFadeColor, and SetBlendMode.
Start by sending the SetCameraViewEntity input, with the name of the point_camera entity that you'll be using as the second view as a parameter. The camera will be automatically activated once the Activate input is fired on script_intro. Remember, the player's viewpoint is the first camera, so in traditional film terms, the player is the A camera, and the point_camera that script_intro is using is the B camera. A subsequent optional SetFOV input will set the desired field of view for the B camera. If you want to control the FOV of the A camera as well, you can use the env_zoom entity. Note that you don't have to ever trigger SetCameraViewEntity; in that case, the input for the B camera will be totally black, and you can still use the entity for its post-processing effects applied to the player's view.
Next, you can use the SetFadeColor and FadeTo inputs to optionally apply an additional blend of solid color to the two cameras once the entity is activated. SetFadeColor (default is 0 0 0) defines the color that is added to the mix, and FadeTo defines how opaque this color will be when blended. You use the input by sending a parameter with it with two values separated by a space. The first value is an integer with a range of 0-255, where 255 is completely opaque, and 0 (default) is completely transparent (resulting in no solid color being mixed into the view). The second value is a number in seconds that the fade will occur over; when initially configuring the entity, use the value of 0 for the second parameter to apply the change instantly.
Finally, you may want to change the default blend mode by firing SetBlendMode. A good choice for a starting value is 8 (see the list below), as it displays only the player (A) camera and ignores the B camera, allowing for a seamless transition. If you are not using the B camera, you are fine with the default 0.
At this point, you can fire the Activate input to enable the blended view on the fully configured entity. Next you'll want to use the SetNextBlendMode, SetNextBlendTime, SetNextFOV, SetFOVBlendTime, and FadeTo to accompish transition effects.
SetNextBlendMode with a parameter of 6 is the most natural of blend modes. It will produce a straight additive blend between the two cameras when complete. The other blend modes will produce special effects, such as the black and white and inversion effects seen in HL2's intro. Send a SetNextBlendMode input with a integer parameter of 0 through 9, each produces a different effect. This sets up the blend; you next send an input of SetNextBlendTime to execute the blend, with a parameter that equals the time value that you want the blend effect to occur over, in seconds. The blend mode will cause the camera to change effects when executed; so it will blend from one effect to the next.
SetNextFOV and SetFOVBlendTime work to smoothly transition camera B FOV from one value (the default, or the last executed SetFOV) to the next; otherwise, they work analogously to SetNextBlendMode and SetNextBlendTime.
Finally, the SetFadeColor and FadeTo inputs can be used to smoothly blend a solid color into the view (similarly to env_fade). In order to avoid sharp changes in color, make sure to only fire SetFadeColor while the FadeTo alpha is set to 0. Once you've set the desired fade color, execute a FadeTo input with the desired fade amount and the number of seconds to accomplish the fade. For example, setting the fade color to 255 255 255 and then executing FadeTo with values of 127 5 will fade the player's view to a milky white over 5 seconds. Of note, the FadeTo input is used in a hacky way in the intro sequence to fade out the player's view. This is because the env_fade entity can't be iterated, i.e. you can't have two env_fades, and fade from one to the other.
Once you are done toying with the player's view, you can fire the Deactivate input to return it to normal, followed by SetOff inputs to any cameras you've been using.
Blend modes
This is a list of the apparent function of the blend modes. These can be set in the entity by sending it a SetNextBlendMode and SetNextBlendTime, or just SetBlendMode.
- 0: Camera A is normal color, camera B is inverted grayscale, multiplicatively blended (each pixel value in the resulting view is determined by multiplying the values of the corresponding pixels in A and B views). Note that if no camera B is used, this just renders the player view normally. This is the default value.
- 1: Camera A is inverted color, camera B is normal grayscale, additively blended (each pixel value in the resulting view is determined by adding up the values of the corresponding pixels in A and B views).
- 2: Camera A is normal grayscale, camera B is normal color, multiplicatively blended.
- 3: Camera A is normal grayscale, camera B is normal color. Camera B is masked with the inverse of camera A's luminosity, which becomes the latter's alpha channel. That is, darker pixels in A do not allow much light from B, whereas brighter pixels in A render almost completely as B.
- 4: Both A and B are normal color, otherwise the same as 3.
- 5: Camera A is posterized color, camera B is normal color, but B's low values (absolute black) serve as an alpha mask for A (are transparent to A). B camera is drawn everywhere except where its pixels would have been black; A camera is drawn for those pixels instead.
- 6: Both A and B are normal color, additively blended. This appears to be the most straightforward mix between the two screenbuffers, applying a straight blend.
- 7: Camera A is blank, camera B is normal. This can be used to take control of the player's view, similar to the point_viewcontrol entity. However, the player can still move around and act, they just won't see what's going on around them.
- 8: Camera A is normal, camera B is blank. This is the opposite of 7 and equivalent to the player's regular view.
- (only in  ) 9: Both A and B are normal color. Camera A is masked with camera B's luminosity, which becomes the latter's alpha channel. That is, brighter pixels in B do not allow much light from A, whereas darker pixels in B render almost completely as A. ) 9: Both A and B are normal color. Camera A is masked with camera B's luminosity, which becomes the latter's alpha channel. That is, brighter pixels in B do not allow much light from A, whereas darker pixels in B render almost completely as A.
 Note:The above descriptions are valid only in DX9. Earlier DirectX versions may not have the features to implement all of these modes, and consequently will either use simplified modes (0, 1, 3, and 5) or forget blending altogether, displaying only one of the inputs (2 and 4). If you make extensive use of these modes, you should test your scripts with all applicable rendering modes (by supplying the appropriate value of
Note:The above descriptions are valid only in DX9. Earlier DirectX versions may not have the features to implement all of these modes, and consequently will either use simplified modes (0, 1, 3, and 5) or forget blending altogether, displaying only one of the inputs (2 and 4). If you make extensive use of these modes, you should test your scripts with all applicable rendering modes (by supplying the appropriate value of mat_dxlevel to the engine command line).Examples of use
See the following maps from the  Half-Life 2 series for various uses of this entity:
 Half-Life 2 series for various uses of this entity:
- d1_trainstation_01 (intro sequence)
- d1_trainstation_05 (teleport sequences)
- d3_breen_01 (outro sequence)
- ep1_citadel_00 (Ep1 intro)
- ep2_outland_02 (G-Man heart-to-heart sequence)
Straight fade from player's view to the camera view and back over 10 seconds (assuming you have a script_intro entity with the name "fxintro" on the map and a camera named "b_camera", fired from (repeatable) OnTrigger outputs):
Bugs
- script_introdoes not work properly on the maps that contain 3D skyboxes. Depending on the engine version, they either won't be rendered at all (even in the player view), or worse, result in clipping of the 2D skyboxes, leaving the sky totally or partially black. To work around this problem, either don't use 3D skyboxes on the affected maps, or make sure the sky is not visible from the places where you intend to use this entity.
- Viewmodels, if present in the player view, are not rendered properly while script_introis active (only the 2D parts are visible). One should make sure the player either does not possess any weapons, or is forced to hide them for the duration of the blend sequence.
Both issues are caused by when the skybox and viewmodels are rendered in the scene composition.
 Code Fix:The skybox bug can be fixed by moving
Code Fix:The skybox bug can be fixed by moving CSkyboxView's setup in CViewRender::RenderView() to occur after the secondary camera would be drawn in the intro scene, meaning it would be separated into one instance directly before CViewRender::ViewDrawScene() and another instance of the setup in CViewRender::ViewDrawScene_Intro() shortly after the m_bDrawPrimary block. Putting it right before g_pClientShadowMgr->PreRender() works. The clear color background should be removed as well, at least while the skybox is calculated to be visible. Confirm:Does removing Confirm:Does removing- VIEW_CLEAR_COLORcause VortWarp to stop working correctly?
 Code Fix:The viewmodel bug can be fixed by disabling the regular call to
Code Fix:The viewmodel bug can be fixed by disabling the regular call to CViewRender::DrawViewModels() in CViewRender::RenderView() when the intro code is active and adding a separate call to CViewRender::ViewDrawScene_Intro() before intro_screenspaceeffect is composed. Putting it right after the main DrawWorldAndEntities works.- This entity doesn't work properly with Gbuffer in  Black Mesa. When activated, all new lights, xog and other Black Mesa. When activated, all new lights, xog and other Xengine features will not be displayed. While it is activated, it spams an error message in the developer console: ERROR!! - Secondary View NewLights RT SIZE MISMATCH VIEWSIZE - 1920 : 1080 : 6 GBUFFER SIZE - 1024 : 1024. All the resolution values depends on current resolution settings. Xengine features will not be displayed. While it is activated, it spams an error message in the developer console: ERROR!! - Secondary View NewLights RT SIZE MISMATCH VIEWSIZE - 1920 : 1080 : 6 GBUFFER SIZE - 1024 : 1024. All the resolution values depends on current resolution settings.
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
- Match env_zoom's FOV transition (alternatefovchange) <boolean>
- Whether the script should match env_zoom's FOV transition.
Inputs
- Activate
- Take control of the player's view and start blending the two scenes.
- Deactivate
- Stop controlling the view.
- SetCameraViewEntity <targetname>
- supports !activator / !caller
 Set the viewpoint to blend with the player's viewpoint.
- SetBlendMode <integer>
- Set the blending mode to use.
- SetFOV <integer>
- Set the fov for the second camera.
- SetNextFOV <integer>
- Set the FOV to blend to over time. Follow this with a SetFOVBlendTimeinput to start the fov blend.
- SetFOVBlendTime <float>
- Set the amount of time it should take to blend to the next fov target, and start blending.
- SetNextBlendMode <integer>
- Set the blending mode to blend to over time. Follow this with a SetNextBlendTimeinput to start the mode blend.
- SetNextBlendTime <float>
- Set the amount of time it should take to blend to the next mode, and start blending.
- FadeTo <string>
- Fade to a specific alpha amount of an amount of time. Parameters: <alpha> <duration>
- SetFadeColor <string>
- Set the fade color. Parameters: <Red> <Green> <Blue>


























