MeshDataTool

Inherits: Reference < Object

Helper tool to access and edit Mesh data.

Description

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 create_from_surface. When you are finished editing the data commit the data to a mesh with commit_to_surface.

Below is an example of how MeshDataTool may be used.

  1. var mesh = ArrayMesh.new()
  2. mesh.add_surface_from_arrays(Mesh.PRIMITIVE_TRIANGLES, CubeMesh.new().get_mesh_arrays())
  3. var mdt = MeshDataTool.new()
  4. mdt.create_from_surface(mesh, 0)
  5. for i in range(mdt.get_vertex_count()):
  6. var vertex = mdt.get_vertex(i)
  7. # In this example we extend the mesh by one unit, which results in seperated faces as it is flat shaded.
  8. vertex += mdt.get_vertex_normal(i)
  9. # Save your change.
  10. mdt.set_vertex(i, vertex)
  11. mesh.surface_remove(0)
  12. mdt.commit_to_surface(mesh)
  13. var mi = MeshInstance.new()
  14. mi.mesh = mesh
  15. add_child(mi)

See also ArrayMesh, ImmediateGeometry and SurfaceTool for procedural geometry generation.

Note: Godot uses clockwise winding order for front faces of triangle primitive modes.

Methods

voidclear ( )
Errorcommit_to_surface ( ArrayMesh mesh )
Errorcreate_from_surface ( ArrayMesh mesh, int surface )
intget_edge_count ( ) const
PoolIntArrayget_edge_faces ( int idx ) const
Variantget_edge_meta ( int idx ) const
intget_edge_vertex ( int idx, int vertex ) const
intget_face_count ( ) const
intget_face_edge ( int idx, int edge ) const
Variantget_face_meta ( int idx ) const
Vector3get_face_normal ( int idx ) const
intget_face_vertex ( int idx, int vertex ) const
intget_format ( ) const
Materialget_material ( ) const
Vector3get_vertex ( int idx ) const
PoolIntArrayget_vertex_bones ( int idx ) const
Colorget_vertex_color ( int idx ) const
intget_vertex_count ( ) const
PoolIntArrayget_vertex_edges ( int idx ) const
PoolIntArrayget_vertex_faces ( int idx ) const
Variantget_vertex_meta ( int idx ) const
Vector3get_vertex_normal ( int idx ) const
Planeget_vertex_tangent ( int idx ) const
Vector2get_vertex_uv ( int idx ) const
Vector2get_vertex_uv2 ( int idx ) const
PoolRealArrayget_vertex_weights ( int idx ) const
voidset_edge_meta ( int idx, Variant meta )
voidset_face_meta ( int idx, Variant meta )
voidset_material ( Material material )
voidset_vertex ( int idx, Vector3 vertex )
voidset_vertex_bones ( int idx, PoolIntArray bones )
voidset_vertex_color ( int idx, Color color )
voidset_vertex_meta ( int idx, Variant meta )
voidset_vertex_normal ( int idx, Vector3 normal )
voidset_vertex_tangent ( int idx, Plane tangent )
voidset_vertex_uv ( int idx, Vector2 uv )
voidset_vertex_uv2 ( int idx, Vector2 uv2 )
voidset_vertex_weights ( int idx, PoolRealArray weights )

Method Descriptions

  • void clear ( )

Clears all data currently in MeshDataTool.


Adds a new surface to specified Mesh with edited data.


Uses specified surface of given Mesh to populate data for MeshDataTool.

Requires Mesh with primitive type Mesh.PRIMITIVE_TRIANGLES.


  • int get_edge_count ( ) const

Returns the number of edges in this Mesh.


Returns array of faces that touch given edge.


Returns meta information assigned to given edge.


  • int get_edge_vertex ( int idx, int vertex ) const

Returns index of specified vertex connected to given edge.

Vertex argument can only be 0 or 1 because edges are comprised of two vertices.


  • int get_face_count ( ) const

Returns the number of faces in this Mesh.


  • int get_face_edge ( int idx, int edge ) const

Returns specified edge associated with given face.

Edge argument must 2 or less because a face only has three edges.


Returns the metadata associated with the given face.


Calculates and returns the face normal of the given face.


  • int get_face_vertex ( int idx, int vertex ) const

Returns the specified vertex of the given face.

Vertex argument must be 2 or less because faces contain three vertices.


  • int get_format ( ) const

Returns the Mesh‘s format. Format is an integer made up of Mesh format flags combined together. For example, a mesh containing both vertices and normals would return a format of 3 because ArrayMesh.ARRAY_FORMAT_VERTEX is 1 and ArrayMesh.ARRAY_FORMAT_NORMAL is 2.

See ArrayFormat for a list of format flags.


Returns the material assigned to the Mesh.


Returns the vertex at given index.


Returns the bones of the given vertex.


  • Color get_vertex_color ( int idx ) const

Returns the color of the given vertex.


  • int get_vertex_count ( ) const

Returns the total number of vertices in Mesh.


Returns an array of edges that share the given vertex.


Returns an array of faces that share the given vertex.


Returns the metadata associated with the given vertex.


Returns the normal of the given vertex.


  • Plane get_vertex_tangent ( int idx ) const

Returns the tangent of the given vertex.


Returns the UV of the given vertex.


Returns the UV2 of the given vertex.


Returns bone weights of the given vertex.


Sets the metadata of the given edge.


Sets the metadata of the given face.


  • void set_material ( Material material )

Sets the material to be used by newly-constructed Mesh.


Sets the position of the given vertex.


Sets the bones of the given vertex.


  • void set_vertex_color ( int idx, Color color )

Sets the color of the given vertex.


Sets the metadata associated with the given vertex.


  • void set_vertex_normal ( int idx, Vector3 normal )

Sets the normal of the given vertex.


  • void set_vertex_tangent ( int idx, Plane tangent )

Sets the tangent of the given vertex.


Sets the UV of the given vertex.


Sets the UV2 of the given vertex.


Sets the bone weights of the given vertex.