2023-01-12 20:49:14 +01:00
2022-03-18 17:46:08 +01:00
2024-04-27 11:28:21 +02:00
# 2D meshes
2022-03-18 17:46:08 +01:00
2024-04-27 11:28:21 +02:00
## Introduction
2022-03-18 17:46:08 +01:00
In 3D, meshes are used to display the world. In 2D, they are rare as images are used more often.
2024-03-16 20:56:52 +01:00
Pandemonium's 2D engine is a pure two-dimensional engine, so it can't really display 3D meshes directly (although it can be done
2023-01-12 19:43:03 +01:00
via `Viewport` and `ViewportTexture` ).
2022-03-18 17:46:08 +01:00
2023-01-12 20:55:57 +01:00
See also:
If you are interested in displaying 3D meshes on a 2D viewport, see the `doc_viewport_as_texture` tutorial.
2022-03-18 17:46:08 +01:00
2D meshes are meshes that contain two-dimensional geometry (Z can be omitted or ignored) instead of 3D.
2023-01-12 19:43:03 +01:00
You can experiment creating them yourself using `SurfaceTool` from code and displaying them in a `MeshInstance2D` node.
2022-03-18 17:46:08 +01:00
Currently, the only way to generate a 2D mesh within the editor is by either importing an OBJ file as a mesh, or converting it from a Sprite.
2024-04-27 11:28:21 +02:00
## Optimizing pixels drawn
2022-03-18 17:46:08 +01:00
2024-03-16 20:56:52 +01:00
This workflow is useful for optimizing 2D drawing in some situations. When drawing large images with transparency, Pandemonium will draw the whole quad to the screen. The large transparent areas will still be drawn.
2022-03-18 17:46:08 +01:00
This can affect performance, especially on mobile devices, when drawing very large images (generally screen sized),
2023-01-12 19:43:03 +01:00
or layering multiple images on top of each other with large transparent areas (for example, when using `ParallaxBackground` ).
2022-03-18 17:46:08 +01:00
Converting to a mesh will ensure that only the opaque parts will be drawn and the rest will be ignored.
2024-04-27 11:28:21 +02:00
## Converting Sprites to 2D meshes
2022-03-18 17:46:08 +01:00
2023-01-12 19:43:03 +01:00
You can take advantage of this optimization by converting a `Sprite` to a `MeshInstance2D` .
2022-03-18 17:46:08 +01:00
Start with an image that contains large amounts of transparency on the edges, like this tree:
2023-01-12 20:16:00 +01:00
![](img/mesh2d1.png)
2022-03-18 17:46:08 +01:00
2023-01-12 19:43:03 +01:00
Put it in a `Sprite` and select "Convert to 2D Mesh" from the menu:
2022-03-18 17:46:08 +01:00
2023-01-12 20:16:00 +01:00
![](img/mesh2d2.png)
2022-03-18 17:46:08 +01:00
A dialog will appear, showing a preview of how the 2D mesh will be created:
2023-01-12 20:16:00 +01:00
![](img/mesh2d3.png)
2022-03-18 17:46:08 +01:00
The default values are good enough for many cases, but you can change growth and simplification according to your needs:
2023-01-12 20:16:00 +01:00
![](img/mesh2d4.png)
2022-03-18 17:46:08 +01:00
2023-01-12 19:43:03 +01:00
Finally, push the `Convert 2D Mesh` button and your Sprite will be replaced:
2022-03-18 17:46:08 +01:00
2023-01-12 20:16:00 +01:00
![](img/mesh2d5.png)