Env sun: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(→‎Entity description: added workaround warning)
mNo edit summary
Line 3: Line 3:


== Entity description ==
== Entity description ==
Places a sun effect (glow sprite) in the skybox representing the Sun or Moon. It does not contribute any actual lighting - this entity is best used in conjunction with a [[light_environment]].
Places a Sun or Moon effect (glow sprite) in the [[skybox]] where it does not parallax, giving the impression that it is infinitely far away. The env_sun Entity does not contribute any actual lighting.  
 
{{skybox_lighting}}


* The effect's position relative to the player is determined by angle; it does not parallax, so gives the effect of the sun being infinitely far away.
* You can also send inputs to the env_sun entity by directing them to "env_sun" instead of using a target name.
* You can also send inputs to the env_sun entity by directing them to "env_sun" instead of using a target name.
* The effect is additive with the sky: a pure yellow sun with a bright blue sky will appear white in-game; change the color to account for this.
* The effect is additive with the sky: a pure yellow sun with a bright blue sky will appear white in-game; change the color to account for this.
{{Warning|[[light_environment]], [[env_sun]] and [[shadow_control]] should be used together. Each entity represents only a one aspect of a naturally unified phenomenon; Sunlight. [[light_environment]] defines the direct sunlight settings and creates (buggy, unconfigurable) dynamic shadows which can only be overridden/controlled by [[shadow_control]]. [[env_sun]] places a glow sprite in the skybox where the sunlight comes from. To make sense of it all, just make sure that the <angles> (Pitch/Yaw/Roll) are set the same for all three entities. Unfortunately [[shadow_control]] does not have the Pitch override parameter, so its Pitch will be determined by the first of its <angles>. Even more unfortunately, the Pitch override rotation cannot be switched off and is measured counter-clockwise from the horizontal (so straight down is -90 degrees) whereas the <angles> Pitch is rotation is clockwise (so straight down is +90 degrees).}}


== Keyvalues ==
== Keyvalues ==
Line 21: Line 20:
* '''pitch'''
* '''pitch'''
: <integer> The pitch of this entity. 90 is straight up, -90 is straight down.
: <integer> The pitch of this entity. 90 is straight up, -90 is straight down.
{{warning|Unfortunately Valve introduced a ''Pitch override'' parameter to the [[light_environment]] and [[env_sun]] entities, but not to [[shadow_control]]. Even more unfortunately, the ''Pitch override'' cannot be switched off and its rotation is measured counter-clockwise from the horizontal (so straight down is -90&deg;) whereas the ''<angles> Pitch'' is rotation is clockwise (so straight down is +90&deg;). The workaround for this is to make sure your ''Pitch override'' merely repeats the ''<angles>'' value; for example, if your [[shadow_control]], [[light_environment]] and [[env_sun]] ''<angles>'' are "45 -60 0" set the ''Pitch override'' to "-45".}}
* '''rendercolor'''
* '''rendercolor'''
: {{color}} Color of the sun.
: {{color}} Color of the sun.

Revision as of 13:32, 15 April 2008

Template:Wrongtitle Template:Base point

Entity description

Places a Sun or Moon effect (glow sprite) in the skybox where it does not parallax, giving the impression that it is infinitely far away. The env_sun Entity does not contribute any actual lighting.

Toolsskybox.gif

Skyboxes are the main source of light for most maps, and as such are one of the most important parts of making a map.

Overview

Skybox lighting enters the map through every toolsskybox-textured brush, representing direct sun/moonlight and diffuse skylight. Its basic properties are controlled by three entities used in combination (four in some games):

  • light_environment defines the direction, color and intensity of the direct sunlight, and the color and intensity of the diffuse skylight.
  • shadow_control defines the color, direction, and attenuation distance of the dynamic shadows that are created by light_environment. Dynamic shadows will be buggy and unconfigurable without this entity.
  • env_sun places a glowing sprite in the skybox to represent the Sun's apparent position in the sky. It has no effect on lighting aside from this.
  • env_cascade_light casts harsh, real-time shadows onto the map, usually copying settings from the light_environment entity (in all games since Counter-Strike: Global Offensive)(also in Xengine).
  • newLight_Dir places godrays radiate from disk/circle in the skybox; does not contribute any actual lighting (the lighting code is disabled) (only in Xengine).
  • light_deferred_global casts dynamic shadows and lighting similar to env_cascade_light (only in Alien Swarm Deferred)(also in Lambda Wars).

Explanation

To make sense of it all, just make sure you have only one of each of these entities in your map, and that the Pitch and Yaw <angles> are set the same for all three of them. (Pitch is equivalent to the Sun's angle of elevation from the ground, and Yaw is its compass bearing.)

These lighting settings—direction, color, brightness, etc.—are fairly specific to the actual image used for the 2D skybox. The List of skies article suggests some settings for official game skyboxes. The worldspawn entity defines which skybox to use. Also note that fog will look wrong if env_fog_controller's settings don't correspond to the particular skybox in use.

Note.pngNote:Pitch can be overridden for light_environment and env_sun, but not shadow_control. The Pitch override also cannot be switched off and its rotation is measured counter-clockwise from the horizontal (so straight down is -90°) whereas the <angles> Pitch's rotation is clockwise (so straight down is +90°). The workaround for this is to make sure your Pitch override merely repeats the <angles> value; for example, if your shadow_control, light_environment and env_sun <angles> are "45 -60 0", set the Pitch override to "-45".
  • You can also send inputs to the env_sun entity by directing them to "env_sun" instead of using a target name.
  • The effect is additive with the sky: a pure yellow sun with a bright blue sky will appear white in-game; change the color to account for this.

Keyvalues

<target_destination> Name of an entity used to determine where the sun is in the skybox. The sun should be lined up on a line from this entity to the env_sun entity.
<boolean> The old way to orient env_sun is to point it at a target. The new way is to specify the angles. If you use the new way, set this property to YES, otherwise, set this property to NO.
  • pitch
<integer> The pitch of this entity. 90 is straight up, -90 is straight down.
Warning.pngWarning:Unfortunately Valve introduced a Pitch override parameter to the light_environment and env_sun entities, but not to shadow_control. Even more unfortunately, the Pitch override cannot be switched off and its rotation is measured counter-clockwise from the horizontal (so straight down is -90°) whereas the <angles> Pitch is rotation is clockwise (so straight down is +90°). The workaround for this is to make sure your Pitch override merely repeats the <angles> value; for example, if your shadow_control, light_environment and env_sun <angles> are "45 -60 0" set the Pitch override to "-45".
  • rendercolor
#000000 Color of the sun.
  • size
<integer> Size of the sun.
#000000 Overlay Color (R G B)
A value of 0 0 0 will act the old way.
<integer> Overlay Size
A value of -1 means the overlay will act the old way.
<material> Material Name
Material of the inner glow. (sprites/light_glow02_add_noz)
<material> Overlay Material Name
Material of the overlay glow. (sprites/light_glow02_add_noz)

Inputs

  • TurnOn
Enable sun rendering.
  • TurnOff
Disable sun rendering.
  • SetColor #000000
Set the rendercolor.

Outputs