2023-01-12 20:49:14 +01:00
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Shader materials
|
|
|
|
================
|
|
|
|
|
|
|
|
Introduction
|
|
|
|
------------
|
|
|
|
|
|
|
|
For the most common cases, Godot provides ready to use materials for
|
2023-01-12 19:30:47 +01:00
|
|
|
most types of shaders, such as `SpatialMaterial`,
|
|
|
|
`CanvasItemMaterial`.
|
2022-03-18 17:46:08 +01:00
|
|
|
They are flexible implementations that cover most use cases.
|
|
|
|
|
|
|
|
Shader materials allow writing a custom shader directly, for maximum flexibility.
|
|
|
|
Examples of this are:
|
|
|
|
|
|
|
|
- Create procedural textures.
|
|
|
|
- Create complex texture blending effects.
|
|
|
|
- Create animated materials, or materials that change over time.
|
|
|
|
- Create refractive effects or other advanced effects.
|
|
|
|
- Create special lighting shaders for more exotic materials.
|
|
|
|
- Animate vertices, like tree leaves or grass.
|
|
|
|
- Create custom particle code.
|
|
|
|
- And much more!
|
|
|
|
|
|
|
|
Godot provides built in functionality to make frequent operations
|
|
|
|
easier. Additionally, Godot's shader editor will detect errors as you
|
|
|
|
type, so you can see your edited shaders in real-time. It is also
|
|
|
|
possible to edit shaders using a visual, node-based graph editor.
|
|
|
|
|
|
|
|
Creating a ShaderMaterial
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
Create a new ShaderMaterial in some object of your choice. Go to the
|
|
|
|
"Material" property and create a ShaderMaterial.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/shader_material_create.png)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Next, click on the shader material to see its properties. From here you
|
|
|
|
can create a shader or visual shader. Regular shaders use code to set
|
|
|
|
their properties while a visual shader uses a node based workflow.
|
|
|
|
|
|
|
|
If you need to you can convert a visual shader to a text shader.
|
|
|
|
However you can't convert a text shader to a visual shader.
|
|
|
|
|
|
|
|
Choose one of them and you can start editing your shader.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/shader_create.png)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
If you create a regular shader click on it and the shader editor will open.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/shader_material_editor.png)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
If you create a visual shader the visual shader editor will open automatically.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/visual_shader_editor.png)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
In the visual shader editor you can click a button and see what your visual
|
|
|
|
shader looks like as shader code. This can be useful if you're trying to
|
|
|
|
replicate a text shader as nodes, or it can be used as a preview for converting
|
|
|
|
your visual shader to a text shader.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/visual_shader_code.png)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
2023-01-12 19:29:11 +01:00
|
|
|
To learn more about visual shaders, read `doc_visual_shaders`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Converting to ShaderMaterial
|
|
|
|
----------------------------
|
|
|
|
|
|
|
|
It is possible to convert from SpatialMaterial, CanvasItemMaterial and
|
|
|
|
ParticlesMaterial to ShaderMaterial. To do so, go to the material properties
|
|
|
|
and select the convert option.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/shader_material_convert.png)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
|
|
|
Using the convert option will turn the SpatialMaterial into a ShaderMaterial
|
|
|
|
with a text shader, not a visual shader.
|