Sky camera: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
 

 Tip:
Tip:
 Note:Fog values on
Note:Fog values on  Confirm:It may be possible to AddOutput the fog keyvalues.
 Confirm:It may be possible to AddOutput the fog keyvalues. 
 Code:There is some leftover code for multiple
Code:There is some leftover code for multiple 
 Warning:If the unmodified version of this entity gets removed in the game, then the game will crash.
Warning:If the unmodified version of this entity gets removed in the game, then the game will crash. 
		
	
| mNo edit summary | No edit summary | ||
| (78 intermediate revisions by 38 users not shown) | |||
| Line 1: | Line 1: | ||
| {{ | {{LanguageBar}} | ||
| {{TabsBar|main=s2|base=sky_camera}} | |||
| {{Preserved entity}} | |||
| {{CD|CSkyCamera|file1=SkyCamera.cpp}} | |||
| {{This is a|semi-internal=1|point entity|name=sky_camera|sprite=1}} It is used to mark the position of the map's origin inside the [[3D Skybox]]. As your position changes relative to the maps origin it will be scaled and applied relative to the <code>sky_camera</code>. | |||
| When the map is compiled, the areas containing <code>sky_camera</code>(s) are skipped during vis calculations. This can be overridden by <code>-forceskyvis</code> on [[VBSP]]. | |||
| By default, only one <code>sky_camera</code> may be active at a time and it cannot move. | |||
| {{tip| | |||
| * In games with [[VScript]], you can control 3D skyboxes and their properties (including fog) per-player using netprops. This includes making them move. Example script can be found [https://tf2maps.net/downloads/change-sky_camera-script.15872/ here] | |||
| * In games without VScript, this [https://tf2maps.net/threads/multiple-3d-skyboxes.35829 workaround] can be used instead for multiple or moving skyboxes. | |||
| * Duplicate your main [[env_fog_controller]] and then turn that into a <code>sky_camera</code> so that the fog settings will be carried over.}} | |||
| {{note|Fog values on <code>sky_camera</code> cannot be changed through inputs (unlike {{ent|env_fog_controller}}) and the max density keyvalue is missing from the FGD by default.{{confirm|It may be possible to [[AddOutput]] the fog keyvalues.}} }} | |||
| {{ModernCodenote|There is some leftover code for multiple <code>sky_camera</code> entities which can be restored in mods. Half-Life 2: Downfall has restored this feature and the work involved is open-source. Downfall's repository can be found [https://github.com/DownFall-Team/DownFall here]. {{mapbase|1}} uses the aforementioned Downfall code and also adds native support for moving (and rotating) skyboxes. Mapbase's repository can be found [https://github.com/mapbase-source/source-sdk-2013 here].}} | |||
| {{warning|If the unmodified version of this entity gets removed in the game, then the game will crash. {{todo|Test the modified code for the same issue.}}}} | |||
| == Keyvalues == | |||
| {{KV|Name|string|intn=targetname|The [[targetname]] that other entities refer to this entity by.|nofgd=1}} | |||
| {{KV|3D Skybox scale|integer|intn=scale|This number determines how large objects in your skybox will seem relative to the map.<br>For example, at a skybox scale of 16, an object 1 unit high in the skybox will seem to be 16 units high to player.}} | |||
| {{KV|Fog Enable|boolean|intn=fogenable|Enable Fog in the Skybox by Default}} | |||
| {{KV|Fog Blend|boolean|intn=fogblend|This will enable blending between two fog colors, based on the direction the player is looking. If the player's viewpoint is equal to the ''fogdir'' vector, the fog will be drawn with the secondary color; if facing in the complete opposite direction, the fog will be drawn with the primary color. <br/> This can be used to approximate the aesthetic effect of diffuse light filtering through the fog, but since the fog effect color is changed for the entire rendered scene, it is best to keep the two colors relatively close to make the blending less obvious. <br/> For example, sunlight with a yaw of 45 degrees and a pitch of -45 degrees could be enhanced using a '''fogdir''' of '-1 -1 1', a '''fogcolor''' of '120 110 100' and a '''fogcolor2''' of '80 70 60'.}} | |||
| {{KV|Use Angles for Fog Dir|boolean|intn=use_angles|}} | |||
| {{KV|Primary Fog Color|color255|intn=fogcolor|The Primary Color of the Fog in the Skybox}} | |||
| {{KV|Secondary Fog Color|color255|intn=fogcolor2|The Secondary Color of the Fog in the Skybox that will be blended to}} | |||
| {{KV|Primary Fog Color (HDR Override)|only={{hl2}} 20th|color255|intn=fogcolor_hdr|The Primary Color of the Fog in the Skybox for HDR maps}} | |||
| {{KV|Secondary Fog Color (HDR Override)|only={{hl2}} 20th|color255|intn=fogcolor2_hdr|The Secondary Color of the Fog in the Skybox for HDR maps that will be blended to}} | |||
| {{KV|Primary Fog Dir|string|intn=fogdir|A vector (given by three space-separated numbers X Y Z) which points from the secondary fog color '''fogcolor2''' towards the primary fog color '''fogcolor'''.}} | |||
| {{KV|Fog Start|string|intn=fogstart|How far from the point-of-view the fog should start. Generally, this should be the same setting as your env_fog_controller.}} | |||
| {{KV|Fog End|string|intn=fogend|How far from the point-of-view the view should be completely fogged. Generally, this should be the same setting as your env_fog_controller.}} | |||
| {{KV|Fog Max Density|float|intn=fogmaxdensity|Fog Max Density [0..1]. Non-FGD in other games except {{gmod|1}}.|nofgd=1|also={{gmod}}}} | |||
| {{KV|Use Radial Fog?|only={{hl2}} 20th, {{hls}}, {{tf2branch}}|intn=fogRadial|boolean|Use radial fog instead of planar-based fog. Only in {{hl2|1}} 20th Anniversary Update, {{hls|1}} (which runs on top of HL2 20th Anniversary base), aswell as all games on {{tf2branch|1}} (since Feb 18, 2025 update).</br>Radial fog is always used on {{l4d|1}} onward, and official maps in {{tf2branch}} games always use radial fog.}} | |||
| {{KV|Clip 3D sky near plane to world far plane|intn=clip_3D_skybox_near_to_world_far|boolean|only={{l4d2}}}} | |||
| {{KV|3D sky near plane offset|intn=clip_3D_skybox_near_to_world_far_offset|float|only={{l4d2}}|Offset for the near clip plane for the 3D sky in world units.  This is only used if the above field is true.  Negative values to pull closer, etc.}} | |||
| {{KV|HDR Color Scale|float|intn=HDRColorScale|Float value to multiply fog color by when running in HDR mode.|since={{l4d2}}}} | |||
| == Inputs == | |||
| {{I|ActivateSkybox|Activates targeted sky_camera and disables rest.|since=L4D2|nofgd=1}} {{warning|Should your skyboxes have models or brushwork capable of throwing shadows, '''all shadows of all props from all skyboxes''' will compile shadows onto your map. Even when the skybox is switched, the shadows on your map will remain.}} | |||
| ==See also== | == See also == | ||
| * [[ | * [[3D Skybox]] | ||
| * [[ | * [[Skybox Basics]] - an overview article on skybox creation. | ||
| [[Category: | [[Category:Skybox]] | ||
Latest revision as of 11:02, 23 September 2025

This is a preserved entity in 







If the game has round restart mechanics this entity may not behave as expected.








If the game has round restart mechanics this entity may not behave as expected.
|  Class hierarchy | 
|---|
| CSkyCamera | 
|  SkyCamera.cpp | 

sky_camera  is a  semi-internal point entity  available in all  Source games. It is used to mark the position of the map's origin inside the 3D Skybox. As your position changes relative to the maps origin it will be scaled and applied relative to the
 Source games. It is used to mark the position of the map's origin inside the 3D Skybox. As your position changes relative to the maps origin it will be scaled and applied relative to the sky_camera.
When the map is compiled, the areas containing sky_camera(s) are skipped during vis calculations. This can be overridden by -forceskyvis on VBSP.
By default, only one sky_camera may be active at a time and it cannot move.
 Tip:
Tip:
- In games with VScript, you can control 3D skyboxes and their properties (including fog) per-player using netprops. This includes making them move. Example script can be found here
- In games without VScript, this workaround can be used instead for multiple or moving skyboxes.
- Duplicate your main env_fog_controller and then turn that into a sky_cameraso that the fog settings will be carried over.
 Note:Fog values on
Note:Fog values on sky_camera cannot be changed through inputs (unlike env_fog_controller) and the max density keyvalue is missing from the FGD by default. Confirm:It may be possible to AddOutput the fog keyvalues.
 Confirm:It may be possible to AddOutput the fog keyvalues. Code:There is some leftover code for multiple
Code:There is some leftover code for multiple sky_camera entities which can be restored in mods. Half-Life 2: Downfall has restored this feature and the work involved is open-source. Downfall's repository can be found here. Mapbase uses the aforementioned Downfall code and also adds native support for moving (and rotating) skyboxes. Mapbase's repository can be found here. Warning:If the unmodified version of this entity gets removed in the game, then the game will crash.
Warning:If the unmodified version of this entity gets removed in the game, then the game will crash. Todo: Test the modified code for the same issue.
Keyvalues
- Name (targetname) <string> !FGD
- The targetname that other entities refer to this entity by.
- 3D Skybox scale (scale) <integer>
- This number determines how large objects in your skybox will seem relative to the map.
 For example, at a skybox scale of 16, an object 1 unit high in the skybox will seem to be 16 units high to player.
- Fog Enable (fogenable) <boolean>
- Enable Fog in the Skybox by Default
- Fog Blend (fogblend) <boolean>
- This will enable blending between two fog colors, based on the direction the player is looking. If the player's viewpoint is equal to the fogdir vector, the fog will be drawn with the secondary color; if facing in the complete opposite direction, the fog will be drawn with the primary color. 
 This can be used to approximate the aesthetic effect of diffuse light filtering through the fog, but since the fog effect color is changed for the entire rendered scene, it is best to keep the two colors relatively close to make the blending less obvious.
 For example, sunlight with a yaw of 45 degrees and a pitch of -45 degrees could be enhanced using a fogdir of '-1 -1 1', a fogcolor of '120 110 100' and a fogcolor2 of '80 70 60'.
- Use Angles for Fog Dir (use_angles) <boolean>
- Primary Fog Color (fogcolor) <color255>
- The Primary Color of the Fog in the Skybox
- Secondary Fog Color (fogcolor2) <color255>
- The Secondary Color of the Fog in the Skybox that will be blended to
- Primary Fog Color (HDR Override) (fogcolor_hdr)  <color255> (only in  20th) 20th)
- The Primary Color of the Fog in the Skybox for HDR maps
- Secondary Fog Color (HDR Override) (fogcolor2_hdr)  <color255> (only in  20th) 20th)
- The Secondary Color of the Fog in the Skybox for HDR maps that will be blended to
- Primary Fog Dir (fogdir) <string>
- A vector (given by three space-separated numbers X Y Z) which points from the secondary fog color fogcolor2 towards the primary fog color fogcolor.
- Fog Start (fogstart) <string>
- How far from the point-of-view the fog should start. Generally, this should be the same setting as your env_fog_controller.
- Fog End (fogend) <string>
- How far from the point-of-view the view should be completely fogged. Generally, this should be the same setting as your env_fog_controller.
- Fog Max Density (fogmaxdensity)  <float> (also in  ) !FGD ) !FGD
- Fog Max Density [0..1]. Non-FGD in other games except Garry's Mod.
- Use Radial Fog? (fogRadial)  <boolean> (only in  20th, 20th, , , ) )
- Use radial fog instead of planar-based fog. Only in Half-Life 2 20th Anniversary Update, Half-Life: Source (which runs on top of HL2 20th Anniversary base), aswell as all games on Team Fortress 2 branch (since Feb 18, 2025 update).
 Radial fog is always used on Left 4 Dead onward, and official maps in games always use radial fog. games always use radial fog.
- Clip 3D sky near plane to world far plane (clip_3D_skybox_near_to_world_far)  <boolean> (only in  ) )
- 3D sky near plane offset (clip_3D_skybox_near_to_world_far_offset)  <float> (only in  ) )
- Offset for the near clip plane for the 3D sky in world units. This is only used if the above field is true. Negative values to pull closer, etc.
- HDR Color Scale (HDRColorScale)  <float> (in all games since  ) )
- Float value to multiply fog color by when running in HDR mode.
Inputs
- ActivateSkybox   (in all games since  ) !FGD ) !FGD
- Activates targeted sky_camera and disables rest.  Warning:Should your skyboxes have models or brushwork capable of throwing shadows, all shadows of all props from all skyboxes will compile shadows onto your map. Even when the skybox is switched, the shadows on your map will remain. Warning:Should your skyboxes have models or brushwork capable of throwing shadows, all shadows of all props from all skyboxes will compile shadows onto your map. Even when the skybox is switched, the shadows on your map will remain.
See also
- 3D Skybox
- Skybox Basics - an overview article on skybox creation.


























