Docs: MeshDataTool: showcase tool in code example
This commit is contained in:
parent
41f66761fd
commit
4f9b993423
1 changed files with 31 additions and 3 deletions
|
@ -7,16 +7,44 @@
|
||||||
MeshDataTool provides access to individual vertices in a [Mesh]. It allows users to read and edit vertex data of meshes. It also creates an array of faces and edges.
|
MeshDataTool provides access to individual vertices in a [Mesh]. It allows users to read and edit vertex data of meshes. It also creates an array of faces and edges.
|
||||||
To use MeshDataTool, load a mesh with [method create_from_surface]. When you are finished editing the data commit the data to a mesh with [method commit_to_surface].
|
To use MeshDataTool, load a mesh with [method create_from_surface]. When you are finished editing the data commit the data to a mesh with [method commit_to_surface].
|
||||||
Below is an example of how MeshDataTool may be used.
|
Below is an example of how MeshDataTool may be used.
|
||||||
[codeblock]
|
[codeblocks]
|
||||||
|
[gdscript]
|
||||||
|
var mesh = ArrayMesh.new()
|
||||||
|
mesh.add_surface_from_arrays(Mesh.PRIMITIVE_TRIANGLES, CubeMesh.new().get_mesh_arrays())
|
||||||
var mdt = MeshDataTool.new()
|
var mdt = MeshDataTool.new()
|
||||||
mdt.create_from_surface(mesh, 0)
|
mdt.create_from_surface(mesh, 0)
|
||||||
for i in range(mdt.get_vertex_count()):
|
for i in range(mdt.get_vertex_count()):
|
||||||
var vertex = mdt.get_vertex(i)
|
var vertex = mdt.get_vertex(i)
|
||||||
...
|
# In this example we extend the mesh by one unit, which results in seperated faces as it is flat shaded.
|
||||||
|
vertex += mdt.get_vertex_normal(i)
|
||||||
|
# Save your change.
|
||||||
mdt.set_vertex(i, vertex)
|
mdt.set_vertex(i, vertex)
|
||||||
mesh.surface_remove(0)
|
mesh.surface_remove(0)
|
||||||
mdt.commit_to_surface(mesh)
|
mdt.commit_to_surface(mesh)
|
||||||
[/codeblock]
|
var mi = MeshInstance.new()
|
||||||
|
mi.mesh = mesh
|
||||||
|
add_child(mi)
|
||||||
|
[/gdscript]
|
||||||
|
[csharp]
|
||||||
|
var mesh = new ArrayMesh();
|
||||||
|
mesh.AddSurfaceFromArrays(Mesh.PrimitiveType.Triangles, new CubeMesh().GetMeshArrays());
|
||||||
|
var mdt = new MeshDataTool();
|
||||||
|
mdt.CreateFromSurface(mesh, 0);
|
||||||
|
for (var i = 0; i < mdt.GetVertexCount(); i++)
|
||||||
|
{
|
||||||
|
Vector3 vertex = mdt.GetVertex(i);
|
||||||
|
// In this example we extend the mesh by one unit, which results in seperated faces as it is flat shaded.
|
||||||
|
vertex += mdt.GetVertexNormal(i);
|
||||||
|
// Save your change.
|
||||||
|
mdt.SetVertex(i, vertex);
|
||||||
|
}
|
||||||
|
mesh.SurfaceRemove(0);
|
||||||
|
mdt.CommitToSurface(mesh);
|
||||||
|
var mi = new MeshInstance();
|
||||||
|
mi.Mesh = mesh;
|
||||||
|
AddChild(mi);
|
||||||
|
[/csharp]
|
||||||
|
[/codeblocks]
|
||||||
See also [ArrayMesh], [ImmediateGeometry3D] and [SurfaceTool] for procedural geometry generation.
|
See also [ArrayMesh], [ImmediateGeometry3D] and [SurfaceTool] for procedural geometry generation.
|
||||||
[b]Note:[/b] Godot uses clockwise [url=https://learnopengl.com/Advanced-OpenGL/Face-culling]winding order[/url] for front faces of triangle primitive modes.
|
[b]Note:[/b] Godot uses clockwise [url=https://learnopengl.com/Advanced-OpenGL/Face-culling]winding order[/url] for front faces of triangle primitive modes.
|
||||||
</description>
|
</description>
|
||||||
|
|
Loading…
Reference in a new issue