3D Skybox
Présentation
Ajouter un skybox 3D peut améliorer le visuel d'un niveau. La skybox 3d est zone supplémentaire construite par le concepteur du niveau.Il est placé hors limites de la gameplay de la carte.
La skybox 3d peut être imperceptible ,avoir des Transitions transparentes. La skybox 3d est très utilisé dans beaucoup cartes officielles .(maps Counter-Strike: Source )

La skybox 2d est toujours en arrière-planPour modifier ou changer la skybox 2D, voir Skybox (2D).
Intérêts
la Skyboxe standard est une simple images 2d.
la skyboxes 3d est réaliser en 3D ,avec un rendus en temps réel le joueur qui ce déplace dans la map peut voir des effects de shader qui ne sont pas possible dans une skyboxe 2d.
L'avantage principal d'employer une skybox 3D est qu'il permet au concepteur de niveau de faire une carte beaucoup plus grande qu'avec une skybox 2d .
La plus grande carte qui peut être faite sans
skybox 3D,est de 32768 unités par côté. En utilisant un skybox 3D, la carte peut être prolongée de 16 fois.
Les cartes de cette taille sont possibles parce que les skyboxes 3D sont créés dans l'éditeur Hammer à 1/16 de l'échelle de cartes standard.Au temps d'exécution, le moteur les met a l'échelle du reste de la carte. Non seulement ceci économise l'espace dans les vues de l'éditeur, il met également beaucoup moins de temp à compiler et à faire un rendu.
Due to their scale, 3D skyboxes have much lower lightmap and texture resolution. This makes 3D skybox geometry less expensive performance-wise than standard world geometry.
3D skyboxes can be used to overcome draw distance limitations, if a low-detail skybox identical to the main map is created. A mod team wanting to do this would have to develop code to ease the transition between map versions.
Basic characteristics
3D Skyboxes have the following characteristics:
- Are constructed in 1/16 scale in the Hammer editor and then rendered at 16 times size in the engine to match the world geometry.
- Support materials with shader effects such as normal mapping, water, environment mapping, proxies, etc.
- Are non-interactive – players and other world entities cannot enter 3D skyboxes. The 3D skybox is just a visual extension of the map extents.
- Can be constructed with brushes, displacements, static and dynamic props, lights, brush entities, and point entities (such as env_sprite).
- Any models that are placed in the 3D skybox must be authored at 1/16 scale. Standard models (props) are not scaled properly for 3D skybox. Special 1/16 scale versions must be used. For Half-Life 2, these props can be found in the
models/props_skybox
directory. - Should not contain info_player_start, NPCs or monsters.
- Have lower lightmap and texture resolution because of the scale at which they are created.
- Must have they their own lighting sources. For example, the light_environment in the non-skybox section will not affect the 3D skybox lighting.
- Use the sky_camera entity to control how they line up with the non-skybox world geometry.
- 3D skyboxes have their own fog parameters, adjustable in the sky_camera entity.
- Geometry in the 3D skybox is not occluded or culled like the rest of the level geometry. Adding lots of detailed brush geometry or models to the 3D skybox, especially with translucent materials, can severely affect performance.
- The 3D skybox MUST have a
light_environment
in it, otherwise models will be lit incorrectly. For best results use an exact copy of the one used in the main part of the map (note that alight_environment
in the 3D skybox negates the need for one in the main map).
Construction of 3D skyboxes
The most efficient way of creating a 3D skybox that matches or "lines up" with the your current map is to use some of the geometry in the main part of the level. Follow these steps after you’ve created your main level geometry:
- Add a sky_camera entity at the world origin (coordinates 0, 0, 0) , the center of the map grid. The sky_camera is a reference point used by the renderer to align the 3D skybox with the main part of the map. In other words, it acts as a marker telling the renderer how the 3D skybox's origin and the world's origin relate to one another. You can think of this process as being similar to selecting all the 3D skybox geometry and then aligning the sky_camera entity in that selection with the world's origin (0,0,0). The geometry is translated back to that position in the world. This is the same concept used when the skybox is rendered in the engine.
- Select some distinct parts of the level that you can use a guideline for scale and position in the 3D skybox. Common elements to select for this purpose would be some of the larger structures, as well as the walls, cliffs, hills, etc. that define the edges of the map. Make sure you also have the sky_camera you created selected as well.
Note:It is important not to select any model entities, only brushes. Models cannot be used as reference geometry, because models cannot be scaled down in the Hammer editor.
- Choose Copy from the Edit menu, or hit CTRL-C.
- Choose Paste Special from the Edit menu. Set the Number of copies to paste to 1, and all other values to 0. Hit OK. This makes a duplicate of the geometry you had selected.
- Leaving geometry selected, choose Transform from the Tools menu. Select the radio button next to Scale. Type in a value of .0625 for X, Y and Z. This is the decimal equivalent to 1/16 – the scale of the 3D skybox. Click OK.
- . You now have a 1/16 scale version of your reference geometry. Now drag (move) it to another part of the map where you wish build your 3D skybox. It doesn’t matter where it is as long as it’s not touching any part of the main level geometry area.
- Delete the sky_camera entity from the normal world map area you started from. Important: only the sky_camera entity in the 3D skybox should remain in the map.
- Build your 3D skybox geometry around the reference geometry, using it as a guide. You can build skybox geometry that meets the reference geometry seamlessly. You can use brush and displacement geometry. Models can also be placed, but since the 3D skybox is at 1/16 scale, any models must also be at 1/16 scale. The model
hl2\models\props_skybox\coast01.mdl
is a sample model in 1/16 scale. Try positioning the 3D view camera near the height of the player. This will give you a good idea of how the 3D skybox will look when it’s rendered in the engine. - Add a hollow cube of brushes around your reference geometry and assign the
tools\toolsskybox
material to it. The standard 2D cubic skybox will appear on these surfaces. The 3D skybox area must be sealed with these brushes. - Add a light_environment to the 3D skybox. You may want to copy and paste the one from the main part of the level, so the lighting matches.
- When you’re done, delete or hide all of the reference geometry except for the sky_camera entity. You may find that it work best to add the reference geometry to it’s own visgroup so that it can be toggled on and off or re-placed. Just make sure you turn it off before you save and compile the level, or it will be compiled into the 3D skybox.
- Your original map still needs the
tools\toolsskybox
material wherever you want to see the sky, however it will now show the 3D skybox as well as the 2D skybox (which is what it did previously).
Testing
If you properly sealed your 3D skybox, you can now compile the map and check out your new 3D skybox in the engine.
Examples
- See
sdk_content\hl2\mapsrc\sdk_3d_skybox.vmf
for an example of a 3D skybox - An example of extending draw distances with 3D skyboxes (commented)
Environment articles: | |
---|---|
Skies and environment maps | ![]() |
Terrain and displacement mapping | Displacements • Creating Holes in Displacements • Digital Elevation Models • Creating custom terrain with Worldmachine |