Textures#
Textures in Ignis are patterns, nodes or other building blocks for shading networks.
All number and color parameters can be connected to a shading network or texture via PExpr to build an actual tree. Cycles are prohibited.
A texture is specified in the textures block with a name and a type. The type has to be one of the textures listed at this section below.
{
// ...
"textures": [
// ...
{"name":"NAME", "type":"TYPE", /* DEPENDS ON TYPE */},
// ...
]
// ...
}
Image texture (image)#
Parameter |
Type |
Default |
PExpr |
Description |
---|---|---|---|---|
filename |
string |
None |
Path to a valid image file. |
|
filter_type |
string |
|
The filter type to be used. Has to be one of the following: [“bicubic”, “bilinear”, “nearest”]. |
|
wrap_mode |
string |
|
The wrap method to be used. Has to be one of the following: [“repeat”, “mirror”, “clamp”]. |
|
transform |
transform |
Identity |
Optional 2d transformation applied to texture coordinates. |
|
linear |
boolean |
false |
The given image file is already in linear space and inverse gamma mapping can be skipped. Ignored for EXR and HDR images as it is expected that they are always in linear space. |
data:image/s3,"s3://crabby-images/49294/4929471884e4abc7e8d15fb3cc7b64ae6e49b3ff" alt="../../_images/texture_image.jpg"
Image texture#
Brick (brick)#
Parameter |
Type |
Default |
PExpr |
Description |
---|---|---|---|---|
color0 color1 |
color |
|
The colors to used for the brick. color0 is the mortar, color1 is the actual brick. |
|
scale_x scale_y |
number |
|
Numbers of grids in a normalized frame [0,0]x[1,1]. |
|
gap_x gap_y |
number |
|
Normalized gap size. |
|
transform |
transform |
Identity |
Optional 2d transformation applied to texture coordinates. |
data:image/s3,"s3://crabby-images/17f38/17f387862bf3965398c734281672d70240d5e1a6" alt="../../_images/texture_brick.jpg"
Brick texture#
Checkerboard (checkerboard)#
Parameter |
Type |
Default |
PExpr |
Description |
---|---|---|---|---|
color0 color1 |
color |
|
The colors to use in the checkerboard. |
|
scale_x scale_y |
number |
|
Numbers of grids in a normalized frame [0,0]x[1,1]. |
|
transform |
transform |
Identity |
Optional 2d transformation applied to texture coordinates. |
data:image/s3,"s3://crabby-images/7df0f/7df0f651706347f2790e6b3eda40d78e73a4df4b" alt="../../_images/texture_checkerboard.jpg"
Checkerboard texture#
Noise (noise)#
Parameter |
Type |
Default |
PExpr |
Description |
---|---|---|---|---|
color |
color |
|
Tint |
|
colored |
boolean |
false |
True will generate a colored texture, instead of a grayscale one. |
data:image/s3,"s3://crabby-images/732cc/732ccf3a6cf58d9444d19ea419515b283050ab5e" alt="../../_images/texture_noise.jpg"
Noise texture, a slight color noise is visible#
Interpolated Noise (pnoise)#
Original noise used in legacy perlin implementation.
Parameter |
Type |
Default |
PExpr |
Description |
---|---|---|---|---|
color |
color |
|
Tint |
|
colored |
boolean |
false |
True will generate a colored texture, instead of a grayscale one. |
|
scale_x scale_y |
number |
|
Numbers of grids used for noise in a normalized frame [0,0]x[1,1]. |
|
transform |
transform |
Identity |
Optional 2d transformation applied to texture coordinates. |
data:image/s3,"s3://crabby-images/2ee8b/2ee8bb8ac2f6e02f150049bfdfdc833d209f4587" alt="../../_images/texture_pnoise.jpg"
PNoise texture#
Cell Noise (cellnoise)#
Parameter |
Type |
Default |
PExpr |
Description |
---|---|---|---|---|
color |
color |
|
Tint |
|
colored |
boolean |
false |
True will generate a colored texture, instead of a grayscale one. |
|
scale_x scale_y |
number |
|
Numbers of grids used for noise in a normalized frame [0,0]x[1,1]. |
|
transform |
transform |
Identity |
Optional 2d transformation applied to texture coordinates. |
data:image/s3,"s3://crabby-images/80b57/80b57a4372a14caebd77b5544a7f499e40220118" alt="../../_images/texture_cellnoise.jpg"
Cell noise texture#
Perlin Noise (perlin)#
Parameter |
Type |
Default |
PExpr |
Description |
---|---|---|---|---|
color |
color |
|
Tint |
|
colored |
boolean |
false |
True will generate a colored texture, instead of a grayscale one. |
|
scale_x scale_y |
number |
|
Numbers of grids used for noise in a normalized frame [0,0]x[1,1]. |
|
transform |
transform |
Identity |
Optional 2d transformation applied to texture coordinates. |
data:image/s3,"s3://crabby-images/180ab/180abf35bdf837d3d851a1431f3e8c3cf53420fa" alt="../../_images/texture_perlin.jpg"
Perlin noise texture#
Voronoi Noise (voronoi)#
Parameter |
Type |
Default |
PExpr |
Description |
---|---|---|---|---|
color |
color |
|
Tint |
|
colored |
boolean |
false |
True will generate a colored texture, instead of a grayscale one. |
|
scale_x scale_y |
number |
|
Numbers of grids used for noise in a normalized frame [0,0]x[1,1]. |
|
transform |
transform |
Identity |
Optional 2d transformation applied to texture coordinates. |
data:image/s3,"s3://crabby-images/7d0e7/7d0e74f002f7b0dbda6b3163961dda4546704670" alt="../../_images/texture_voronoi.jpg"
Voronoi texture#
Fractional Brownian Motion (fbm)#
Parameter |
Type |
Default |
PExpr |
Description |
---|---|---|---|---|
color |
color |
|
Tint |
|
colored |
boolean |
false |
True will generate a colored texture, instead of a grayscale one. |
|
scale_x scale_y |
number |
|
Numbers of grids used for noise in a normalized frame [0,0]x[1,1]. |
|
transform |
transform |
Identity |
Optional 2d transformation applied to texture coordinates. |
data:image/s3,"s3://crabby-images/6f85b/6f85b415ccfa8faefa25e9331b3db67825cd928b" alt="../../_images/texture_fbm.jpg"
FBM texture#
Expression (expr)#
A custom PExpr expression with optional parameters.
Available are color (vec4
), vector (vec3
), number (num
) and bool
variables.
The parameters used inside the expression have to be prefixed with color_
, vec_
, num_
and bool_
respectively.
E.g., color_tint
will be called tint
inside the expression.
Parameter |
Type |
Default |
PExpr |
Description |
---|---|---|---|---|
expr |
string |
None |
A PExpr based expression |
data:image/s3,"s3://crabby-images/25074/2507455034e595ad18a8d9e2a40ef96f97338a90" alt="../../_images/texture_expr.jpg"
Custom texture generated by an expression#
{
"type": "expr",
"name": "tex",
"color_tint_1": [0.8, 0.4, 0.6],
"color_tint_2": [0.2, 0.1, 0.6],
"expr": "perlin(20*uv)*select(cos(8*Pi*uv.x*uv.y)*sperlin(10*uv) < 0, tint_1, tint_2)"
}
Texture transform (transform)#
Parameter |
Type |
Default |
PExpr |
Description |
---|---|---|---|---|
texture |
color |
None |
The texture the transform is applied to. |
|
transform |
transform |
Identity |
2d transformation applied to texture coordinates. |
data:image/s3,"s3://crabby-images/f1873/f1873c32a10e336bdc5a2be8bcb06ef7307593d9" alt="../../_images/texture_transform.jpg"
Transformed texture as a texture#