Cubemaps: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(Better way to fix the cubemap crash bug in P2.)
 
(274 intermediate revisions by 47 users not shown)
Line 1: Line 1:
{{otherlang2
{{LanguageBar}}
|fr=Cubemaps:fr
{{Tabs|Cubemaps|source=1|source2=1|main=source}}
}}
{{warning|{{clr}}
[[Image:Env_cubemap.png|left]][[Image:Specular.jpg|thumb|350px|right|Specular reflections.]]
* '''EPILEPSY WARNING''': Building cubemaps on a faster systems (with high single-thread performance) will causes the top left of the screen (which display captured cubemap images) to flicker much faster.<br>It will also flicker white when building HDR cubemaps}}
Many reflective [[material]]s must be combined with external data so that the [[Source]] engine can correctly generate their appearance. This data is stored as a ''cubemap'', a texture which represents a three-dimensional rendering of an area. The Source engine uses [[env_cubemap|env_cubemap]] entities as sampling points for generating these textures, and saves the cubemaps inside each map's .bsp file. While processing specular and environment-mapped materials, it utilizes them to more accurately generate environments.
[[File:Env_cubemap.png|left]]
[[File:Specular.jpg|thumb|right|300px|An example of specular reflections on some models (exaggerated through {{cmd|r_showenvcubemap}}).]]
A '''cubemap''' is a texture that represents a three-dimensional rendering of an area. {{source|4.1}} uses {{ent|env_cubemap}} entities as sampling points to generate these textures, which are then integrated into the [[BSP|map file]]. Cubemaps, when [[#Building cubemaps|built]], are reflected on materials that use the [[$envmap]] parameter (surfaces such as reflective glass, tiles, water, etc.) A map without built or existing '''env_cubemap''' entities will instead use other kinds of "reflections" (such as default cubemap texture, see below) that don't properly depict it, appear broken ([[Missing content|missing textures]], reflections appear bright, etc...), or simply doesn't show any reflections (if the cubemap texture is black).


In other words, a cubemap creates the textures that a reflective surface will be reflecting.


{{note|In some games, there are no default cubemaps, so all reflective surfaces will show the [[missing content]] texture, which resembles a pink and black checkerboard. To fix this you will need to build cubemaps manually as described further on.}}
==Building cubemaps==
[[File:Default_cubemap.png|192px|thumb|right|This default cubemap texture will appear if you skip building blank cubemaps during VBSP process.]]
'''Building cubemaps''' is the process of generating textures to use as reflections. For technical reasons, this process isn't automated {{mapbase|in|addtext-front=''Except''{{nbsp}}}} and is up to the user to do so; until then, existing '''env_cubemap''' entities will remain unused and the map, depending on the game, will display either:
*A blank (black) texture (which basically make it look the same as {{code|mat_specular 0}} / disabled reflections)
** During compilation, VBSP will generate blank cubemap textures.
** If you skip VBSP's blank cubemap generation (either by using Mapbase's VBSP without adding {{code|-autocubemap}}, using {{slamminsrc|name}} VBSP with {{code|-nodefaultcubemap}}, or if you [[#Deleting cubemaps|deleted the cubemaps]], it will display the missing or generic environment texture instead, and building cubemaps for the first time (without disabling {{code|mat_specular}}) will instead generate blank textures (or partially generate the cubemaps, with some of them being blank), until building it again second time, so don't forget to disable it. {{code|mat_specular}} must be also disabled prior to loading the map, otherwise disabling them after the map have been loaded, will cause {{code|buildcubemaps}} to generate blank textures aswell.
*Default cubemap texture (see image on right)
** If the cubemap is missing, the game first tries to fall back to LDR cubemaps (and fails), so the game ended up using this texture instead, showing the empty desert with sunset sky as reflections.
*Cubemaps causing models appear bright or glowing ([[HDR]] only, if LDR cubemaps is only present)
** If HDR version of the cubemap isn't present, the game will fall back to LDR version, which will cause it to appear bright and glowing on HDR.
*[[Missing content|Missing textures]] as reflections
** If the cubemap is missing and the game fails to use the default cubemap texture for some reasons, missing texture will show up as reflections.
** This also appears if you recompiled the map and overwrite the original which have cubemaps texture baked in, then {{key|Alt}} + {{Key|Tab}} back to the game (which sometime reloads the textures).


==Placement==
===Before building===
Declaring areas for cubemaps to cover is simple, just place an [[env_cubemap|env_cubemap]] point entity inside the space of a map. When the map is compiled with [[vbsp|VBSP]], world geometry surfaces automatically associate themselves with the nearest [[env_cubemap|env_cubemap]] and will use the cubemap generated from it. Entities associate themselves with the [[env_cubemap|env_cubemap]] closest to their origin (alternatively, a cubemap can be applied to specific brush faces in the cubemap's properties); moving entities will dynamically change which cubemap they use. It is important to choose [[env_cubemap|env_cubemap]] positions properly for both aesthetic and performance issues.
{{Cleanup|Modern Source games, namely {{portal2|1}} and {{p2ce|1|nt=1}}, do not need all these complicated params and steps, at least in my experience -[[User:Equalizer5118|Equalizer]] ([[User talk:Equalizer5118|talk]]) 10:56, 22 March 2024 (PDT)
Also some Source games (such as CS:S and HL2), doesn't appear to require cheats to be enabled to build cubemaps. Deleting cubemaps is probably not needed (atleast for SP games), since this would require you to use {{code|mat_specular 0}}, otherwise {{code|buildcubemaps}} will instead generate blank texture until you run the command again.</br>Edit 2: {{css|2}} builds cubemap correctly now without deleting cubemaps after engine update ({{tf2branch|1}}), so some steps can be skipped. -[[User:Kr0tchet|leonidakarlach]] ([[User talk:Kr0tchet|talk]]) 02:50, 25 August 2024 (PDT) - Edited 24 Feb 2025.
{{l4d2|2}} also does not require anything, other than '''maybe''' turning shader quality to medium. But it's not always required. Just loading the map and running Buildcubemaps is often enough. --[[User:MrFunreal|MrFunreal]] ([[User talk:MrFunreal|talk]]) 02:23, 11 February 2025 (PST)}}
{{Important|Maps for {{src13|4.1}} games (including {{tf2branch|4.1}}) and others, such as {{css|4.1}}, are known to include pre-built, blank cubemaps after being compiled (even if there are no '''env_cubemap''' entities in them). In {{mapbase|4.1}}, blank cubemaps are not automatically generated by default.</br>For {{src13sp|2}} and {{src13mp|2}} titles (including previous version of Valve games), [[#Deleting cubemaps|deleting cubemaps]] will be required (in order to make sure cubemaps are properly written to the BSP).
{{Tip|Deleting pre-built blank cubemaps, while not required, is recommended for {{l4dbranch|2}} games or later (and [[HDR]]-only games) since [[VBSP]] generates blank LDR cubemap textures that increase BSP file size while being unused anyway in those games.}}
{{Note|Deleting pre-built blank cubemaps isn't required for {{hl2|1}}, {{portal|1}} nor the {{tf2branch|2}} games ({{css}}, {{dods}}, {{hldms}}, {{hldms}} and {{tf2}}), since the updated version of those games (as of 2025) now have built and written generated cubemaps to the .BSP correctly. Deleting blank cubemaps is also not required on {{Srcsdk13mp|1}} (also on TF2 branch), but required for {{srcsdk13sp|1}}, and the legacy version of {{srcsdk13mp|1}}.}}
}}
{{Important|
*  To build cubemaps, your game's screen resolution needs to be at least 4 times higher than the highest [[Env cubemap#Keyvalues|size]] of an existing '''env_cubemap''', or else attempting to build them will either fail or even cause the game to crash.<br>For example, if the highest '''env_cubemap''' sizes 128x128, a resolution no lower than 512x512 will be required. (''128 &times; 4 &#61; '''512''' -&gt; 720x576'' (as a valid resolution) or higher)
* Disable any [[anti-aliasing]] method (SGSSAA for example) forced through GPU driver and enable the in-game AA or use FXAA instead (or simply run the game in [[Vulkan]] which will disable all forced AA) to avoid cubemaps being slowly built. This also applies to running the game at higher resolutions (such as 4K), which will cause cubemaps to be slowly built on weaker hardware. Running the game at lower resolutions (like 1080p) and/or disable AA (other than in-game AA), and disable any FPS cap, will significantly speed up building cubemaps progress.
}}
{{warning|{{clr}}
* '''EPILEPSY WARNING''': Building cubemaps on a faster systems (with high single-thread performance) will causes the top left of the screen (which display captured cubemap images) to flicker much faster. Look away from the screen while the cubemaps are being built.
** Additionally, the screen will also flashes white when building HDR cubemaps.
** This mostly doesn't applies to games on {{src06|1}} or earlier, since these branches doesn't support multi-core and building cubemaps will take little bit longer on these branches.
* If the {{Command|nav_show_ladder_bounds}} command was used before building cubemaps, the green boxes will also be baked into the cubemap. The same goes for {{cmd|r_screenoverlay}}, and most screen space effects.
* While taking damage, building cubemaps when the screen is tinted red/white will cause the red/white tints baked into the cubemap.
* Maps that contains {{ent|env_credits}}, like the Half-Life 2 introduction scene seen in {{code|d1_trainstation_01}} on "[[Point Insertion]]" and the [[Half-Life 2 Credits|HL2 Credits]], you must wait for the credits/introduction to end, otherwise building cubemaps will lead to generating blank (black) textures. Use {{code|host_timescale}} console command and temporarily set to high value (like {{code|99}}) to speed up the introduction scene/end credits, then set {{code|host_timescale}} to {{code|1}} and follow the build cubemaps instructions below.
* The game may appear to freeze or become unresponsive during the process of building cubemaps, and the amount of time depends on various factors (amount of {{code|env_cubemap(s)}}, cubemap sizes, CPU usage/utilization and framerate). For successful results, don't switch away from the game until it's done.</br>If you have the game running on windowed/borderless windowed mode, clicking on the game while building cubemaps will cause the windows to freeze with "Not Responding" on the titlebar (even through the game is still building cubemaps). To avoid this, it's highly recommended that you run the game in (exclusively) fullscreen mode.</br>'''For users using Vulkan instead of Direct3D 9 (Windows only):''' Clicking on the game while building cubemaps, even in fullscreen, will also cause the game to permanently freeze.
* If you are building cubemaps for {{Hl2|4.1}} (except episodes) after the '''20th Anniversary Update''', you must [[Cubemaps#Half-Life 2|follow the instructions]] here. Also building cubemaps in Half-Life 2 without removing some NPCs (or switching to a non-Gravity Gun weapon) will cause sprites' light from them to be baked into cubemaps.
}}
{{tip|{{clr}}
* {{ent|env_cubemap}} entities [[Env cubemap#Keyvalues|allow]] for generating higher- or lower-quality reflections, though the game's texture quality also comes into play; consider maxing out your game's visual settings (set texture, models, shaders, shadow details to '''High'''/'''Very High''') before building cubemaps. Higher anti-aliasing settings also makes minor differences (not easily noticable).
* Running the game at lower resolution (while making sure your screen resolutions are 4 times larger) and disabling FPS cap (both in game, graphics driver and software like [https://www.guru3d.com/page/rivatuner-rtss-homepage/ RTSS]) can speed up building cubemaps progress.
* [[Bind]] {{code|mat_hdr_level 0}}, {{code|mat_hdr_level 2}}, {{code|building_cubemaps 1}} to any numpad keys, and {{code|buildcubemaps}} to numpad {{Key|Enter}} key, so you don't have to manually type and submit most of these command on console.
}}
* If you are using {{mapbase|4.1}}, you can add {{code|-autocubemap}} to launch the game ({{code|$game_exe}}) command line in {{hammer|1}}. The game will automatically build cubemaps.
* {{slamminsrc|4.1|nt=1}} VBSP features the {{code|-nodefaultcubemap}} command, which skips automatically generating skybox cubemaps on map compile.


Cubemaps are used in a few specific ways, and should be placed accordingly. Some cubemaps are used for reflections on static world geometry. Others are used with player entities, including [[NPC|NPCs]]. And the rest are used for any non-player reflective entities. The optimal placement of [[env_cubemap|env_cubemap]] entities corresponds with each of these uses, to ensure the maximal benefit, ''visually and in performance.'' Here are a few simple heuristics to follow:
===LDR===
{{note|This step doesn't apply to {{l4d|4.1}} nor {{csgo|4.1}} as their maps are compiled in [[#HDR|HDR mode]] only. While {{p2|4.1}} does support LDR, the game uses HDR by default, so we recommend building cubemaps in HDR only.}}
{{Note|Cheats do not have to be enabled to build cubemaps in: {{hls|1}}, {{hl2|1}}, {{hl2dm|1}} (all three since {{hl2}} 20th Anniversary Update), {{portal|1}} (since May 20, 2025) nor the {{tf2branch|1}} games.}}
Building cubemaps in a map compiled in '''LDR''' (''Low Dynamic Range'') mode will generate textures only for that mode, regardless of your game's ''High Dynamic Range'' video setting. To build the cubemaps, submit the following commands into the game's console:
{| class="wikitable"
|-
! Command !! Description
|-
| {{Command|mat_specular|0}} || Turns reflections off, which is necessary if using only one iteration of buildcubemaps, and if all [[#Deleting cubemaps|cubemaps has been deleted]].<br>It also meant that disabling reflections would avoid some case where missing textures or default cubemap texture ({{code|materials/engine/defaultcubemap.vtf}}, aka a desert with orange sunset sky), might end up reflected on the cubemap itself.</br>{{Note|If you let VBSP generate blank cubemaps and you build the cubemaps without this command, it will build (and written cubemaps to [[BSP]]) just fine (atleast in {{hl2}}), however, if you deleted the cubemaps and run {{code|buildcubemaps}}, without disable {{code|mat_specular}}, it will instead generate and write blank textures, until you run {{code|buildcubemaps}} a second time. {{code|mat_specular}} must be also disabled prior to loading the map, otherwise disabling them after the map have been loaded, will cause {{code|buildcubemaps}} to generate blank textures aswell.}}
|-
| {{Command|map}} ''map_name''</code> || Loads the map; replace "''map_name''" with the map's actual name
|-
| {{Command|sv_cheats|1}} || Enables the use of cheat commands; required to build cubemaps<br>{{Note|{{hl2|1}}, {{hl2dm|1}} (since 20th Anniversary), {{portal|1}} (since May 20, 2025 update) and all {{tf2branch|1}} games ({{css}}, {{dods}}, {{hl2dm}}, {{hldms}} and {{tf2}}), doesn't require cheats to build cubemaps, so this step can be skipped. In many {{src13|1}} (SP/MP) games, including previous version of {{css|1}}, {{code|buildcubemaps}} can also be built without having to enable cheats, however, {{code|mat_reloadallmaterials}} (command that requires {{code|sv_cheats 1}}) must be run once in order to display the newly-built cubemaps, since cubemap textures may not be automatically loaded when you load up the map manually. Confirm if other games also require cheats to build cubemaps.}}
|-
| {{Command|buildcubemaps}} || Begins building cubemaps. Optionally, specify the number of iterations (e.g.: <code>buildcubemaps 2</code> (default is 1))
|-
| {{Command|disconnect}} || Unloads the map and returns to the main menu
|-
| {{Command|mat_specular|1}} || Turns reflections on, then follow the step below, or optionally you can repeat the process again by following instructions on [[#Improve reflections by rebuilding cubemaps|Improve reflections by rebuilding cubemaps]].
|-
| {{Command|map}} ''map_name''</code> || Loads the map again, your cubemaps should display after doing these steps.
|-
| {{code|[[mat_reloadallmaterials]]}}</br>(''requires'' {{code|sv_cheats 1}})|| In some games or branch ({{src13|1}}), if it doesn't display new cubemap textures after loading the map, run this command to display the newly-built cubemaps. This command may run automatically when you load up the map while cheats is already enabled. This command is usually not required on {{hl2|1}} (since 20th Anniversary update), {{portal|1}} (since May 2025 update) nor the {{tf2branch|1}} games, since cubemaps should be automatically reloaded when you load the map.
|}


*If a cubemap is intended for NPCs or the player, the [[env_cubemap|env_cubemap]] should be placed at head-height (as a rule of thumb, 64 hammer units) above the ground. This way, the cubemap will most accurately represent the world from the perspective of a standing creature.
===LDR + HDR===
*If a cubemap is intended for static world geometry, the [[env_cubemap|env_cubemap]] should be a fair distance (as a rule of thumb, 16 hammer units) away from all brush surfaces.
Building cubemaps in {{src06|3.1}} - {{src13|3.1}} game, with a map compiled with [[HDR]] support needs to be performed twice - once for each mode ('''HDR''' and '''LDR'''). As opposed to an '''LDR''' map's case, your game's ''High Dynamic Range'' video setting has to be set to "Full" to build '''HDR''' cubemaps, and to "None" to build '''LDR''' ones (or using the {{code|mat_hdr_level}} command. To build the cubemaps for both LDR + HDR, submit the following commands into the game's console:
*A different cubemap should be taken in each area of distinct of visual contrast. A hallway with bright yellow light will need its own [[env_cubemap|env_cubemap]], especially if it is next to a room with low blue light. Without two [[env_cubemap|env_cubemap]] entities, reflections and specular highlights will seem incorrect on entities and world geometry in one of the areas.
{{Note|Maps built on {{l4d|1}}, or later (and some third-party Source games), does not requires building cubemaps on LDR. See [[#HDR]]}}
{{Note|Cheats are not required to be enable to build cubemaps in: {{hl2|1}}, {{hl2dm|1}} (since 20th Anniversary) and all {{tf2branch|1}} games.}}
{| class="wikitable"
|-
! Command !! Description
|-
| {{Command|mat_specular|0}} || Turns reflections off, which is necessary if using only one iteration of buildcubemaps, and if all [[#Deleting cubemaps|cubemaps has been deleted]].<br>It also meant that disabling reflections would avoid some case where missing textures or default cubemap texture ({{code|materials/engine/defaultcubemap.vtf}}, aka a desert with orange sunset sky), might end up reflected on the cubemap itself.{{Note|This command is flagged as "launcher"-only in {{l4d|1}} and {{l4d2|1}}, you can use the following command instead: </br>{{L4d}} {{code|sm_cvar mat_specular 0}} command (with [[SourceMod]] installed) or </br>{{L4d2}} {{code|script Convars.SetValue("mat_specular", "0")}} (using [[VScript]]).}}{{Note|If you let VBSP generate blank cubemaps and you build cubemaps without this command, it will build (and written cubemaps to [[BSP]]) just fine (atleast in {{hl2}}), however, if you deleted the cubemaps and run {{code|buildcubemaps}}, without disabling {{code|mat_specular}}, it will instead generate and write blank textures, until you run {{code|buildcubemaps}} a second time. {{code|mat_specular}} must be also disabled prior to loading the map, otherwise disabling them after the map have been loaded, will cause {{code|buildcubemaps}} to generate blank textures aswell.}}
|-
| {{Command|map}} ''map_name'' || Loads the map; replace "''map_name''" with the map's actual name
|-
| {{Command|sv_cheats|1}} || Enables the use of cheat commands; required to build cubemaps<br>{{Note|{{hl2|1}}, {{hl2dm|1}} (since 20th Anniversary) and all {{tf2branch|1}} games ({{css}}, {{dods}}, {{hl2dm}}, {{hldms}} and {{tf2}}), doesn't require cheats to build cubemaps, so this step can be skipped. In many {{src13|1}} (SP/MP) games, including previous version of {{css|1}}, {{code|buildcubemaps}} can be also built without enabling cheats, however, {{code|mat_reloadallmaterials}} (command that requires {{code|sv_cheats 1}}) must be run once in order to display the newly built-cubemaps, since cubemap textures may not be automatically loaded when you load up the map manually. Confirm if other games also require cheats to build cubemaps.}}
|-
| {{Command|building_cubemaps (console command)|alt=building_cubemaps|1}} || Sets HDR exposure to a consistent value, which will make sure that no cubemaps won't look brighter or darker than others. This will automatically reset back to 0 after cubemaps are built.{{Note|This command is flagged as "launcher"-only in {{l4d|1}} and {{l4d2|1}}, you can use the following command instead: </br>{{L4d}} {{code|sm_cvar building_cubemaps 1}} command (with [[SourceMod]] installed) or </br>{{L4d2}} {{code|script Convars.SetValue("building_cubemaps", "1")}} (using [[VScript]]).}}
|-
| {{Command|buildcubemaps}} || Begins building cubemaps. Optionally, specify the number of iterations (e.g.: <code>buildcubemaps 2</code> (default is 1))</br>In singleplayer games, the map will be automatically reloaded after building cubemaps.
|-
| {{Command|disconnect}} || Unloads the map and returns to the main menu
|-
| {{Command|sv_cheats|0}} || Disables cheat commands; prevents command <code>''mat_reloadallmaterials''</code> from unnecessarily self-executing (which briefly freezes the game)
|-
| {{Command|mat_hdr_level|0}} || Switches to '''LDR''' mode (from '''HDR'''); submit <code>''mat_hdr_level 2''</code> instead if '''LDR''' cubemaps were built first
|-
| {{Command|map}} ''map_name'' || Loads the map again to build cubemaps for the new mode
|-
| {{Command|sv_cheats|1}} ||
|-
| {{Command|buildcubemaps}} || Begins building cubemaps for the new mode
|-
| {{Command|disconnect}} ||
|-
| {{Command|mat_specular|1}} || Turns reflections on, then follow the step below, or optionally you can repeat the process again by following instructions on [[#Improve reflections by rebuilding cubemaps|Improve reflections by rebuilding cubemaps]].
|-
| {{Command|mat_hdr_level|0/1/2}} || If necessary, switches back to the mode it was before having submitted <code>''mat_hdr_level 0/2''</code>
|-
| {{Command|map}} ''map_name''</code> || Loads the map again, your cubemaps should display after doing these steps.
|-
| {{code|[[mat_reloadallmaterials]]}}</br>(''requires'' {{code|sv_cheats 1}})</br>or {{Key|Alt + Tab}} / Restart game|| In some games, such as {{css|1}}, if it doesn't display new cubemap textures after loading the map, run this command to display the newly-built cubemaps. This command may run automatically when you load up the map while server cheats are already enabled.</br>If this command does not reload cubemaps in-game, you can instead try {{key|Alt}} + {{key|Tab}}'ing while in fullscreen or simply restart the game; the latter method can sometimes reload the texture (and display the new cubemap) aswell.
{{Note|{{Key|Alt + Tab}} only works properly in {{src09|1}} or earlier, and {{l4dbranch|1}} or later. {{src13|1}} and {{csgobranch|1}} games use Direct3D 9Ex, which meant that running those games on Windows 10/11, without setting multiple displays to "Duplicate" or disable fullscreen optimization, it will not reload anything at all when you {{key|Alt + Tab}}.}}
{{Note|Usually not required on {{hl2|1}} nor the {{tf2branch|1}} games, since cubemaps should be automatically reloaded when you load the map.}}
|}


==Building==
===HDR===
Once a map has been compiled and lit by [[Vbsp|VBSP]] and [[Vrad|VRAD]] (respectively), the cubemaps can be built. Run the map and allow the any node graphs or other pre-process activities to finish. Then use the <code>buildcubemaps</code> [[Developer_Console|console]] command to begin building the cubemaps for the level. In the upper left-hand corner of the screen you’ll be able to see each facet of the cubemap (six per cubemap) render. Depending on your video card, driver and complexity of your scenes, this can take seconds or minutes to complete. Once finished, the map must be restarted for the cubemaps to properly be applied to all surfaces.
This section is for games running on the {{l4dbranch|4}} and later, or engine branches that only support HDR (such as {{xengine|1}}). To build cubemaps in HDR only, submit the following commands into the game's console:


{{note|Built cubemaps are saved in the bsp file the game loaded, which will be in the maps folder, not the location where the bsp file was built.}}
{| class="wikitable"
|-
! Command !! Description
|-
| {{Command|mat_specular|0}} || Turns reflections off, which is necessary if using only one iteration of buildcubemaps, and if all [[#Deleting cubemaps|cubemaps have been deleted]].<br>It also meant that disabling reflections would avoid some case where missing textures or default cubemap texture ({{code|materials/engine/defaultcubemap.vtf}}, aka a desert with orange sunset sky), might end up reflected on the cubemap itself.{{Note|This command is flagged as "launcher"-only in {{l4d|1}} and {{l4d2|1}}, you can use the following command instead: </br>{{L4d}} {{code|sm_cvar mat_specular 0}} command (with [[SourceMod]] installed) or </br>{{L4d2}} {{code|script Convars.SetValue("mat_specular", "0")}} (using [[VScript]]).}}{{Note|If you let VBSP generate blank cubemaps and you build cubemaps without this command, it will build (and written cubemaps to [[BSP]]) just fine (atleast in {{hl2}}), however, if you deleted the cubemaps and run {{code|buildcubemaps}}, without disabling {{code|mat_specular}} first, it will instead generate blank textures, until you run {{code|buildcubemaps}} a second time. {{code|mat_specular}} must be also disabled prior to loading the map, otherwise disabling them after the map have been loaded, will cause {{code|buildcubemaps}} to generate blank textures aswell.}}
|-
| {{Command|map}} ''map_name'' || Loads the map; replace "''map_name''" with the map's actual name
|-
| {{Command|sv_cheats|1}} || Enables the use of cheat commands; required to build cubemaps<br>{{Note|{{hl2|1}}, {{hl2dm|1}} (since 20th Anniversary) and all {{tf2branch|1}} games ({{css}}, {{dods}}, {{hl2dm}}, {{hldms}} and {{tf2}}), do not require cheats to build cubemaps, so this step can be skipped. In many {{src13|1}} (SP/MP) games, including previous version of {{css|1}}, {{code|buildcubemaps}} can be also built without enabling cheats, however, {{code|mat_reloadallmaterials}} (a command that requires {{code|sv_cheats 1}}) must be run once in order to display the newly built-cubemaps, since cubemap textures may not be automatically loaded when you load up the map manually. Confirm if other games also require cheats to build cubemaps.}}
|-
| {{Command|building_cubemaps (console command)|alt=building_cubemaps|1}} || Sets HDR exposure to a consistent value, which will make sure that one cubemap won't look brighter or darker than others. This will automatically reset back to 0 after cubemaps are built.{{Note|This command is flagged as "launcher"-only in {{l4d|1}} and {{l4d2|1}}, you can use the following command instead: </br>{{L4d}} {{code|sm_cvar building_cubemaps 1}} command (with [[SourceMod]] installed) or </br>{{L4d2}} {{code|script Convars.SetValue("building_cubemaps", "1")}} (using [[VScript]]).}}
|-
| {{Command|buildcubemaps}} || Begins building cubemaps. Optionally, specify the number of iterations (e.g.: <code>buildcubemaps 2</code> (default is 1))</br>In singleplayer games, the map will be automatically reloaded after building cubemaps.
|-
| {{Command|disconnect}} || Unloads the map and returns to the main menu
|-
| {{Command|mat_specular|1}} || Turns reflections on, then follow the step below, or optionally you can repeat the process again by following instructions on [[#Improve reflections by rebuilding cubemaps|Improve reflections by rebuilding cubemaps]].
|-
| {{Command|map}} ''map_name''</code> || Loads the map again, your cubemaps should display after doing these steps.
|-
| {{code|[[mat_reloadallmaterials]]}}</br>(''requires'' {{code|sv_cheats 1}})</br>or {{key|Alt + Tab}} / Restart game|| In some games, such as {{css|1}}, if it doesn't display new cubemap textures after loading the map, run this command to display the newly-built cubemaps. This command may run automatically when you load up the map while server cheats are already enabled. In {{l4d|1}} (or some Source games), this command may not reload cubemaps in-game, so instead {{key|Alt}} + {{key|Tab}}'ing while in fullscreen or simply restarting the game can sometimes reload the texture (and display the new cubemap) aswell.
{{Note|{{Key|Alt + Tab}} only works properly in {{src09|1}} or earlier, and {{l4dbranch|1}} or later. {{src13|1}} and {{csgobranch|1}} games use Direct3D 9Ex, which meant that running those games on Windows 10/11, without setting multiple displays to "Duplicate" or disable fullscreen optimization, it will not reload anything at all when you {{key|Alt + Tab}}.}}
{{Note|Usually not required on {{hl2|1}} or all {{tf2branch|1}} games, since cubemaps should be automatically reloaded when you load the map.}}
|}


{{note|If you intend to change the name of your bsp and build its cubemaps, you must buildcubemaps before renaming and packing the bsp.}}
==Building cubemaps in specific games==
===Black Mesa===
To build cubemaps in {{bms|4.1}} maps, the game has to be launched with these parameters: <code>-oldgameui -dev -console +r_4way_use_fast_normals 0</code><br>Then, load the map, follow the instructions on [[#HDR|HDR section]].


===Left 4 dead===
After building cubemaps, you can proceed to [[#Improve reflections by rebuilding cubemaps]] or simply quit the game, then launch the game again without the command-line argument.
{{note| For some games (L4D{{L4d}}/L4D2{{L4d2}}) a complete '''game restart''' is required after building the cubemaps in order to enable them.}}


===Team Fortress 2===
===Half-Life: Source===
[[Team Fortress 2]] does not have a default cubemap applied to reflective surfaces. Everything shiny will shine with a pink and black checkered texture. If you were to build cubemaps now and one of your cubemap is able to see a large shiny surface; the cubemap will register that in its 6 images. That means some objects might shine as if there was something shining next to it with the pink and black texture. To solve this, you need to build the cubemaps with specular turned off. To build cubemaps for your TF2 map, load it up via "Create Server". Then, go to the console and execute the following commands:
{{Note|Some materials/textures in HL:S will use reflections located on {{path|environment maps}} folder instead. So even if you already build cubemaps, it only displays in some materials that use {{code|[[$envmap]] env_cubemap}}.}}
{{bug|hidetested=1|Building cubemaps in older version of {{hls|4.1}} is currently not possible as their textures, despite being generated, aren't embedded into the map file afterward.</br>
This is fixed with Half-Life 2's 20th Anniversary update, which also applies to HL:S. Issue is not affected on {{hldms|1}}.
{{workaround|Move the map file into the {{path|maps}} folder of a game in the same engine branch (such as {{hl2|4.1}}), build its cubemaps in that game, then move the file back into '''Half-Life: Source'''<nowiki>'</nowiki>s folder.}}}}


Building Cubemaps for LDR '''or''' HDR only:
=== Half-Life 2 ===
mat_specular 0
; All versions
buildcubemaps
{{bug|hidetested=1|NPCs such as [[npc_combine_camera]] and [[npc_turret_ceiling]], while completely invisible when building cubemaps, will have it's sprite lights baked into cubemaps.
mat_specular 1
{{Workaround|Enable {{code|sv_cheats 1}} then remove the NPCs above using {{code|ent_remove_all npc_combine_camera;ent_remove_all npc_turret_ceiling}} command before running {{code|buildcubemaps}}.}}
disconnect
}}
sv_cheats 1
{{bug|hidetested=1|Similar to above, if the [[player]] equips [[weapon_physcannon|Gravity Gun]], then building cubemaps, it's sprite lights also get's baked into cubemaps.
mat_reloadallmaterials
{{Workaround|Simply switch to other weapons, or use {{code|[[give]]}} console command to give player another weapon. Example: {{code|give [[weapon_crowbar]]}}, {{code|give [[weapon_cubemap]]}}, etc...}}
sv_cheats 0
}}
; 20th Anniversary only
{{bug|hidetested=1|Building cubemaps in {{hl2|4.1}}, {{hl2ep1|4.1}} and {{hl2ep2|4.1}}, after the 20th Anniversary update, might fail. In Half-Life 2's case, the game may access the wrong directory (example: {{code|episodic/maps}}), instead of {{code|hl2/maps}}, preventing the cubemaps from embedded into the map file.


Building cubemaps for HDR requires you to repeat these steps after loading your map while HDR is enabled.
You may also see this error message generated on the console:
{{code|vtex failed to compile cubemap! Unable to remove \steamapps\common\half-life 2\episodic\materials\maps\<map name>\<cubemap location>.vtf}}


{{note|If the game crashes when you try to build cubemaps, this probably means your game resolution is set too low. Before you try to build cubemaps you must ensure your game width and height are over 512 pixels. This means that the minimal standard resolution to build is 800X600. The video resolution can be changed from the Video tab, found under the game Options menu.}}
{{Workaround|Launch Half-Life 2 with {{code|-game hl2}} [[command line argument]] (or go to {{code|steamapps\common\Half-Life 2}} and run {{code|hl2.exe}} directly). For Episodes, launch the game through Steam > Tools (or using {{code|-game episodic}} or {{code|-game ep2}}).}}
}}


{{note|If the map bsp file is renamed after the cubemaps have been built the cubemaps will no longer work and default to the sky cubemap. You must rebuild cubemaps again each time a map is renamed. However, the no-longer-working cubemaps are not removed, so this can lead to bloated files. If you plan to release a map so that others can download it, it is best to try to avoid any map-renaming after you compile it, to avoid problems.}}
=== Left 4 Dead / Left 4 Dead 2 ===
{{l4d|4}} and {{l4d2|4}} restrict certain console commands, such as {{code|mat_specular}} and {{code|building_cubemaps}}. While it seems to be optional, the latter command is recommended to make HDR cubemap have consistent exposure.


{{note|For multiplayer maps in some games, you may need to enable cheats (<code>sv_cheats 1</code>) before running the <code>buildcubemaps</code> command.}}
;For {{l4d|2}}, you must use {{code|SourceMod}} in order to use these commands (since VScript wasn't introduced until L4D2):
:{{code|sm_cvar mat_specular 0}}
:{{code|sm_cvar building_cubemaps 1}}


===Portal 2===
;For {{l4d2|2}}, you can either use SourceMod or run these [[VScript]] command:
:{{code|script Convars.SetValue("mat_specular", "0")}}
:{{code|script Convars.SetValue("building_cubemaps", "1")}}


{{bug|Building cubemaps in Portal 2 will crash the game if the map you are running is in the default ''common/portal 2/portal2/maps'' folder. This crash happens when the map is being reloaded, after the cubemaps have been saved to the file. To prevent the crash, set the 'Place compiled maps' option in the [[Hammer_Build_Programs|Build Programs]] tab of Hammer options to 'common/portal 2/portal2_dlc2/maps'', then recompile the map before compiling the cubemaps.}}
Additionally, unlike {{css|1}} or other Source branches, {{code|mat_reloadallmaterials}} does not reload the cubemap texture, so after you built the cubemap, you will need to restart the game, or alternatively, while in fullscreen mode, {{key|Alt}} + {{key|Tab}} to desktop then back to the game (while the map is already loaded) will reload the cubemap texture in-game.


=== Cubemaps and HDR ===
===Portal 2===
{{bug|hidetested=1|Building cubemaps in {{portal2|4.1}} will fail (and may crash the game) if the map file is not in the highest-numbered DLC folder ({{path|dlc2}} by default, mods installed will be {{path|dlc3}} or higher).


If the map has been compiled with the [[HDR|HDR]] lighting option enabled in [[Vrad|VRAD]], cubemaps '''must''' be built in both HDR '''and''' LDR (non-HDR) modes. Building cubemaps in only one mode will mean that cubemaps will not be present the other mode. For information on how to build cubemaps under HDR, see [[HDR Lighting Basics]].
{{Note|Does not affect [[sourcemods]].}}


Cubemaps should be built for LDR and HDR maps. Presuming you are already in HDR mode and have your map loaded fresh from compilation (VRAD must have the '<code>-both</code>' parameter enabled). Go to the console and execute the following commands:
{{workaround|Move the map to that folder before building cubemaps and, if necessary, edit the "'''Place compiled maps in this directory before running the game'''" path in [[Hammer Build Programs|Hammer's Build Programs]] options so that the map is automatically generated there.}}|only=portal2}}


buildcubemaps
===Source Filmmaker===
mat_hdr_level 0 ''(to go to LDR)''
[[File:Cubemap_bug_sfm.jpg|thumb|right|300px|Improper rendering of an HDR cubemap's face in Source Filmmaker.]]
restart ''(to reload map)''
{{bug|hidetested=1|'''HDR''' cubemaps built in {{tf2|4.1}} and some other games usually display graphical artifacts on reflections due to the engine expecting 6 total cubemap faces instead of 7, combined with the issue that HDR sphere maps do not get generated correctly. While rebuilding cubemaps would normally fix the issue, they are not built correctly in float HDR mode ({{code|mat_hdr_level 3}}), which {{Sfm|4}} launches with by default (all faces end up looking the same as each other, even if there are multiple {{code|env_cubemap}} entities).
buildcubemaps
{{workaround|Launch {{sfm|4}} with {{code|+mat_hdr_level 2}}, which will use integer HDR mode. This cannot be changed without restarting (check {{code|sfm_diagnostics}} and/or {{code|mat_info}} for its value).}}}}
mat_hdr_level 2 ''(to go back to HDR)''
restart ''(to reload map)''
This does not apply to CS:GO as HDR cannot be turned off.


== Testing ==
=== Source 2013 MP / Team Fortress 2 ===
Cubemaps are best tested by using the <code>[[impulse]] 81</code> console command. This replaces the current weapon model with the "[[weapon_cubemap|cubemap weapon]]"; a set of spheres, each with different reflective surfaces. By moving around the level it is possible to see what cubemap is being applied at that position in space at any given time, as well as if that cubemap accurately describes the area’s lighting and color. This is the best way to assess the validity of your cubemaps.
{{warning| Building cubemaps on a [[BSPZIP#Compression|compressed .bsp]] (in {{src13mp|1}} and {{tf2branch|1}} games) will crash the game!}}
{{Note|For {{tf2branch|4}} games, [[#Deleting cubemaps|deleting cubemaps]], and using {{code|sv_cheats}} to build cubemaps are no longer required. However if you are mapping on {{src13mp|1}} games (including previous version of Valve games running on {{src13mp|1}} branch), you will need to delete cubemaps and enable cheats to build cubemaps.}}


For some reason, Team Fortress 2 does not have the "[[weapon_cubemap|cubemap weapon]]". The Sniper's primary weapon, however, has a slightly reflective lens on the scope and the Demoman's Bottle, and thus will reflect the cubemap.
== Improve reflections by rebuilding cubemaps ==
This step is optional but after building cubemaps once and enable reflections ({{code|mat_specular 1}}), you can build cubemaps again to improve reflections. The improvement it makes is only noticeable if the {{code|env_cubemap}} size was increased to higher resolutions and/or there are two reflective surfaces near each other.


The [[weapon_cubemap|cubemap weapon]] can be copied from ''Steam\SteamApps\common\Half-Life 2\hl2\models\shadertest\envballs.mdl'' to a desired mod which doesn't have it.
To improve reflections, run the following commands:
{| class="wikitable"
|-
! Command !! Description
|-
| colspan = 2 | <center>Follow the same instructions as '''[[#LDR|LDR]]''', '''[[#LDR + HDR|LDR + HDR]]''' or '''[[#HDR|HDR]]''', up until the {{code|building_cubemaps}} and {{code|buildcubemaps}} command. Make sure {{code|mat_specular}} is set to "0" first.</center>
|-
| {{Command|building_cubemaps (console command)|alt=building_cubemaps|1}} || Sets HDR exposure to a consistent value, which will make sure that one cubemap won't look brighter or darker than others. This will automatically reset back to 0 after cubemaps are built.{{note|Only use this command if the map is loaded in HDR}}{{Note|This command is flagged as "launcher"-only in {{l4d|1}} and {{l4d2|1}}, you can use the following command instead: </br>{{L4d}} {{code|sm_cvar building_cubemaps 1)}} command (with [[SourceMod]] installed) or </br>{{L4d2}} {{code|script Convars.SetValue("building_cubemaps", "1")}} (using [[VScript]]).}}
|-
| {{Command|buildcubemaps}} || Begins building cubemaps.{{note|Running {{code|buildcubemaps}} with multiple iterations (e.g. {{code|buildcubemaps 2-4}} or etc..), does not appear to actually improve reflections, it only repeats the buildcubemaps process. To actually improve reflections, you have to disconnect and reload the map before building cubemaps again, this will make sure the map would display the newly built cubemaps.}}
|-
| {{Command|disconnect}} || Unloads the map and returns to the main menu</br>Skip both {{code|disconnect}} and {{code|map}} if the game (usually singleplayer like {{hl2}}) reloads map automatically.
|-
| {{Command|map}} ''map_name'' || Loads the map again
|-
| {{Command|mat_specular|1}} || Turns reflections on.
|-
| {{Command|building_cubemaps_(console_command)|alt=building_cubemaps|1}} || Sets HDR exposure to a consistent value again. This will automatically reset back to 0 after cubemaps are built.{{note|Only use this command if the map is loaded in HDR}}{{Note|This command is flagged as "launcher"-only in {{l4d|1}} and {{l4d2|1}}, you can use the following command instead: </br>{{L4d}} {{code|sm_cvar building_cubemaps 1)}} command (with [[SourceMod]] installed) or </br>{{L4d2}} {{code|script Convars.SetValue("building_cubemaps", "1")}} (using [[VScript]]).}}
|-
| {{Command|buildcubemaps}} || Building cubemaps the second time.
|-
| {{Command|disconnect}} || Once you are done, unloads the map.<br>Alternatively, you can switch to LDR or HDR mode using {{code|mat_hdr_level 0/2}}, then repeat the steps starting from the first {{code|buildcubemaps}} command. You can also optionally repeat the process again multiple times to further improve reflections, but 2 iterations should be enough.
|-
| {{Command|map}} ''map_name'' || Loads the map again, it should display the new cubemap textures after doing these steps.
|-
| {{Command|mat_reloadallmaterials}}</br>or {{Key|Alt + Tab}} / Restart game || In some games, such as {{css|1}}, if it doesn't display new cubemap textures after loading the map, run this command to display the newly-built cubemaps. This command may run automatically when you load up the map while cheats is already enabled. In {{l4d|1}} (or some Source games), this command may not reload cubemaps in-game, so instead {{key|Alt}} + {{Key|Tab}} while in fullscreen or simply restart the game can sometime reload the texture (and display the new cubemap) aswell.
{{Note|{{Key|Alt + Tab}} only works properly in {{src09|1}} or earlier, and {{l4dbranch|1}} or later. {{src13|1}} or {{csgobranch|1}} games use Direct3D 9Ex, which meant that running those games on Windows 10/11, without setting multiple displays to "Duplicate" or disable fullscreen optimization, it will not reload anything at all when you {{key|Alt + Tab}}.}}
|-
|}


{{note|If you run a recompiled copy of the same map without restarting the game, the cubemaps from the previous version will still be cached, making it appear as if cubemaps do not need to be rebuilt. These cubemaps are ''not'' in the map, however, as running the map again on another computer or after restarting the game will reveal. Every new compile wipes out all packed content, including cubemaps.}}
<div style=width:100%;overflow:auto>
{| border="0" cellpadding="4"
|[[File:Buildcubemaps - 1st iterations.jpg|thumb|center|1st iteration]]
|[[File:Buildcubemaps - 2nd iterations.jpg|thumb|center|2nd iteration]]
|[[File:Buildcubemaps - 8th iterations.jpg|thumb|center|4-8th iteration]]
|}
</div>


== Performance ==
==Deleting cubemaps==
The <code>[[env_cubemap|env_cubemap]]</code> entity allows the user to define how large the target cubemap’s texture resolution is. While a larger texture resolution will provide more accurate and “sharp” results when sampled, it also incurs a cost in texture memory. Most cubemaps should only use the default setting in the <code>[[env_cubemap|env_cubemap]]</code> entity for their texture resolution (32x32 pixels for each surface). This is generally acceptable in normal conditions. Some exceptions may be necessary for areas of high reflectivity or detail, such as set-pieces for acting.
Several tools make it possible to delete unnecessary or outdated cubemaps; [[BSPZIP]] is one official, command-line tool which is usually the preferred option for this procedure, allowing for an usage unlikely of corrupting the map file due to misuse. To delete cubemaps, execute the following command within the {{path|maps}} folder:
..\..\bin\bspzip -deletecubemaps map_name.bsp
{{note|Replace "''map_name''" with the map's actual name.}}
{{Note|Once you delete the cubemaps, building cubemaps again will require {{code|mat_specular 0}} prior to loading the map, otherwise {{code|buildcubemaps}} will need to be run twice, since it has to generate blank textures first to avoid missing texture/generic textures on reflective surfaces being baked into cubemaps. {{code|mat_specular 0}} will prevent that from happen, so you just simply run {{code|buildcubemaps}} once.
Deleting cubemaps will also display the message {{code|Failed, using default cubemap 'maps/map-name/cubemapdefault'}} once you load the map with deleted cubemaps.
}}
{{Note|If you are making maps for HDR-only games (such as {{l4d|1}} or games on later branches after {{l4dbranch|1}}), deleting unused blank LDR cubemaps is optional but recommended to reduce BSP file sizes.}}
{{Important|It is not required to delete cubemaps on {{tf2branch|1}} games ({{css}}, {{dods}}, {{hl2dm}}, {{hldms}} and {{tf2}}), aswell as {{hl2|1}}, {{hls|1}} and {{portal|1}} (all of which, runs on more up to date version of {{src13sp|1}} from 2025), since cubemaps are now properly written to the BSP. But if you still encounter the problem, try to delete cubemaps.
</br>Deleting cubemaps is only required on {{src13sp|1}} (including {{srcsdk13sp|1}}, which hasn't been updated since 2014, and mods built on it) and {{src13mp|1}} (including legacy version of {{srcsdk13mp|1}}), {{src09|1}}/{{srcmp|1}} or earlier.}}
{{warning|Deleting cubemaps actually deletes all the texture ("[[Valve Texture Format|.vtf]]") files currently embedded into the map, so it's recommended not to embed custom textures before deleting cubemaps.}}


Because surfaces must approximate their surroundings via cubemaps, using too many cubemaps in a small area can cause noticeable visual discontinuities when moving around. For areas of high reflectivity, it is generally more correct to place one cubemap in the center of the surface and no more. This avoids seams or popping as the view changes.
==Extracting cubemaps==
In cases where a map has to be recompiled with minor changes (and its built cubemaps vanish as a result), extracting them beforehand will make it not necessary to go through the whole cubemap-building process again. To extract cubemaps with '''BSPZIP''', create a folder that will contain the extracted cubemaps inside the {{path|maps}} one, then execute the following command:
..\..\bin\bspzip -extractcubemaps map_name.bsp "foldername"
{{note|Replace "''map_name''" with the map's actual name, and "''foldername''" with the actual name of the folder to extract cubemaps into.}}


To determine the cost of cubemaps in any one area, first look at the World Rendering category using the <code>[[showbudget|+showbudget]]</code> console command. If this category is registering an unusually high cost, it may be due to using too many cubemaps in an area. A simple solution to check for this scenario is to use Hammer to Hide all the cubemaps in the map, and then compile and run the map again. If the performance is noticeably better, cubemap density or resolution may need to be reduced.
===Embedding cubemaps===
Eventually this can also be checked by turning off cubemaps, by using <code>mat_specular 0</code> to disable it, however this needs confirmation.
For '''BSPZIP''' to make a map use extracted cubemaps, create a text file inside the {{path|maps}} folder. The file's content should look like this:
materials/maps/map_name/c-128_384_64.hdr.vtf
'''foldername\materials\maps\map_name\c-128_384_64.hdr.vtf'''
materials/maps/map_name/c-128_384_64.vtf
'''foldername\materials\maps\map_name\c-128_384_64.vtf'''
materials/maps/map_name/c448_-256_64.hdr.vtf
'''foldername\materials\maps\map_name\c448_-256_64.hdr.vtf'''
materials/maps/map_name/c448_-256_64.vtf
'''foldername\materials\maps\map_name\c448_-256_64.vtf'''
materials/maps/map_name/cubemapdefault.vtf
'''foldername\materials\maps\map_name\cubemapdefault.vtf'''
{{note|Replace "''map_name''" with the map's actual name, the cubemaps' filenames with correct ones, and "''foldername''" with the actual name of the folder that contains the extracted cubemaps.}}
A file requires two dedicated lines (paths): the first line represents the path it will use within the map file, whereas the second one is the actual location of the file to embed into the map file. Relative location paths were used for the example, but they can also be Absolute. Once the text file is ready, execute the following command:
..\..\bin\bspzip -addlist map_name.bsp textfile.txt newmap_name.bsp
{{note|Replace "''map_name''" with the map's actual name, "''textfile''" with the text file's actual name, and "''newmap_name''" with either the map's actual name, or a new name not to overwrite the original file (and instead create a separate one).}}


== See Also ==
==Renaming a map==
Renaming the map .bsp file breaks cubemaps on non-world geometry (models, props, weapons etc.). When map is being loaded the Source engine loads the Pakfile (containing, amongst others, cubemap textures and patch materials) embedded in the map. To display cubemaps on said geometry the engine searches ''materials/<MAP BSP FILENAME>'' directory but if such directory is not found, due to the BSP file being renamed, the cubemaps are not displayed.
Cubemaps on world geometry however are not affected, as the internal BSP data still points to a valid materials inside the Pakfile (see [[BSP (Source)#TexdataStringData and TexdataStringTable|TexdataStringData and TexdataStringTable]]).
<br>
{{Bspentspy|2}} allows for renaming the internal map structure and data to fix the issues with Cubemaps


==See also==
* [[env_cubemap]]
* [[$envmap]]
* [[$envmap]]
* [[parallax_obb]] - For Parallax Corrected Cubemaps.


[[Category:Cubemaps]]
[[Category:Level Design]]
[[Category:Level Design]]

Latest revision as of 08:47, 30 August 2025

English (en)Español (es)Français (fr)Português do Brasil (pt-br)Русский (ru)中文 (zh)Translate (Translate)
Warning.pngWarning:
  • EPILEPSY WARNING: Building cubemaps on a faster systems (with high single-thread performance) will causes the top left of the screen (which display captured cubemap images) to flicker much faster.
    It will also flicker white when building HDR cubemaps
Env cubemap.png
An example of specular reflections on some models (exaggerated through r_showenvcubemap).

A cubemap is a texture that represents a three-dimensional rendering of an area. Source Source uses env_cubemap entities as sampling points to generate these textures, which are then integrated into the map file. Cubemaps, when built, are reflected on materials that use the $envmap parameter (surfaces such as reflective glass, tiles, water, etc.) A map without built or existing env_cubemap entities will instead use other kinds of "reflections" (such as default cubemap texture, see below) that don't properly depict it, appear broken (missing textures, reflections appear bright, etc...), or simply doesn't show any reflections (if the cubemap texture is black).


Building cubemaps

This default cubemap texture will appear if you skip building blank cubemaps during VBSP process.

Building cubemaps is the process of generating textures to use as reflections. For technical reasons, this process isn't automated (Except in Mapbase) and is up to the user to do so; until then, existing env_cubemap entities will remain unused and the map, depending on the game, will display either:

  • A blank (black) texture (which basically make it look the same as mat_specular 0 / disabled reflections)
    • During compilation, VBSP will generate blank cubemap textures.
    • If you skip VBSP's blank cubemap generation (either by using Mapbase's VBSP without adding -autocubemap, using Slammin' Source Map Tools VBSP with -nodefaultcubemap, or if you deleted the cubemaps, it will display the missing or generic environment texture instead, and building cubemaps for the first time (without disabling mat_specular) will instead generate blank textures (or partially generate the cubemaps, with some of them being blank), until building it again second time, so don't forget to disable it. mat_specular must be also disabled prior to loading the map, otherwise disabling them after the map have been loaded, will cause buildcubemaps to generate blank textures aswell.
  • Default cubemap texture (see image on right)
    • If the cubemap is missing, the game first tries to fall back to LDR cubemaps (and fails), so the game ended up using this texture instead, showing the empty desert with sunset sky as reflections.
  • Cubemaps causing models appear bright or glowing (HDR only, if LDR cubemaps is only present)
    • If HDR version of the cubemap isn't present, the game will fall back to LDR version, which will cause it to appear bright and glowing on HDR.
  • Missing textures as reflections
    • If the cubemap is missing and the game fails to use the default cubemap texture for some reasons, missing texture will show up as reflections.
    • This also appears if you recompiled the map and overwrite the original which have cubemaps texture baked in, then Alt + Tab back to the game (which sometime reloads the textures).

Before building

Broom icon.png
This article or section needs to be cleaned up to conform to a higher standard of quality because:
Modern Source games, namely Portal 2 and P2:CE, do not need all these complicated params and steps, at least in my experience -Equalizer (talk) 10:56, 22 March 2024 (PDT)

Also some Source games (such as CS:S and HL2), doesn't appear to require cheats to be enabled to build cubemaps. Deleting cubemaps is probably not needed (atleast for SP games), since this would require you to use mat_specular 0, otherwise buildcubemaps will instead generate blank texture until you run the command again.
Edit 2: Counter-Strike: Source Counter-Strike: Source builds cubemap correctly now without deleting cubemaps after engine update (Team Fortress 2 branch), so some steps can be skipped. -leonidakarlach (talk) 02:50, 25 August 2024 (PDT) - Edited 24 Feb 2025.

Left 4 Dead 2 Left 4 Dead 2 also does not require anything, other than maybe turning shader quality to medium. But it's not always required. Just loading the map and running Buildcubemaps is often enough. --MrFunreal (talk) 02:23, 11 February 2025 (PST)
For help, see the VDC Editing Help and Wikipedia cleanup process. Also, remember to check for any notes left by the tagger at this article's talk page.
Icon-Important.pngImportant:Maps for Source 2013 Source 2013 games (including Team Fortress 2 branch Team Fortress 2 branch) and others, such as Counter-Strike: Source Counter-Strike: Source, are known to include pre-built, blank cubemaps after being compiled (even if there are no env_cubemap entities in them). In Mapbase Mapbase, blank cubemaps are not automatically generated by default.
For Source 2013 Singleplayer Source 2013 Singleplayer and Source 2013 Multiplayer Source 2013 Multiplayer titles (including previous version of Valve games), deleting cubemaps will be required (in order to make sure cubemaps are properly written to the BSP).
Tip.pngTip:Deleting pre-built blank cubemaps, while not required, is recommended for Left 4 Dead engine branch Left 4 Dead engine branch games or later (and HDR-only games) since VBSP generates blank LDR cubemap textures that increase BSP file size while being unused anyway in those games.
Note.pngNote:Deleting pre-built blank cubemaps isn't required for Half-Life 2, Portal nor the Team Fortress 2 branch Team Fortress 2 branch games (Counter-Strike: Source, Day of Defeat: Source, Half-Life Deathmatch: Source, Half-Life Deathmatch: Source and Team Fortress 2), since the updated version of those games (as of 2025) now have built and written generated cubemaps to the .BSP correctly. Deleting blank cubemaps is also not required on Source SDK Base 2013 - Multiplayer (also on TF2 branch), but required for Source SDK Base 2013 - Singleplayer, and the legacy version of Source SDK Base 2013 - Multiplayer.
Icon-Important.pngImportant:
  • To build cubemaps, your game's screen resolution needs to be at least 4 times higher than the highest size of an existing env_cubemap, or else attempting to build them will either fail or even cause the game to crash.
    For example, if the highest env_cubemap sizes 128x128, a resolution no lower than 512x512 will be required. (128 × 4 = 512 -> 720x576 (as a valid resolution) or higher)
  • Disable any anti-aliasing method (SGSSAA for example) forced through GPU driver and enable the in-game AA or use FXAA instead (or simply run the game in Vulkan which will disable all forced AA) to avoid cubemaps being slowly built. This also applies to running the game at higher resolutions (such as 4K), which will cause cubemaps to be slowly built on weaker hardware. Running the game at lower resolutions (like 1080p) and/or disable AA (other than in-game AA), and disable any FPS cap, will significantly speed up building cubemaps progress.
Warning.pngWarning:
  • EPILEPSY WARNING: Building cubemaps on a faster systems (with high single-thread performance) will causes the top left of the screen (which display captured cubemap images) to flicker much faster. Look away from the screen while the cubemaps are being built.
    • Additionally, the screen will also flashes white when building HDR cubemaps.
    • This mostly doesn't applies to games on Source 2006 or earlier, since these branches doesn't support multi-core and building cubemaps will take little bit longer on these branches.
  • If the nav_show_ladder_bounds command was used before building cubemaps, the green boxes will also be baked into the cubemap. The same goes for r_screenoverlay, and most screen space effects.
  • While taking damage, building cubemaps when the screen is tinted red/white will cause the red/white tints baked into the cubemap.
  • Maps that contains env_credits, like the Half-Life 2 introduction scene seen in d1_trainstation_01 on "Point Insertion" and the HL2 Credits, you must wait for the credits/introduction to end, otherwise building cubemaps will lead to generating blank (black) textures. Use host_timescale console command and temporarily set to high value (like 99) to speed up the introduction scene/end credits, then set host_timescale to 1 and follow the build cubemaps instructions below.
  • The game may appear to freeze or become unresponsive during the process of building cubemaps, and the amount of time depends on various factors (amount of env_cubemap(s), cubemap sizes, CPU usage/utilization and framerate). For successful results, don't switch away from the game until it's done.
    If you have the game running on windowed/borderless windowed mode, clicking on the game while building cubemaps will cause the windows to freeze with "Not Responding" on the titlebar (even through the game is still building cubemaps). To avoid this, it's highly recommended that you run the game in (exclusively) fullscreen mode.
    For users using Vulkan instead of Direct3D 9 (Windows only): Clicking on the game while building cubemaps, even in fullscreen, will also cause the game to permanently freeze.
  • If you are building cubemaps for Half-Life 2 Half-Life 2 (except episodes) after the 20th Anniversary Update, you must follow the instructions here. Also building cubemaps in Half-Life 2 without removing some NPCs (or switching to a non-Gravity Gun weapon) will cause sprites' light from them to be baked into cubemaps.
Tip.pngTip:
  • env_cubemap entities allow for generating higher- or lower-quality reflections, though the game's texture quality also comes into play; consider maxing out your game's visual settings (set texture, models, shaders, shadow details to High/Very High) before building cubemaps. Higher anti-aliasing settings also makes minor differences (not easily noticable).
  • Running the game at lower resolution (while making sure your screen resolutions are 4 times larger) and disabling FPS cap (both in game, graphics driver and software like RTSS) can speed up building cubemaps progress.
  • Bind mat_hdr_level 0, mat_hdr_level 2, building_cubemaps 1 to any numpad keys, and buildcubemaps to numpad Enter key, so you don't have to manually type and submit most of these command on console.
  • If you are using Mapbase Mapbase, you can add -autocubemap to launch the game ($game_exe) command line in Hammer. The game will automatically build cubemaps.
  • Slammin' Source Map Tools Slammin' VBSP VBSP features the -nodefaultcubemap command, which skips automatically generating skybox cubemaps on map compile.

LDR

Note.pngNote:This step doesn't apply to Left 4 Dead Left 4 Dead nor Counter-Strike: Global Offensive Counter-Strike: Global Offensive as their maps are compiled in HDR mode only. While Portal 2 Portal 2 does support LDR, the game uses HDR by default, so we recommend building cubemaps in HDR only.
Note.pngNote:Cheats do not have to be enabled to build cubemaps in: Half-Life: Source, Half-Life 2, Half-Life 2: Deathmatch (all three since Half-Life 2 20th Anniversary Update), Portal (since May 20, 2025) nor the Team Fortress 2 branch games.

Building cubemaps in a map compiled in LDR (Low Dynamic Range) mode will generate textures only for that mode, regardless of your game's High Dynamic Range video setting. To build the cubemaps, submit the following commands into the game's console:

Command Description
mat_specular 0 Turns reflections off, which is necessary if using only one iteration of buildcubemaps, and if all cubemaps has been deleted.
It also meant that disabling reflections would avoid some case where missing textures or default cubemap texture (materials/engine/defaultcubemap.vtf, aka a desert with orange sunset sky), might end up reflected on the cubemap itself.
Note.pngNote:If you let VBSP generate blank cubemaps and you build the cubemaps without this command, it will build (and written cubemaps to BSP) just fine (atleast in Half-Life 2), however, if you deleted the cubemaps and run buildcubemaps, without disable mat_specular, it will instead generate and write blank textures, until you run buildcubemaps a second time. mat_specular must be also disabled prior to loading the map, otherwise disabling them after the map have been loaded, will cause buildcubemaps to generate blank textures aswell.
map map_name Loads the map; replace "map_name" with the map's actual name
sv_cheats 1 Enables the use of cheat commands; required to build cubemaps
Note.pngNote:Half-Life 2, Half-Life 2: Deathmatch (since 20th Anniversary), Portal (since May 20, 2025 update) and all Team Fortress 2 branch games (Counter-Strike: Source, Day of Defeat: Source, Half-Life 2: Deathmatch, Half-Life Deathmatch: Source and Team Fortress 2), doesn't require cheats to build cubemaps, so this step can be skipped. In many Source 2013 (SP/MP) games, including previous version of Counter-Strike: Source, buildcubemaps can also be built without having to enable cheats, however, mat_reloadallmaterials (command that requires sv_cheats 1) must be run once in order to display the newly-built cubemaps, since cubemap textures may not be automatically loaded when you load up the map manually. Confirm if other games also require cheats to build cubemaps.
buildcubemaps Begins building cubemaps. Optionally, specify the number of iterations (e.g.: buildcubemaps 2 (default is 1))
disconnect Unloads the map and returns to the main menu
mat_specular 1 Turns reflections on, then follow the step below, or optionally you can repeat the process again by following instructions on Improve reflections by rebuilding cubemaps.
map map_name Loads the map again, your cubemaps should display after doing these steps.
mat_reloadallmaterials
(requires sv_cheats 1)
In some games or branch (Source 2013), if it doesn't display new cubemap textures after loading the map, run this command to display the newly-built cubemaps. This command may run automatically when you load up the map while cheats is already enabled. This command is usually not required on Half-Life 2 (since 20th Anniversary update), Portal (since May 2025 update) nor the Team Fortress 2 branch games, since cubemaps should be automatically reloaded when you load the map.

LDR + HDR

Building cubemaps in Source 2006 - Source 2013 game, with a map compiled with HDR support needs to be performed twice - once for each mode (HDR and LDR). As opposed to an LDR map's case, your game's High Dynamic Range video setting has to be set to "Full" to build HDR cubemaps, and to "None" to build LDR ones (or using the mat_hdr_level command. To build the cubemaps for both LDR + HDR, submit the following commands into the game's console:

Note.pngNote:Maps built on Left 4 Dead, or later (and some third-party Source games), does not requires building cubemaps on LDR. See #HDR
Note.pngNote:Cheats are not required to be enable to build cubemaps in: Half-Life 2, Half-Life 2: Deathmatch (since 20th Anniversary) and all Team Fortress 2 branch games.
Command Description
mat_specular 0 Turns reflections off, which is necessary if using only one iteration of buildcubemaps, and if all cubemaps has been deleted.
It also meant that disabling reflections would avoid some case where missing textures or default cubemap texture (materials/engine/defaultcubemap.vtf, aka a desert with orange sunset sky), might end up reflected on the cubemap itself.
Note.pngNote:This command is flagged as "launcher"-only in Left 4 Dead and Left 4 Dead 2, you can use the following command instead:
Left 4 Dead sm_cvar mat_specular 0 command (with SourceMod installed) or
Left 4 Dead 2 script Convars.SetValue("mat_specular", "0") (using VScript).
Note.pngNote:If you let VBSP generate blank cubemaps and you build cubemaps without this command, it will build (and written cubemaps to BSP) just fine (atleast in Half-Life 2), however, if you deleted the cubemaps and run buildcubemaps, without disabling mat_specular, it will instead generate and write blank textures, until you run buildcubemaps a second time. mat_specular must be also disabled prior to loading the map, otherwise disabling them after the map have been loaded, will cause buildcubemaps to generate blank textures aswell.
map map_name Loads the map; replace "map_name" with the map's actual name
sv_cheats 1 Enables the use of cheat commands; required to build cubemaps
Note.pngNote:Half-Life 2, Half-Life 2: Deathmatch (since 20th Anniversary) and all Team Fortress 2 branch games (Counter-Strike: Source, Day of Defeat: Source, Half-Life 2: Deathmatch, Half-Life Deathmatch: Source and Team Fortress 2), doesn't require cheats to build cubemaps, so this step can be skipped. In many Source 2013 (SP/MP) games, including previous version of Counter-Strike: Source, buildcubemaps can be also built without enabling cheats, however, mat_reloadallmaterials (command that requires sv_cheats 1) must be run once in order to display the newly built-cubemaps, since cubemap textures may not be automatically loaded when you load up the map manually. Confirm if other games also require cheats to build cubemaps.
building_cubemaps 1 Sets HDR exposure to a consistent value, which will make sure that no cubemaps won't look brighter or darker than others. This will automatically reset back to 0 after cubemaps are built.
Note.pngNote:This command is flagged as "launcher"-only in Left 4 Dead and Left 4 Dead 2, you can use the following command instead:
Left 4 Dead sm_cvar building_cubemaps 1 command (with SourceMod installed) or
Left 4 Dead 2 script Convars.SetValue("building_cubemaps", "1") (using VScript).
buildcubemaps Begins building cubemaps. Optionally, specify the number of iterations (e.g.: buildcubemaps 2 (default is 1))
In singleplayer games, the map will be automatically reloaded after building cubemaps.
disconnect Unloads the map and returns to the main menu
sv_cheats 0 Disables cheat commands; prevents command mat_reloadallmaterials from unnecessarily self-executing (which briefly freezes the game)
mat_hdr_level 0 Switches to LDR mode (from HDR); submit mat_hdr_level 2 instead if LDR cubemaps were built first
map map_name Loads the map again to build cubemaps for the new mode
sv_cheats 1
buildcubemaps Begins building cubemaps for the new mode
disconnect
mat_specular 1 Turns reflections on, then follow the step below, or optionally you can repeat the process again by following instructions on Improve reflections by rebuilding cubemaps.
mat_hdr_level 0/1/2 If necessary, switches back to the mode it was before having submitted mat_hdr_level 0/2
map map_name Loads the map again, your cubemaps should display after doing these steps.
mat_reloadallmaterials
(requires sv_cheats 1)
or Alt + Tab / Restart game
In some games, such as Counter-Strike: Source, if it doesn't display new cubemap textures after loading the map, run this command to display the newly-built cubemaps. This command may run automatically when you load up the map while server cheats are already enabled.
If this command does not reload cubemaps in-game, you can instead try Alt + Tab 'ing while in fullscreen or simply restart the game; the latter method can sometimes reload the texture (and display the new cubemap) aswell.
Note.pngNote:Alt + Tab only works properly in Source 2009 or earlier, and Left 4 Dead engine branch or later. Source 2013 and CS:GO engine branch games use Direct3D 9Ex, which meant that running those games on Windows 10/11, without setting multiple displays to "Duplicate" or disable fullscreen optimization, it will not reload anything at all when you Alt + Tab.
Note.pngNote:Usually not required on Half-Life 2 nor the Team Fortress 2 branch games, since cubemaps should be automatically reloaded when you load the map.

HDR

This section is for games running on the Left 4 Dead engine branch Left 4 Dead engine branch and later, or engine branches that only support HDR (such as Xengine). To build cubemaps in HDR only, submit the following commands into the game's console:

Command Description
mat_specular 0 Turns reflections off, which is necessary if using only one iteration of buildcubemaps, and if all cubemaps have been deleted.
It also meant that disabling reflections would avoid some case where missing textures or default cubemap texture (materials/engine/defaultcubemap.vtf, aka a desert with orange sunset sky), might end up reflected on the cubemap itself.
Note.pngNote:This command is flagged as "launcher"-only in Left 4 Dead and Left 4 Dead 2, you can use the following command instead:
Left 4 Dead sm_cvar mat_specular 0 command (with SourceMod installed) or
Left 4 Dead 2 script Convars.SetValue("mat_specular", "0") (using VScript).
Note.pngNote:If you let VBSP generate blank cubemaps and you build cubemaps without this command, it will build (and written cubemaps to BSP) just fine (atleast in Half-Life 2), however, if you deleted the cubemaps and run buildcubemaps, without disabling mat_specular first, it will instead generate blank textures, until you run buildcubemaps a second time. mat_specular must be also disabled prior to loading the map, otherwise disabling them after the map have been loaded, will cause buildcubemaps to generate blank textures aswell.
map map_name Loads the map; replace "map_name" with the map's actual name
sv_cheats 1 Enables the use of cheat commands; required to build cubemaps
Note.pngNote:Half-Life 2, Half-Life 2: Deathmatch (since 20th Anniversary) and all Team Fortress 2 branch games (Counter-Strike: Source, Day of Defeat: Source, Half-Life 2: Deathmatch, Half-Life Deathmatch: Source and Team Fortress 2), do not require cheats to build cubemaps, so this step can be skipped. In many Source 2013 (SP/MP) games, including previous version of Counter-Strike: Source, buildcubemaps can be also built without enabling cheats, however, mat_reloadallmaterials (a command that requires sv_cheats 1) must be run once in order to display the newly built-cubemaps, since cubemap textures may not be automatically loaded when you load up the map manually. Confirm if other games also require cheats to build cubemaps.
building_cubemaps 1 Sets HDR exposure to a consistent value, which will make sure that one cubemap won't look brighter or darker than others. This will automatically reset back to 0 after cubemaps are built.
Note.pngNote:This command is flagged as "launcher"-only in Left 4 Dead and Left 4 Dead 2, you can use the following command instead:
Left 4 Dead sm_cvar building_cubemaps 1 command (with SourceMod installed) or
Left 4 Dead 2 script Convars.SetValue("building_cubemaps", "1") (using VScript).
buildcubemaps Begins building cubemaps. Optionally, specify the number of iterations (e.g.: buildcubemaps 2 (default is 1))
In singleplayer games, the map will be automatically reloaded after building cubemaps.
disconnect Unloads the map and returns to the main menu
mat_specular 1 Turns reflections on, then follow the step below, or optionally you can repeat the process again by following instructions on Improve reflections by rebuilding cubemaps.
map map_name Loads the map again, your cubemaps should display after doing these steps.
mat_reloadallmaterials
(requires sv_cheats 1)
or Alt + Tab / Restart game
In some games, such as Counter-Strike: Source, if it doesn't display new cubemap textures after loading the map, run this command to display the newly-built cubemaps. This command may run automatically when you load up the map while server cheats are already enabled. In Left 4 Dead (or some Source games), this command may not reload cubemaps in-game, so instead Alt + Tab 'ing while in fullscreen or simply restarting the game can sometimes reload the texture (and display the new cubemap) aswell.
Note.pngNote:Alt + Tab only works properly in Source 2009 or earlier, and Left 4 Dead engine branch or later. Source 2013 and CS:GO engine branch games use Direct3D 9Ex, which meant that running those games on Windows 10/11, without setting multiple displays to "Duplicate" or disable fullscreen optimization, it will not reload anything at all when you Alt + Tab.
Note.pngNote:Usually not required on Half-Life 2 or all Team Fortress 2 branch games, since cubemaps should be automatically reloaded when you load the map.

Building cubemaps in specific games

Black Mesa

To build cubemaps in Black Mesa Black Mesa maps, the game has to be launched with these parameters: -oldgameui -dev -console +r_4way_use_fast_normals 0
Then, load the map, follow the instructions on HDR section.

After building cubemaps, you can proceed to #Improve reflections by rebuilding cubemaps or simply quit the game, then launch the game again without the command-line argument.

Half-Life: Source

Note.pngNote:Some materials/textures in HL:S will use reflections located on 🖿environment maps folder instead. So even if you already build cubemaps, it only displays in some materials that use $envmap env_cubemap.
Icon-Bug.pngBug:Building cubemaps in older version of Half-Life: Source Half-Life: Source is currently not possible as their textures, despite being generated, aren't embedded into the map file afterward.

This is fixed with Half-Life 2's 20th Anniversary update, which also applies to HL:S. Issue is not affected on Half-Life Deathmatch: Source.

PlacementTip.pngWorkaround:Move the map file into the 🖿maps folder of a game in the same engine branch (such as Half-Life 2 Half-Life 2), build its cubemaps in that game, then move the file back into Half-Life: Source's folder.

Half-Life 2

All versions
Icon-Bug.pngBug:NPCs such as npc_combine_camera and npc_turret_ceiling, while completely invisible when building cubemaps, will have it's sprite lights baked into cubemaps.
PlacementTip.pngWorkaround:Enable sv_cheats 1 then remove the NPCs above using ent_remove_all npc_combine_camera;ent_remove_all npc_turret_ceiling command before running buildcubemaps.
Icon-Bug.pngBug:Similar to above, if the player equips Gravity Gun, then building cubemaps, it's sprite lights also get's baked into cubemaps.
PlacementTip.pngWorkaround:Simply switch to other weapons, or use give console command to give player another weapon. Example: give weapon_crowbar, give weapon_cubemap, etc...
20th Anniversary only
Icon-Bug.pngBug:Building cubemaps in Half-Life 2 Half-Life 2, Half-Life 2: Episode One Half-Life 2: Episode One and Half-Life 2: Episode Two Half-Life 2: Episode Two, after the 20th Anniversary update, might fail. In Half-Life 2's case, the game may access the wrong directory (example: episodic/maps), instead of hl2/maps, preventing the cubemaps from embedded into the map file.

You may also see this error message generated on the console: vtex failed to compile cubemap! Unable to remove \steamapps\common\half-life 2\episodic\materials\maps\<map name>\<cubemap location>.vtf

PlacementTip.pngWorkaround:Launch Half-Life 2 with -game hl2 command line argument (or go to steamapps\common\Half-Life 2 and run hl2.exe directly). For Episodes, launch the game through Steam > Tools (or using -game episodic or -game ep2).

Left 4 Dead / Left 4 Dead 2

Left 4 Dead Left 4 Dead and Left 4 Dead 2 Left 4 Dead 2 restrict certain console commands, such as mat_specular and building_cubemaps. While it seems to be optional, the latter command is recommended to make HDR cubemap have consistent exposure.

For Left 4 Dead Left 4 Dead, you must use SourceMod in order to use these commands (since VScript wasn't introduced until L4D2)
sm_cvar mat_specular 0
sm_cvar building_cubemaps 1
For Left 4 Dead 2 Left 4 Dead 2, you can either use SourceMod or run these VScript command
script Convars.SetValue("mat_specular", "0")
script Convars.SetValue("building_cubemaps", "1")

Additionally, unlike Counter-Strike: Source or other Source branches, mat_reloadallmaterials does not reload the cubemap texture, so after you built the cubemap, you will need to restart the game, or alternatively, while in fullscreen mode, Alt + Tab to desktop then back to the game (while the map is already loaded) will reload the cubemap texture in-game.

Portal 2

Icon-Bug.pngBug:Building cubemaps in Portal 2 Portal 2 will fail (and may crash the game) if the map file is not in the highest-numbered DLC folder (🖿dlc2 by default, mods installed will be 🖿dlc3 or higher).
Note.pngNote:Does not affect sourcemods.
PlacementTip.pngWorkaround:Move the map to that folder before building cubemaps and, if necessary, edit the "Place compiled maps in this directory before running the game" path in Hammer's Build Programs options so that the map is automatically generated there.

Source Filmmaker

Improper rendering of an HDR cubemap's face in Source Filmmaker.
Icon-Bug.pngBug:HDR cubemaps built in Team Fortress 2 Team Fortress 2 and some other games usually display graphical artifacts on reflections due to the engine expecting 6 total cubemap faces instead of 7, combined with the issue that HDR sphere maps do not get generated correctly. While rebuilding cubemaps would normally fix the issue, they are not built correctly in float HDR mode (mat_hdr_level 3), which Source Filmmaker Source Filmmaker launches with by default (all faces end up looking the same as each other, even if there are multiple env_cubemap entities).
PlacementTip.pngWorkaround:Launch Source Filmmaker Source Filmmaker with +mat_hdr_level 2, which will use integer HDR mode. This cannot be changed without restarting (check sfm_diagnostics and/or mat_info for its value).

Source 2013 MP / Team Fortress 2

Warning.pngWarning: Building cubemaps on a compressed .bsp (in Source 2013 Multiplayer and Team Fortress 2 branch games) will crash the game!
Note.pngNote:For Team Fortress 2 branch Team Fortress 2 branch games, deleting cubemaps, and using sv_cheats to build cubemaps are no longer required. However if you are mapping on Source 2013 Multiplayer games (including previous version of Valve games running on Source 2013 Multiplayer branch), you will need to delete cubemaps and enable cheats to build cubemaps.

Improve reflections by rebuilding cubemaps

This step is optional but after building cubemaps once and enable reflections (mat_specular 1), you can build cubemaps again to improve reflections. The improvement it makes is only noticeable if the env_cubemap size was increased to higher resolutions and/or there are two reflective surfaces near each other.

To improve reflections, run the following commands:

Command Description
Follow the same instructions as LDR, LDR + HDR or HDR, up until the building_cubemaps and buildcubemaps command. Make sure mat_specular is set to "0" first.
building_cubemaps 1 Sets HDR exposure to a consistent value, which will make sure that one cubemap won't look brighter or darker than others. This will automatically reset back to 0 after cubemaps are built.
Note.pngNote:Only use this command if the map is loaded in HDR
Note.pngNote:This command is flagged as "launcher"-only in Left 4 Dead and Left 4 Dead 2, you can use the following command instead:
Left 4 Dead sm_cvar building_cubemaps 1) command (with SourceMod installed) or
Left 4 Dead 2 script Convars.SetValue("building_cubemaps", "1") (using VScript).
buildcubemaps Begins building cubemaps.
Note.pngNote:Running buildcubemaps with multiple iterations (e.g. buildcubemaps 2-4 or etc..), does not appear to actually improve reflections, it only repeats the buildcubemaps process. To actually improve reflections, you have to disconnect and reload the map before building cubemaps again, this will make sure the map would display the newly built cubemaps.
disconnect Unloads the map and returns to the main menu
Skip both disconnect and map if the game (usually singleplayer like Half-Life 2) reloads map automatically.
map map_name Loads the map again
mat_specular 1 Turns reflections on.
building_cubemaps 1 Sets HDR exposure to a consistent value again. This will automatically reset back to 0 after cubemaps are built.
Note.pngNote:Only use this command if the map is loaded in HDR
Note.pngNote:This command is flagged as "launcher"-only in Left 4 Dead and Left 4 Dead 2, you can use the following command instead:
Left 4 Dead sm_cvar building_cubemaps 1) command (with SourceMod installed) or
Left 4 Dead 2 script Convars.SetValue("building_cubemaps", "1") (using VScript).
buildcubemaps Building cubemaps the second time.
disconnect Once you are done, unloads the map.
Alternatively, you can switch to LDR or HDR mode using mat_hdr_level 0/2, then repeat the steps starting from the first buildcubemaps command. You can also optionally repeat the process again multiple times to further improve reflections, but 2 iterations should be enough.
map map_name Loads the map again, it should display the new cubemap textures after doing these steps.
mat_reloadallmaterials
or Alt + Tab / Restart game
In some games, such as Counter-Strike: Source, if it doesn't display new cubemap textures after loading the map, run this command to display the newly-built cubemaps. This command may run automatically when you load up the map while cheats is already enabled. In Left 4 Dead (or some Source games), this command may not reload cubemaps in-game, so instead Alt + Tab while in fullscreen or simply restart the game can sometime reload the texture (and display the new cubemap) aswell.
Note.pngNote:Alt + Tab only works properly in Source 2009 or earlier, and Left 4 Dead engine branch or later. Source 2013 or CS:GO engine branch games use Direct3D 9Ex, which meant that running those games on Windows 10/11, without setting multiple displays to "Duplicate" or disable fullscreen optimization, it will not reload anything at all when you Alt + Tab.
1st iteration
2nd iteration
4-8th iteration

Deleting cubemaps

Several tools make it possible to delete unnecessary or outdated cubemaps; BSPZIP is one official, command-line tool which is usually the preferred option for this procedure, allowing for an usage unlikely of corrupting the map file due to misuse. To delete cubemaps, execute the following command within the 🖿maps folder:

..\..\bin\bspzip -deletecubemaps map_name.bsp
Note.pngNote:Replace "map_name" with the map's actual name.
Note.pngNote:Once you delete the cubemaps, building cubemaps again will require mat_specular 0 prior to loading the map, otherwise buildcubemaps will need to be run twice, since it has to generate blank textures first to avoid missing texture/generic textures on reflective surfaces being baked into cubemaps. mat_specular 0 will prevent that from happen, so you just simply run buildcubemaps once.

Deleting cubemaps will also display the message Failed, using default cubemap 'maps/map-name/cubemapdefault' once you load the map with deleted cubemaps.

Note.pngNote:If you are making maps for HDR-only games (such as Left 4 Dead or games on later branches after Left 4 Dead engine branch), deleting unused blank LDR cubemaps is optional but recommended to reduce BSP file sizes.
Icon-Important.pngImportant:It is not required to delete cubemaps on Team Fortress 2 branch games (Counter-Strike: Source, Day of Defeat: Source, Half-Life 2: Deathmatch, Half-Life Deathmatch: Source and Team Fortress 2), aswell as Half-Life 2, Half-Life: Source and Portal (all of which, runs on more up to date version of Source 2013 Singleplayer from 2025), since cubemaps are now properly written to the BSP. But if you still encounter the problem, try to delete cubemaps.
Deleting cubemaps is only required on Source 2013 Singleplayer (including Source SDK Base 2013 - Singleplayer, which hasn't been updated since 2014, and mods built on it) and Source 2013 Multiplayer (including legacy version of Source SDK Base 2013 - Multiplayer), Source 2009/Source Multiplayer or earlier.
Warning.pngWarning:Deleting cubemaps actually deletes all the texture (".vtf") files currently embedded into the map, so it's recommended not to embed custom textures before deleting cubemaps.

Extracting cubemaps

In cases where a map has to be recompiled with minor changes (and its built cubemaps vanish as a result), extracting them beforehand will make it not necessary to go through the whole cubemap-building process again. To extract cubemaps with BSPZIP, create a folder that will contain the extracted cubemaps inside the 🖿maps one, then execute the following command:

..\..\bin\bspzip -extractcubemaps map_name.bsp "foldername"
Note.pngNote:Replace "map_name" with the map's actual name, and "foldername" with the actual name of the folder to extract cubemaps into.

Embedding cubemaps

For BSPZIP to make a map use extracted cubemaps, create a text file inside the 🖿maps folder. The file's content should look like this:

materials/maps/map_name/c-128_384_64.hdr.vtf
foldername\materials\maps\map_name\c-128_384_64.hdr.vtf
materials/maps/map_name/c-128_384_64.vtf
foldername\materials\maps\map_name\c-128_384_64.vtf
materials/maps/map_name/c448_-256_64.hdr.vtf
foldername\materials\maps\map_name\c448_-256_64.hdr.vtf
materials/maps/map_name/c448_-256_64.vtf
foldername\materials\maps\map_name\c448_-256_64.vtf
materials/maps/map_name/cubemapdefault.vtf
foldername\materials\maps\map_name\cubemapdefault.vtf
Note.pngNote:Replace "map_name" with the map's actual name, the cubemaps' filenames with correct ones, and "foldername" with the actual name of the folder that contains the extracted cubemaps.

A file requires two dedicated lines (paths): the first line represents the path it will use within the map file, whereas the second one is the actual location of the file to embed into the map file. Relative location paths were used for the example, but they can also be Absolute. Once the text file is ready, execute the following command:

..\..\bin\bspzip -addlist map_name.bsp textfile.txt newmap_name.bsp
Note.pngNote:Replace "map_name" with the map's actual name, "textfile" with the text file's actual name, and "newmap_name" with either the map's actual name, or a new name not to overwrite the original file (and instead create a separate one).

Renaming a map

Renaming the map .bsp file breaks cubemaps on non-world geometry (models, props, weapons etc.). When map is being loaded the Source engine loads the Pakfile (containing, amongst others, cubemap textures and patch materials) embedded in the map. To display cubemaps on said geometry the engine searches materials/<MAP BSP FILENAME> directory but if such directory is not found, due to the BSP file being renamed, the cubemaps are not displayed. Cubemaps on world geometry however are not affected, as the internal BSP data still points to a valid materials inside the Pakfile (see TexdataStringData and TexdataStringTable).
BSPEntSpy BSPEntSpy allows for renaming the internal map structure and data to fix the issues with Cubemaps

See also