Skybox (2D)

From Valve Developer Community

Jump to: navigation, search
简体中文

A 2D skybox is a skybox that lacks geometrical depth, consisting only of a skybox texture (without using the sky_camera entity to display a 3D miniature model).

Skybox Template.jpg

Contents

Adding sky to a map

Simply texture a world brush (not a brush entity) with the tools/toolsskybox or (if you are mapping for the Orange box) the tools/toolsskybox2d material.

In-game, the skybox will be seen through each surface that toolsskybox is applied to.

toolsskybox Brushes do not need to be box-shaped.

Note:In HL2 the default skybox has visible seams. This is not your fault. See the next section for how to change the default.
Note:You should never create a skybox by drawing a big hollowed out cube with the Skybox texture around your map.

Changing the displayed skybox

See also Sky List
Sky change.png

If you don't like the standard "sky_day01_01" sky, you can change it by setting the skybox name in Hammer's Map Properties dialog. With the correct map opened, follow these steps:

  1. Go to the Map menu
  2. Choose Map Properties... from the drop down list
  3. In the Object Properties window, select the Skybox Texture Name field.
  4. Replace the sky listed there with the name of the skybox you wish to display.

Skybox Lighting

Skyboxlight is projected into the World from every toolsskybox surface, and represents Direct Sunlight (or Moonlight) and the Diffuse light reflected from overhead cloud, etc.

These lighting settings - direction, colour, brightness, etc are fairly specific to the actual image used for the 2D skybox. The Sky List article suggests some settings for some of Valve's skyboxes. Note also that env_fog_controller settings will look wrong if they don't correspond to the particular skybox used.

Toolsskybox.gif
Skybox Lighting enters the Map through every toolsskybox-textured Brush.
  • Its basic properties are controlled by three Entities used in combination: light_environment defines (a) the color and intensity of the Diffuse Skylight and (b) the direction, color and intensity of the Direct Sunlight. It also creates (buggy, unconfigurable) Dynamic Shadows which can only be overridden/controlled by the shadow_control Entity. env_sun places a glow sprite in the skybox to represent the Sun's apparent position in the sky. 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.)
  • The Sky List article suggests some settings for some of Valve's skyboxes. The worldspawn Entity defines which skybox to use. Note also that env_fog_controller settings will look wrong if they don't correspond to the particular skybox in use.
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°) 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".

Creating a Custom 2D Skybox Texture

  1. Prepare your image files. You need six images of the same resolution:
    • <skyname>BK
    • <skyname>DN
    • <skyname>FT
    • <skyname>LF
    • <skyname>RT
    • <skyname>UP
  2. Convert them to VTF. Make sure that you "Clamp S" and "Clamp T" or you'll see seams when running with lower texture detail.
  3. Create materials for each texture in \materials\skybox\, using the following template:
unlitgeneric
{
	$basetexture "<VTF>"
	$hdrcompressedtexture "<VTF>"
	$nofog 1
	$ignorez 1
}

Now, in Hammer, go to Map > Map Properties > Skybox Texture Name and type in your skybox name without any side tags.

Creating a 2D skybox for Goldsource, using Source

It is possible to create an area of your map into a 2D Skybox to be used in Goldsource (the HL1-engine). Here's an simple example:

  1. Create a large outdoor area with some displacement maps and treelines, and fog to hide the edges. Lets call it carrotjuice .
  2. Load the map ingame and turn cheats on ( sv_cheats 1 ).
  3. Activate the noclip-mode by simply opening the console and enter "noclip" and hit Enter.
  4. Fly to the center of where you want the skybox.
  5. Open up the console and type "mat_envmaptgasize 256", hit Enter.
  6. Now type "envmap" and press Enter. Now, 6 TGA-files are now created and saved into a folder named "cubemap_screenshots" in your modfolder ( i.e. for HL2DM: Steam\SteamApps\youraccount\Half-Life 2 Deathmatch\hl2mp ).

Since the mapname was carrotjuice , the name of the 6 TGA-files are as following:

carrotjuicert.tga (Right)
carrotjuiceft.tga (Front)
carrotjuicelf.tga (Left)
carrotjuicebk.tga (Back)
carrotjuiceup.tga (Up)
carrotjuicedn.tga (Down)

You can now copy or move these to your HL1-mods gfx\env-folder, to use it as skybox in a level.

See also

Environment articles:
Skies and environment maps Skybox (2D)Skybox (3D)HDR SkiesSkybox with TerragenSkybox with Terragen - AdvancedList of skies
Terrain and displacement mapping DisplacementsHoles in displacementsDigital Elevation Models
Personal tools
Namespaces
Variants
Actions