mirror of
https://github.com/Relintai/material-maker.git
synced 2025-02-27 12:04:19 +01:00
112 lines
4.1 KiB
Markdown
112 lines
4.1 KiB
Markdown
This is a tool based on the Godot game engine that can be used to create textures procedurally. It can also be used as a Godot addon (but there's no good reason for not using it as a standalone tool).
|
|
|
|
Its user interface is based on Godot's GraphEditor: textures are described as interconnected texture generators and operators.
|
|
|
|
data:image/s3,"s3://crabby-images/0918c/0918cd6d5d52c7861fd624a69d46134702d5efdd" alt="Screenshot"
|
|
|
|
## Generators
|
|
|
|
### Image
|
|
|
|
This node reads a bitmap from disk
|
|
|
|
### Pattern
|
|
|
|
This generator creates a greyscale image by mixing an horizontal and a vertical pattern.
|
|
Patterns can either be based on a sine, triangle, square, saw or "constant" waveform (i.e. the color as function of the x or y coordinate).
|
|
The frequency (number of waves per unit) can be configure for both axes.
|
|
Mix functions can also be configured.
|
|
|
|
data:image/s3,"s3://crabby-images/a07ce/a07ce3a45bcf586edaa8fff7537e081af013ab10" alt="Pattern"
|
|
|
|
### Bricks
|
|
|
|
This generator creates bricks greyscale patterns.
|
|
|
|
The Bricks generator has 5 parameters:
|
|
* the number of brick rows
|
|
* the number of bricks per row
|
|
* the offset between even and odd rows
|
|
* the mortar space between bricks
|
|
* the bevel at the edge of the bricks
|
|
|
|
The bricks generator has 2 output:
|
|
* the first one will show mortal as black and bricks as white (bevel being shown as a gradient). It can be used as mask to mix brick and mortar, or to generate depth and normal textures
|
|
* the second one will just show a different color for each brick. It can be used to affect the brick's colors (and will be used in the future to offset textures).
|
|
|
|
data:image/s3,"s3://crabby-images/ac238/ac238afd425ead4f79b0584e36217f032dcf6b0a" alt="Bricks pattern"
|
|
|
|
### Perlin Noise
|
|
|
|
The Perlin Noise generator creates a greyscale pattern and has 4 parameters:
|
|
* the horizontal and vertical scale of the first iteration
|
|
* the number of iteration
|
|
* the persistence (the weight ratio between 2 iterations)
|
|
|
|
data:image/s3,"s3://crabby-images/3321a/3321ab3dd75d8da47fe4c78c109b857df14999d2" alt="Perlin Noise"
|
|
|
|
### Voronoi Noise
|
|
|
|
The Voronoi Noise generator creates greyscale patterns based on Voronoi diagrams and has 3 parameters:
|
|
* the horizontal and vertical scale (the number of feature points)
|
|
* the "intensity" of the noise (used to adjust the generated color)
|
|
|
|
The Voronoi generator has 3 outputs:
|
|
* The first output shows a greyscale image where intensity depends on the distance to the cell centers
|
|
* The second output shows a greyscale image where intensity depends on the distance to the cell edges
|
|
* The third output shows a different color for each cell.
|
|
|
|
data:image/s3,"s3://crabby-images/33f16/33f165d5a5fd76e8b279f50306d6ef8d2c63b681" alt="Voronoi Noise"
|
|
|
|
## Filters
|
|
|
|
### Colorize
|
|
|
|
This filter accepts a greyscale image as input and is configured using a gradient. The output image is obtained by applying the gradient to the greyscale image (the example below shows a colorized perlin noise).
|
|
|
|
data:image/s3,"s3://crabby-images/387a8/387a8700d278d3321d61c7fe308bb8b8df6746cd" alt="Colorize"
|
|
|
|
### Blend
|
|
|
|
This filter accepts 2 inputs and an optional mask and blends the 2 images according to the selected blend algorithm.
|
|
|
|
### Blur
|
|
|
|
This node applies a Gaussian blur to the input image.
|
|
|
|
### Combine
|
|
|
|
This node accepts 3 greyscale images as inputs (one for each R, G and B channels) and combines them into a single image. It is useful to create textures that combine distinct features (for example Metallic and Roughness for Godot's Spatial materials).
|
|
|
|
### Emboss
|
|
|
|
This node creates a lighting effect from a greyscale image, with a configurable light direction.
|
|
|
|
data:image/s3,"s3://crabby-images/6f595/6f595ed5194fa292620210cd789de394687b6360" alt="Emboss"
|
|
|
|
### Normal map
|
|
|
|
This node creates a normal map from a greyscale height map.
|
|
|
|
### Transform
|
|
|
|
This node applies a transform (translation, rotation, and scale) to its input image. Whether the input image is clamped or repeated when downsizing is configurable.
|
|
|
|
This can be combined with the pattern node to create a great variety of shapes.
|
|
|
|
### Warp
|
|
|
|
This node deforms an input image according to the gradient of another image (generally perlin noise).
|
|
|
|
data:image/s3,"s3://crabby-images/2b3d8/2b3d8a5921f3f71ed1107d02c62ac48208417c99" alt="Warp"
|
|
|
|
## Miscellaneous
|
|
|
|
### Material
|
|
|
|
This node defines the material shown in the 3d preview. It accepts textures for a subset of the PBR lighting model as implemented in the Godot engine. When exporting the material, each texture will be saved as a PNG file named after the project's name and a suffix for each material node input.
|
|
|
|
### Export
|
|
|
|
This node can be used to export extra PNG files (for example a combined PNG to be used with Godot materials).
|