Postprocess controller: Difference between revisions
| ThaiGrocer (talk | contribs) m (→Keyvalues) |  (its position in the world irrelevant so it's logical entity) | ||
| (36 intermediate revisions by 15 users not shown) | |||
| Line 1: | Line 1: | ||
| {{ | {{CD|CPostProcessController|file1=1}} | ||
| {{ | {{this is a|logical entity|since=Left 4 Dead|name=postprocess_controller|sprite=1}} {{also|{{mapbase}}}} | ||
| {{toc-right}} | |||
| This entity controls a bunch of cinematic post-processing effects primarily used in the {{l4ds|4.1}}. Many of the effects were designed specifically to supplement Left 4 Dead's "filmic" art direction, such as film grain or local contrast. | |||
| Multiple controllers can exist in the map at the same time and each controller be applied on a player-by-player basis, with effects fading between each other automatically. A <code>postprocess_controller</code> can be enabled on a player by using the "Master" spawnflag or the {{ent|fog_volume}} entity. | |||
| }} | |||
| Other post-processing effects, such as [[color_correction|Color correction]], are controlled by other entities. (e.g. {{ent|color_correction (entity)}} or {{ent|env_dof_controller}}) | |||
| }} | |||
| == | {{note|In {{l4ds}}, It may be necessary to have at least one {{ent|fog_volume}} in the map in order for a master <code>postprocess_controller</code> to take effect.}} | ||
| {{ | {{bug|hidetested=1|None of these effects work in {{Portal2}} except for vignette.}} | ||
| == Effects == | |||
| === Film grain === | |||
| [[File:Postprocess_controller_film_grain.jpg|thumb|150px|right|Film grain on and off. Click for detail.]]Film grain heightens the frightening feeling of dark and shadowy environments. This helps make the cinematic experience as gritty and authentic as possible and effectively implies a greater detail to the surrounding darkness than is actually there. The technique avoids applying film grain uniformly as it causes players to get tired of it fast. Instead, film grain is prevalent in very dark areas with lots of shadows. The brighter an area gets, the more the grain fades into the background, causing it to disappear entirely in very bright areas. | |||
| This effect was used by game code in {{l4d|4.1}}, but it wasn't added to <code>postprocess_controller</code> until {{l4d2|4.1}}. | |||
| {{clr}} | |||
| === Vignette === | |||
| [[File:Postprocess controller vignette.jpg|thumb|150px|right|Vignette on and off. Click for detail.]]Vignetting is a lens artifact you'll often see in lower budget films where cheap cameras were used: specifically, dark edges seeping in around the edges of the screen. Even still, it usually needs to be applied sparingly. As shown in the example picture, the effect was only applied around all of the top edges of the screen, so a player wouldn't feel like they were looking through a telescope. A little goes a long way — playtesters don't feel like it intrudes their view at all. It also does a good job of softening the top edges, focusing the gameplay downwards to the center of the screen, where you want a player to look. {{confirm|{{l4d2|4.1}} seems to have changed this into a full vignette effect and split top-of-screen vignette into a different effect; later games can only use full vignette.}} {{clr}} | |||
| === Local contrast === | |||
| [[File:Postprocess controller local contrast.jpg|thumb|150px|right|Local contrast on and off. Click for detail.]]Local contrast is a technique borrowed from photo retouching, where the contrast is adjusted specifically on areas of an image that contain a high level of visual detail. This technique helps make the visuals sharper and more focused. It is a convenient way to effectively imitate the feeling of an adrenaline rush or near-death experience. The effect gives the player a sense of heightened perspective and is a great subliminal way to foreshadow imminent danger.{{clr}} | |||
| === Depth and full screen blur === | |||
| Depth and full screen blur apply a blurring effect to certain parts of the screen. Depth blur allows blur to be applied at a certain focal distance and screen blur applies the effect across the whole screen. | |||
| This effect was used by game code in {{l4d|4.1}}, but it wasn't added to <code>postprocess_controller</code> until {{as|4.1}}. | |||
| {{note|Blur can cancel out an active vignette effect.}} | |||
| {{todo|Example picture and full explanation.}} | |||
| === Fade out/Fade to black === | |||
| "Fade to black" simply fades the screen into complete darkness. Normally, {{ent|env_fade}} (which provides more control over the fade's properties) would be used for fading the screen, but some post-processing effects are still applied or do not disappear smoothly when <code>env_fade</code> is used. The "Fade to black" effect is applied after all of the other effects, allowing them to fade with the rest of the screen. This is recommended if the other effects controlled by this entity are used often and should not appear in intro/outro fades. | |||
| == Keyvalues == | |||
| {{KV Targetname}} | |||
| {{KV|Fade-in time|float|intn=fadetime|Fade-in time}} | |||
| {{KV|Local contrast strength [-1..x]|float|intn=localcontraststrength|Local contrast strength}} | |||
| {{KV|Local contrast edge strength [0..1]|float|intn=localcontrastedgestrength|Local contrast edge strength}} | |||
| {{KV|Vignette start distance [0..1]|float|intn=vignettestart|Vignette start distance}} | |||
| {{KV|Vignette end distance [0..x]|float|intn=vignetteend|Vignette end distance}} | |||
| {{KV|Vignette blur strength [0..1]|float|intn=vignetteblurstrength|Vignette blur strength}} | |||
| {{KV|Fade to black strength [0..1]|float|intn=fadetoblackstrength|Fade to black strength}} | |||
| {{KV|Film grain strength [0..x]|float|intn=grainstrength|Film grain strength|since={{l4d2}}}} | |||
| {{KV|Top-of-screen vignette strength [0..1]|float|intn=topvignettestrength|Top-of-screen vignette strength|only={{l4d2}}}} | |||
| {{KV|Depth-blur focal plane distance [0..1]|float|intn=depthblurfocaldistance|Depth-blur focal plane distance (in dest alpha space [0,1], not world units)|since={{as}}}} | |||
| {{KV|Depth-blur effect strength [0..x]|float|intn=depthblurstrength|Depth-blur effect strength|since={{as}}}} | |||
| {{KV|Full-screen blur strength [0..1]|float|intn=screenblurstrength|Full-screen blur strength|since={{as}}}} | |||
| == Flags == | |||
| {{Fl|1|Master|Has priority if multiple postprocess_controllers exist}} | |||
| == Inputs == | |||
| {{I|SetLocalContrastStrength|Set the local contrast strength.|param=float}} | |||
| {{I|SetLocalContrastEdgeStrength|Set the local contrast strength at the edge of the screen (controlled by vignette).|param=float}} | |||
| {{I|SetVignetteStart|Set the vignette start distance (from screen center).|param=float}} | |||
| {{I|SetVignetteEnd|Set the vignette end distance.|param=float}} | |||
| {{I|SetVignetteBlurStrength|Set the strength of the desaturated blur on the vignette.|param=float}} | |||
| {{I|SetFadeToBlackStrength|Set the fadeout strength.|param=float}} | |||
| {{I|SetDepthBlurFocalDistance|Set the focal distance of the depth blur effect (in dest alpha space [0,1], not world units).|param=float|since=AS}} | |||
| {{I|SetDepthBlurStrength|Set the depth blur effect strength.|param=float|since={{as}}}} | |||
| {{I|SetScreenBlurStrength|Set the screen blur effect strength.|param=float|since={{as}}}} | |||
| {{I|SetFilmGrainStrength|Set the film grain effect strength.|param=float|since={{as}}}} | |||
| {{I|SetFadeTime|Set the fade time between post process settings.|param=float|since={{as}}}} | |||
| ==See also== | |||
| *[[color_correction|Color Correction]] | |||
| *[[color_correction (entity)]] | |||
| *[[env_fog_controller]] | |||
| *[[fog_volume]] | |||
| ==External links== | |||
| [http://www.l4d.com/blog/post.php?id=1962 L4D Art Direction, Part 1: Filmic Effects] - Valve blog regarding film effects in Left 4 Dead | |||
| [[Category:Mapbase Entities]] | |||
Latest revision as of 08:00, 29 April 2025
|  Class hierarchy | 
|---|
| CPostProcessController | 
|  postprocesscontroller.cpp | 

postprocess_controller  is a   logical entity  available in all  Source games since
 Source games since  Left 4 Dead. (also in
 Left 4 Dead. (also in  )
)
This entity controls a bunch of cinematic post-processing effects primarily used in the 
 Left 4 Dead series. Many of the effects were designed specifically to supplement Left 4 Dead's "filmic" art direction, such as film grain or local contrast.
 Left 4 Dead series. Many of the effects were designed specifically to supplement Left 4 Dead's "filmic" art direction, such as film grain or local contrast.
Multiple controllers can exist in the map at the same time and each controller be applied on a player-by-player basis, with effects fading between each other automatically. A postprocess_controller can be enabled on a player by using the "Master" spawnflag or the fog_volume entity.
Other post-processing effects, such as Color correction, are controlled by other entities. (e.g. color_correction (entity) or env_dof_controller)
 Note:In
Note:In 
 , It may be necessary to have at least one fog_volume in the map in order for a master
, It may be necessary to have at least one fog_volume in the map in order for a master postprocess_controller to take effect.Effects
Film grain
Film grain heightens the frightening feeling of dark and shadowy environments. This helps make the cinematic experience as gritty and authentic as possible and effectively implies a greater detail to the surrounding darkness than is actually there. The technique avoids applying film grain uniformly as it causes players to get tired of it fast. Instead, film grain is prevalent in very dark areas with lots of shadows. The brighter an area gets, the more the grain fades into the background, causing it to disappear entirely in very bright areas.
This effect was used by game code in  Left 4 Dead, but it wasn't added to
 Left 4 Dead, but it wasn't added to postprocess_controller until  Left 4 Dead 2.
 Left 4 Dead 2.
Vignette
Vignetting is a lens artifact you'll often see in lower budget films where cheap cameras were used: specifically, dark edges seeping in around the edges of the screen. Even still, it usually needs to be applied sparingly. As shown in the example picture, the effect was only applied around all of the top edges of the screen, so a player wouldn't feel like they were looking through a telescope. A little goes a long way — playtesters don't feel like it intrudes their view at all. It also does a good job of softening the top edges, focusing the gameplay downwards to the center of the screen, where you want a player to look.
 Confirm:
 Confirm: Left 4 Dead 2 seems to have changed this into a full vignette effect and split top-of-screen vignette into a different effect; later games can only use full vignette.
 Left 4 Dead 2 seems to have changed this into a full vignette effect and split top-of-screen vignette into a different effect; later games can only use full vignette.Local contrast
Local contrast is a technique borrowed from photo retouching, where the contrast is adjusted specifically on areas of an image that contain a high level of visual detail. This technique helps make the visuals sharper and more focused. It is a convenient way to effectively imitate the feeling of an adrenaline rush or near-death experience. The effect gives the player a sense of heightened perspective and is a great subliminal way to foreshadow imminent danger.
Depth and full screen blur
Depth and full screen blur apply a blurring effect to certain parts of the screen. Depth blur allows blur to be applied at a certain focal distance and screen blur applies the effect across the whole screen.
This effect was used by game code in  Left 4 Dead, but it wasn't added to
 Left 4 Dead, but it wasn't added to postprocess_controller until  Alien Swarm.
 Alien Swarm.
 Note:Blur can cancel out an active vignette effect.
Note:Blur can cancel out an active vignette effect.Fade out/Fade to black
"Fade to black" simply fades the screen into complete darkness. Normally, env_fade (which provides more control over the fade's properties) would be used for fading the screen, but some post-processing effects are still applied or do not disappear smoothly when env_fade is used. The "Fade to black" effect is applied after all of the other effects, allowing them to fade with the rest of the screen. This is recommended if the other effects controlled by this entity are used often and should not appear in intro/outro fades.
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
- Fade-in time (fadetime) <float>
- Fade-in time
- Local contrast strength [-1..x] (localcontraststrength) <float>
- Local contrast strength
- Local contrast edge strength [0..1] (localcontrastedgestrength) <float>
- Local contrast edge strength
- Vignette start distance [0..1] (vignettestart) <float>
- Vignette start distance
- Vignette end distance [0..x] (vignetteend) <float>
- Vignette end distance
- Vignette blur strength [0..1] (vignetteblurstrength) <float>
- Vignette blur strength
- Fade to black strength [0..1] (fadetoblackstrength) <float>
- Fade to black strength
- Top-of-screen vignette strength [0..1] (topvignettestrength)  <float> (only in  ) )
- Top-of-screen vignette strength
- Depth-blur focal plane distance [0..1] (depthblurfocaldistance)  <float> (in all games since  ) )
- Depth-blur focal plane distance (in dest alpha space [0,1], not world units)
- Depth-blur effect strength [0..x] (depthblurstrength)  <float> (in all games since  ) )
- Depth-blur effect strength
- Full-screen blur strength [0..1] (screenblurstrength)  <float> (in all games since  ) )
- Full-screen blur strength
Flags
- Master : [1]
- Has priority if multiple postprocess_controllers exist
Inputs
- SetLocalContrastStrength <float>
- Set the local contrast strength.
- SetLocalContrastEdgeStrength <float>
- Set the local contrast strength at the edge of the screen (controlled by vignette).
- SetVignetteStart <float>
- Set the vignette start distance (from screen center).
- SetVignetteEnd <float>
- Set the vignette end distance.
- SetVignetteBlurStrength <float>
- Set the strength of the desaturated blur on the vignette.
- SetFadeToBlackStrength <float>
- Set the fadeout strength.
- SetDepthBlurFocalDistance  <float> (in all games since  ) )
- Set the focal distance of the depth blur effect (in dest alpha space [0,1], not world units).
See also
External links
L4D Art Direction, Part 1: Filmic Effects - Valve blog regarding film effects in Left 4 Dead





