Parallax mapping
data:image/s3,"s3://crabby-images/bcc25/bcc250fdc1ba17b3d0b4fca30ed3ba052ddf5bc7" alt="English (en) English (en)"
data:image/s3,"s3://crabby-images/d9bd4/d9bd41dfed422a2d3ef4a409c5e3126fdd5c5d8a" alt="Translate (Translate) Translate (Translate)"
data:image/s3,"s3://crabby-images/9d3c9/9d3c9ef79c5c9830bb60c03b8cd2aa6c3f370c89" alt="Warning.png"
data:image/s3,"s3://crabby-images/bb04d/bb04dce45e12c47a9c47f828f56eb489633daa34" alt="Alien Swarm engine branch"
Parallax mapping (also known as offset mapping or virtual displacement mapping) is a shading technique that displaces the individual pixel height of a surface so that when you look at it at an angle, the high points will obscure the low points behind them, making it look three-dimensional. The height data for each pixel comes from a $parallaxmap texture, which needs to be created for each parallax mapped material.
Parallax mapping is an enhancement of the bump mapping technique. It is only worthwhile for textures that have a depth of at least a few centimeters, like deep-set bricks or stone.
Creating a parallax mapped material
Creating a heightmap
Regardless of the way you are going to render them, creating parallax mapped materials always starts with creating a heightmap.
Adding a parallax map with the built-in support for parallax maps
data:image/s3,"s3://crabby-images/9d3c9/9d3c9ef79c5c9830bb60c03b8cd2aa6c3f370c89" alt="Warning.png"
data:image/s3,"s3://crabby-images/640bf/640bfb60fb766257d898ce693ccdfea26092d18f" alt="Source"
data:image/s3,"s3://crabby-images/3011e/3011e053ef8b8cf0210068d556327f8389727b7e" alt="Half-Life 2"
Add these two lines to your Valve Material (.vmt) file:
$parallaxmap <texture>
$parallaxmapscale <float>
Fill in the path and name of your heightmap on the first line, and a number between 0 and 1 on the second line. This number affects how deep the texture will look. 0.05
is an appropriate value for bricks.
Example VMT:
Adding a parallax map with the Parallax Occlusion Shader mod
data:image/s3,"s3://crabby-images/704f2/704f290aa02410ca6fa3b309d87b3304fb70c19e" alt="Obsolete-notext.png"
data:image/s3,"s3://crabby-images/49672/49672e1f1674427f38ae7020fe2c43dc7d4ed5d3" alt="Note.png"
data:image/s3,"s3://crabby-images/a9ee9/a9ee9f75a272a811a1ceca0a9ae0c5b6c21e3439" alt="Source 2006"
First, in the Valve Material (.vmt) file, after the line
"LightmappedGeneric"
add this line:
//"MN_PrlxLightmappedGeneric"
When playing a map with your parallax mapped material, comment out the first line. When compiling a map with your parallax mapped material in Hammer, comment out the last line. This (according to the author of the mod) is a workaround to a glitch in Source SDK.
Finally, add this line to your VMT file:
"$heightmap" "texture name"
Other parameters you may need:
"$heightscale"
, defines the "depth" of the effect, takes values 0.0—1.0, default=0.4
"$heightmapsample"
, default=16
Example VMT:
Adding parallax map with the PBR shader
Games running on Strata Source or with Thexa4's PBR shader installed can use parallax mapping already. All Strata Source games use a similar method.
data:image/s3,"s3://crabby-images/49672/49672e1f1674427f38ae7020fe2c43dc7d4ed5d3" alt="Note.png"
data:image/s3,"s3://crabby-images/bebe0/bebe0a353544a71001b6d37b9a000757a23c7acd" alt="Source 2013"
data:image/s3,"s3://crabby-images/9d3c9/9d3c9ef79c5c9830bb60c03b8cd2aa6c3f370c89" alt="Warning.png"
To make the effect work you will need to have these 3 parameters in your VMT:
$parallax <bool> - Enables/Disables parallax mapping.
$parallaxdepth <float> - Controls the intensity of the parallax effect.
$parallaxcenter <float> - Center depth of the Parallax Map.
To make the parallax mapping work you will need to put your Heightmap into the Bump map's alpha channel. See Creating PBR materials for a tutorial on how to do this.
Example VMT:
Parallax occlusion mapping in
Black Mesa
Black Mesa has its own way of rendering parallax mapping, which was not used in the original campaign, but was used in Black Mesa: Blue Shift for brick walls and the likes. This material shader parameter can be used for LightmappedGeneric and VertexLitGeneric. Also works with Lightmapped_4WayBlend, useless however.
data:image/s3,"s3://crabby-images/9d3c9/9d3c9ef79c5c9830bb60c03b8cd2aa6c3f370c89" alt="Warning.png"
data:image/s3,"s3://crabby-images/ad66f/ad66f6dafe095f26bc49a3535f335e1bee686747" alt="Icon-Bug.png"
|
To make the effect work you will need to have these 3 parameters in your VMT:
$pomscale <float> - Scale of parallax mapping.
$pomminsamples <float> - Min amount of depth samples. The minimum is used at steep glancing angles and far distances. Less samples means more performance, but also worse quality.
data:image/s3,"s3://crabby-images/49672/49672e1f1674427f38ae7020fe2c43dc7d4ed5d3" alt="Note.png"
|
$pommaxsamples <float> - Max amount of depth samples. The maximum is used at shallow glancing angles and close distances.
data:image/s3,"s3://crabby-images/49672/49672e1f1674427f38ae7020fe2c43dc7d4ed5d3" alt="Note.png"
|
To make the parallax mapping work you'll need Heightmap. This is not embedded in the Bumpmap, but is instead kept separate in it's own VTF image.
Example VMT:
See also
- Adding PBR to Your Mod
- Creating PBR materials
- Material Creation
- $parallax
- Normal Map Creation
- Wikipedia:Parallax mapping