$envmap: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(Added mat_specular console command, changed console commands to use IO templates)
(Expanded on $noenvmapmip, $envmaplightscale and $envmaplightscaleminmax based on dumped strings)
Line 81: Line 81:
:*<code>95</code> (DirectX 9 with Shader Model 3)}}
:*<code>95</code> (DirectX 9 with Shader Model 3)}}
{{MatParam|$envmapsphere|bool|Determines whether the material's envmap should be a spheremap (deprecated) instead of a cubemap. Set this to 1 to use a spheremap. Non-functional beyond {{As}}.|deprecated=1}}
{{MatParam|$envmapsphere|bool|Determines whether the material's envmap should be a spheremap (deprecated) instead of a cubemap. Set this to 1 to use a spheremap. Non-functional beyond {{As}}.|deprecated=1}}
{{MatParam|$noenvmapmip|bool|{{Todo|What does this actually do and what engine branches is it in? Found in {{csgo}} under materials/metal/hr_metal/hr_metal_corrugated_001.vmt}}}}
{{MatParam|$noenvmapmip|bool|Disables [[mipmap]]ping on the cubemap used for the reflection.|only=CSGO}}
{{MatParam|$fresnelreflection|float|Adds a [http://www.3drender.com/glossary/fresneleffect.htm Fresnel effect] to the reflection. 0 is none, while 1 applies the full effect, similar to <code>[[Water_(shader)|Water]]</code>. The effect becomes multiplied with values higher than 1.
{{MatParam|$fresnelreflection|float|Adds a [http://www.3drender.com/glossary/fresneleffect.htm Fresnel effect] to the reflection. 0 is none, while 1 applies the full effect, similar to <code>[[Water_(shader)|Water]]</code>. The effect becomes multiplied with values higher than 1.
: {{Note|Only available for <code>LightmappedGeneric</code> and <code>WorldVertexTransition</code>.}}|since=EP1}}
: {{Note|Only available for <code>LightmappedGeneric</code> and <code>WorldVertexTransition</code>.}}|since=EP1}}
Line 88: Line 88:
: {{Note|The fresnel values here are NOT the same as those for <code>[[$phong|$phongfresnelranges.]]</code>Instead, the first value is the minimum amount of fresnel, the second value is the maximum, and the final value is exponent.}}
: {{Note|The fresnel values here are NOT the same as those for <code>[[$phong|$phongfresnelranges.]]</code>Instead, the first value is the minimum amount of fresnel, the second value is the maximum, and the final value is exponent.}}
: {{bug|Cannot be used with {{ent|$bumpmap}}. <code>$phongfresnelranges</code> must be used instead.}}|since=L4D2}}
: {{bug|Cannot be used with {{ent|$bumpmap}}. <code>$phongfresnelranges</code> must be used instead.}}|since=L4D2}}
{{MatParam|$envmaplightscale|float|Allows the surface's lightmap to tint the reflections. A value between 0 and 1 determines how much the reflection is tinted; values above 1 are permitted but seem to actually start inverting the effect.
{{MatParam|$envmaplightscale|float|How much the surface's lightmap tints the specular reflection. A value between 0 (off) and 1 (no reflection with completely black lightmap) determines how much the reflection is tinted; values above 1 are permitted but seem to actually start inverting the effect.
: {{note|<code>LightmappedGeneric</code> only in {{As}}{{portal2}}}}|since=AS}}
: {{note|<code>LightmappedGeneric</code> only in {{As}}{{portal2}}, expanded to <code>VertexLitGeneric</code> and <code>WorldVertexTransition</code> in {{csgo}}.}}|since=AS}}
{{MatParam|$envmaplightscaleminmax|vector2|How strong the reflection should be. First value is minimum, second value is maximum. {{todo|Needs testing and a better description. Default seems to be [0 1].}}|since=CSGO}}
{{MatParam|$envmaplightscaleminmax|vector2|Thresholds for the lightmap reflection tinting effect. Setting the minimum value higher increases the minimum light amount at which the reflection gets nerfed to nothing.|only=CSGO}}
{{MatParam|$envmapanisotropy|bool|Enables warping of the reflection, "pushing" the top downward.
{{MatParam|$envmapanisotropy|bool|Enables warping of the reflection, "pushing" the top downward.
: {{Note|Not available on <code>VertexLitGeneric.</code>}}|since=CSGO}}
: {{Note|Not available on <code>VertexLitGeneric.</code>}}|only=CSGO}}
{{MatParam|$envmapanisotropyscale|normal|The amount the reflection should be warped by.|since=CSGO}}
{{MatParam|$envmapanisotropyscale|normal|The amount the reflection should be warped by.|only=CSGO}}


== Console commands ==
== Console commands ==

Revision as of 18:38, 8 December 2019

Template:Otherlang2

Specular reflections.

Template:Shaderparam It creates specular reflections, which are seen on smooth surfaces. It does this by defining an "environment map" (specifically a cubemap) to draw as a reflection; normally that of the nearest env_cubemap entity. The reflection is not dynamic.

Icon-Bug.pngBug:$envmap does not work in the latest Source engine version (v24) of Template:Game link if it uses an env_cubemap. This is probably the reason Valve used the same static reflective image for every reflective texture in the game.  [todo tested in ?]

The other form of reflection supported by Source is the diffuse Phong type.

Syntax

$envmap env_cubemap

"env_cubemap" is normally used, as it tells VBSP to swap in the name of the nearest env_cubemap when the map compiles. However it is also possible to use a static cubemap image that has been manually created.

Note.pngNote:If $envmap is used without specifying $basetexture, the specular reflections will be force drawn regardless of anything.
Note.pngNote:Most Cubemap textures will have no reflectivity when used as overlays or decals. It is unclear why this is so[Clarify].

Creating a custom static cubemap texture

Creating a custom cubemap texture might be required for some circumstances and is used occasionally in some Valve models.

In VTFEdit

For this to work you will need to have the 6 sides of the cubemap saved as individual textures in the correct orientation for it to appear correctly in the Source Engine. So some faces might need to be rotated either clockwise or counter clockwise. Each face will need to be mirrored horizontally before orientation.

Note.pngNote:Pre-Template:Game link games require 7 faces for the cubemap to work. The seventh in this case is a round texture, used as a sphere map for the $envmapsphere parameter.

To the right hand side of this page you will find two guide images to aid in properly rotating each side of your environment render.
Save one or both of those guides on your computer and then import your environment render onto it or recreate it in a smaller scale, then rotate your sides as instructed by the images.
Save every side as a separate image file, their names should be the number found on that specific square. This will ensure that the environment texture will be built correctly, as the numbers also represent the import order in VTFEdit.

Orientation guide for T-assembled environments. Click to enlarge
Orientation guide for Blender render results. Click to enlarge

Once you have all the image sides ready you can just import them all into VTFEdit and select "Environment Map". Texture format is up to you, generally DXT5 will do.

Cubemap tut1 cra0.jpg

Then just save it all as a .vtf file and use it in your VMT like so:

"$Envmap" "effects/my_cubemap"

"effects" is the usual folder for environments/cubemaps You may put yours anywhere you like

In VTEX

VTEX will automatically mirror and orient your faces, you need only to provide correctly named textures. Name each file something like envmap001a*.tga, where * is put BK, FT, LF, RT, UP, or DN. If you took a cubemap screenshot in-game, this step will already by done, but to make them work properly with Vtex.exe you must use HDRShop (but before you need to change textures format to BMP, because HDRShop can only work with that kind of format) and then covert them to PFM files format.

Todo: What axis does each direction relate to?

Cubemap axis reference 1.jpg

Create a text file the same name as your textures (e.g. envmap001a.txt). If building for HDR write in the following, otherwise leave it blank:

pfm 1
pfmscale 1
nocompress 1

Put these files into materialsrc and then just drag-n-drop .txt file into vtex.exe and you should end up with a working cubemap! HDR envmaps will be named like envmap001a.hdr.vtf, and only need to exist to work.

Parameters and Effects

$envmapmask $envmaptint $envmapcontrast $envmapsaturation $envmapframe $envmapmode $basetexturenoenvmap $envmapoptional $envmapsphere $noenvmapmip $fresnelreflection $envmapfresnel $envmapfresnelminmaxexp $envmaplightscale $envmaplightscaleminmax $envmapanisotropy $envmapanisotropyscale

Console commands

buildcubemaps
Generates cubemaps for use in materials. If this isn't run, objects will reflect the skybox (OB) or have an invalid reflection, white in Ep1 and pink checkerboards in MP.
mat_specular <booleanRedirectInput/boolean>
Disable or enable specular reflections. Default 1.
r_showenvcubemap <booleanRedirectInput/boolean>
Debug command to display cubemaps on all dynamic objects at full intensity. It was used to create the image at the start of this article.

See Also