ProjectCameraMap_v2
Overview
ProjectCameraMap_v2 uses a camera frustum to directly apply a texture to a material. This is useful for techniques such as decals and background mattes.
ProjectCameraMap, by comparison, creates texture coordinates that are used as inputs to other maps.
data:image/s3,"s3://crabby-images/11016/11016c60817283612fe834e01c4e9a6e154dd937" alt="Texture is applied via a camera frustum"
data:image/s3,"s3://crabby-images/3b099/3b099f82a03669e418574b970f98e195ec994c6d" alt="Decal setup with premultiplied color"
data:image/s3,"s3://crabby-images/b05be/b05becc033b8682e68bd38b9c345654f61f3bfa0" alt="Decal setup"
data:image/s3,"s3://crabby-images/ec20d/ec20d6cd0a93977647f81135249d3af0c3b9a22d" alt="Matte setup with premultiplied color"
data:image/s3,"s3://crabby-images/6c6e2/6c6e27e1957b12c62fb25f31382d8b19d19f4f7b" alt="Matte setup"
Attribute Reference
General attributes
alpha_only
Bool
default: False
When enabled, the alpha channel is returned instead of RGB
aspect_ratio_source
Int enum
0 = “from texture” (default)
1 = “custom”
Whether to use the image and pixel aspect ratio of the texture being projected, or a custom aspect ratio
black_outside_projection
Bool
default: True
Toggles whether projections appear outside the 0-1 uv range of the projector
custom_aspect_ratio
Float
default: 1.0
Custom aspect ratio for the projected texture
gamma
Int enum
0 = “off”
1 = “on”
2 = “auto” (default)
Controls application of gamma to images (off -0, on - 1, auto - 2). Auto will apply gamma decoding to 8-bit images
project_on_back_faces
Bool
default: False
Toggles whether camera projections appear on back faces.
data:image/s3,"s3://crabby-images/b0171/b017146841fe65670dd6673ffe079863d3081bb9" alt="Inactive (Default)"
data:image/s3,"s3://crabby-images/f2437/f2437984800ec7ae3f12d2da069d8b668b06cc5b" alt="Active"
projector
Camera
default: None
The camera to project from
texture
String filename
default:
Filename that points to a texture .exr or .tx file (must be mip-mapped and tiled with maketx).
unpremultiply
Bool
default: False
When enabled, the rgb channels are divided by the alpha channel (where non-zero)
data:image/s3,"s3://crabby-images/d68a2/d68a269742bc3ea865ff60be2d588f43c50977e2" alt="Dark edges appear on premultiplied textures"
data:image/s3,"s3://crabby-images/a8a19/a8a19dd8ff5d228e8060a0c38cb8025758ac8c34" alt="Turning this on fixes the edges"
use_reference_space
Bool
default: False
Use reference space
Examples
local projCam1 = Camera("projCam1")
{
["node xform"] = translate(0, 3, 75) * rotate(-5, 1, 0, 0) * rotate(90, 0, 1, 0),
["focal"] = 150,
["film width aperture"] = 24,
}
local projMap = ProjectCameraMap_v2("projMap") {
["projector"] = projCam1,
["texture"] = "myTexture.tx",
["project_on_back_faces"] = false,
}
local mtl1 = DwaSolidDielectricMaterial("mtl1") {
["show diffuse"] = false,
["show specular"] = false,
["show emission"] = true,
["emission"] = bind(projMap, Rgb(1,1,1)),
}