fiftyone.core.threed.mesh#
Mesh definitions for 3D visualization.
Classes:
|
Represents an abstract 3D mesh. |
|
Represents an OBJ mesh. |
|
Represents an FBX mesh. |
|
Represents a gLTF mesh. |
|
Represents a PLY mesh. |
|
Represents an STL mesh. |
- class fiftyone.core.threed.mesh.Mesh(name: str, material: MeshMaterial | None = None, visible=True, position: Vector3 | List[float] | Tuple[float] | array | None = None, scale: Vector3 | List[float] | Tuple[float] | array | None = None, quaternion: Quaternion | None = None)#
Bases:
Object3DRepresents an abstract 3D mesh.
- Parameters:
name – the name of the mesh
material (
fiftyone.core.threed.MeshMaterial, optional) – the default material for the mesh. Defaults tofiftyone.core.threed.MeshStandardMaterialif not providedvisible (True) – default visibility of the mesh in the scene
position (None) – the position of the mesh in object space
quaternion (None) – the quaternion of the mesh in object space
scale (None) – the scale of the mesh in object space
Methods:
set_default_material(material)Sets the material of the mesh.
add(*objs)Add one or more objects as children of this one.
as_dict()Converts the object to a dict.
clear()Remove all children from this object.
find_and_execute(node, predicate, on_match)Recursively search the scene graph and execute an action on matching nodes.
remove(*objs)Remove one or more objects from the scene graph recursively.
remove_by_name(name)Remove all objects with the given name from the scene graph recursively.
remove_by_uuid(target_uuid)Remove the object with the given UUID from the scene graph recursively.
traverse([include_self])Traverse the scene graph.
Attributes:
The local transform matrix of the object.
The position of the object in object space.
The quaternion of the object in object space.
The rotation of the object in object space.
The scale of the object in object space.
The unique ID of the object.
- set_default_material(material: MeshMaterial)#
Sets the material of the mesh.
- Parameters:
material (MeshMaterial) – the material to set as the default
- as_dict()#
Converts the object to a dict.
- clear() None#
Remove all children from this object.
- find_and_execute(node: Object3D, predicate, on_match, stop_on_first_match: bool = False) bool#
Recursively search the scene graph and execute an action on matching nodes.
This is a generic method for traversing the scene graph and performing operations on nodes that match a given predicate. It can be used for finding and removing nodes, collecting nodes, updating nodes, etc.
The traversal continues into the subtrees of both matching and non-matching nodes. For matching nodes, the subtree is traversed when on_match returns True and stop_on_first_match is False.
- Parameters:
node – the node to start searching from
predicate – a function that takes a child Object3D and returns
criteria (True if it matches the search)
on_match – a function called when a match is found, takes
(parent
searching (child) and returns True to continue)
to (False)
stop
stop_on_first_match – if True, stop searching after first match
processed (is)
- Returns:
True if a match was found and we should stop, False otherwise
Example
# Find all nodes with a specific name and collect them matches = [] def predicate(child):
return child.name == “target”
- def on_match(parent, child):
matches.append(child) return True # continue searching
scene.find_and_execute(scene, predicate, on_match)
- property local_transform_matrix#
The local transform matrix of the object.
Setting this property also decomposes the matrix into its constituent position, quaternion, and scale components. However, decomposition of matrices with skew / shear components (non-uniform scaling) might have unexpected results.
- property position#
The position of the object in object space.
- property quaternion#
The quaternion of the object in object space.
- remove(*objs: Object3D) None#
Remove one or more objects from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes any matching objects from their parent’s children list.
- Parameters:
*objs – one or more Object3D instances to remove
- Raises:
ValueError – if any of the objects to remove is this object itself
ValueError – if any of the objects is not found in the scene graph
- remove_by_name(name: str) None#
Remove all objects with the given name from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes all objects matching the given name from their parent’s children lists.
- Parameters:
name – the name of the objects to remove
- Raises:
ValueError – if attempting to remove this object itself by name
ValueError – if no objects with the given name are found
- remove_by_uuid(target_uuid: str) None#
Remove the object with the given UUID from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes the object matching the given UUID from its parent’s children list. UUIDs should be unique, so only one match is expected.
- Parameters:
target_uuid – the UUID of the object to remove
- Raises:
ValueError – if attempting to remove this object itself by UUID
ValueError – if no object with the given UUID is found
- property rotation#
The rotation of the object in object space.
- property scale#
The scale of the object in object space.
- traverse(include_self=True)#
Traverse the scene graph.
- property uuid#
The unique ID of the object.
- class fiftyone.core.threed.mesh.ObjMesh(name: str, obj_path: str, mtl_path: str | None = None, default_material: MeshMaterial | None = None, visible=True, position: Vector3 | List[float] | Tuple[float] | array | None = None, scale: Vector3 | List[float] | Tuple[float] | array | None = None, quaternion: Quaternion | None = None)#
Bases:
MeshRepresents an OBJ mesh.
- Parameters:
name (str) – the name of the mesh
obj_path (str) – the path to the
.objfile. The path may be either absolute or relative to the directory containing the.fo3dfilemtl_path (str, optional) – the path to the
.mtlfile. Defaults toNone. The path may be either absolute or relative to the directory containing the.fo3dfilematerial (
fiftyone.core.threed.MeshMaterial, optional) – the default material for the mesh ifmtl_pathis not provided or if material inmtl_pathis not found. Defaults tofiftyone.core.threed.MeshStandardMaterialvisible (True) – default visibility of the mesh in the scene
position (None) – the position of the mesh in object space
quaternion (None) – the quaternion of the mesh in object space
scale (None) – the scale of the mesh in object space
- Raises:
ValueError – if
obj_pathdoes not end with.objValueError – if
mtl_pathdoes not end with.mtl
Methods:
add(*objs)Add one or more objects as children of this one.
as_dict()Converts the object to a dict.
clear()Remove all children from this object.
find_and_execute(node, predicate, on_match)Recursively search the scene graph and execute an action on matching nodes.
remove(*objs)Remove one or more objects from the scene graph recursively.
remove_by_name(name)Remove all objects with the given name from the scene graph recursively.
remove_by_uuid(target_uuid)Remove the object with the given UUID from the scene graph recursively.
set_default_material(material)Sets the material of the mesh.
traverse([include_self])Traverse the scene graph.
Attributes:
The local transform matrix of the object.
The position of the object in object space.
The quaternion of the object in object space.
The rotation of the object in object space.
The scale of the object in object space.
The unique ID of the object.
- as_dict()#
Converts the object to a dict.
- clear() None#
Remove all children from this object.
- find_and_execute(node: Object3D, predicate, on_match, stop_on_first_match: bool = False) bool#
Recursively search the scene graph and execute an action on matching nodes.
This is a generic method for traversing the scene graph and performing operations on nodes that match a given predicate. It can be used for finding and removing nodes, collecting nodes, updating nodes, etc.
The traversal continues into the subtrees of both matching and non-matching nodes. For matching nodes, the subtree is traversed when on_match returns True and stop_on_first_match is False.
- Parameters:
node – the node to start searching from
predicate – a function that takes a child Object3D and returns
criteria (True if it matches the search)
on_match – a function called when a match is found, takes
(parent
searching (child) and returns True to continue)
to (False)
stop
stop_on_first_match – if True, stop searching after first match
processed (is)
- Returns:
True if a match was found and we should stop, False otherwise
Example
# Find all nodes with a specific name and collect them matches = [] def predicate(child):
return child.name == “target”
- def on_match(parent, child):
matches.append(child) return True # continue searching
scene.find_and_execute(scene, predicate, on_match)
- property local_transform_matrix#
The local transform matrix of the object.
Setting this property also decomposes the matrix into its constituent position, quaternion, and scale components. However, decomposition of matrices with skew / shear components (non-uniform scaling) might have unexpected results.
- property position#
The position of the object in object space.
- property quaternion#
The quaternion of the object in object space.
- remove(*objs: Object3D) None#
Remove one or more objects from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes any matching objects from their parent’s children list.
- Parameters:
*objs – one or more Object3D instances to remove
- Raises:
ValueError – if any of the objects to remove is this object itself
ValueError – if any of the objects is not found in the scene graph
- remove_by_name(name: str) None#
Remove all objects with the given name from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes all objects matching the given name from their parent’s children lists.
- Parameters:
name – the name of the objects to remove
- Raises:
ValueError – if attempting to remove this object itself by name
ValueError – if no objects with the given name are found
- remove_by_uuid(target_uuid: str) None#
Remove the object with the given UUID from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes the object matching the given UUID from its parent’s children list. UUIDs should be unique, so only one match is expected.
- Parameters:
target_uuid – the UUID of the object to remove
- Raises:
ValueError – if attempting to remove this object itself by UUID
ValueError – if no object with the given UUID is found
- property rotation#
The rotation of the object in object space.
- property scale#
The scale of the object in object space.
- set_default_material(material: MeshMaterial)#
Sets the material of the mesh.
- Parameters:
material (MeshMaterial) – the material to set as the default
- traverse(include_self=True)#
Traverse the scene graph.
- property uuid#
The unique ID of the object.
- class fiftyone.core.threed.mesh.FbxMesh(name: str, fbx_path: str, default_material: MeshMaterial | None = None, visible=True, position: Vector3 | List[float] | Tuple[float] | array | None = None, scale: Vector3 | List[float] | Tuple[float] | array | None = None, quaternion: Quaternion | None = None)#
Bases:
MeshRepresents an FBX mesh.
- Parameters:
name (str) – the name of the mesh
fbx_path (str) – the path to the
.fbxfile. Path may be either absolute or relative to the directory containing the.fo3dfilematerial (
fiftyone.core.threed.MeshMaterial, optional) – the default material for the mesh if FBX file does not contain material information. Defaults tofiftyone.core.threed.MeshStandardMaterialvisible (True) – default visibility of the mesh in the scene
position (None) – the position of the mesh in object space
quaternion (None) – the quaternion of the mesh in object space
scale (None) – the scale of the mesh in object space
- Raises:
ValueError – If
fbx_pathdoes not end with.fbx
Methods:
add(*objs)Add one or more objects as children of this one.
as_dict()Converts the object to a dict.
clear()Remove all children from this object.
find_and_execute(node, predicate, on_match)Recursively search the scene graph and execute an action on matching nodes.
remove(*objs)Remove one or more objects from the scene graph recursively.
remove_by_name(name)Remove all objects with the given name from the scene graph recursively.
remove_by_uuid(target_uuid)Remove the object with the given UUID from the scene graph recursively.
set_default_material(material)Sets the material of the mesh.
traverse([include_self])Traverse the scene graph.
Attributes:
The local transform matrix of the object.
The position of the object in object space.
The quaternion of the object in object space.
The rotation of the object in object space.
The scale of the object in object space.
The unique ID of the object.
- as_dict()#
Converts the object to a dict.
- clear() None#
Remove all children from this object.
- find_and_execute(node: Object3D, predicate, on_match, stop_on_first_match: bool = False) bool#
Recursively search the scene graph and execute an action on matching nodes.
This is a generic method for traversing the scene graph and performing operations on nodes that match a given predicate. It can be used for finding and removing nodes, collecting nodes, updating nodes, etc.
The traversal continues into the subtrees of both matching and non-matching nodes. For matching nodes, the subtree is traversed when on_match returns True and stop_on_first_match is False.
- Parameters:
node – the node to start searching from
predicate – a function that takes a child Object3D and returns
criteria (True if it matches the search)
on_match – a function called when a match is found, takes
(parent
searching (child) and returns True to continue)
to (False)
stop
stop_on_first_match – if True, stop searching after first match
processed (is)
- Returns:
True if a match was found and we should stop, False otherwise
Example
# Find all nodes with a specific name and collect them matches = [] def predicate(child):
return child.name == “target”
- def on_match(parent, child):
matches.append(child) return True # continue searching
scene.find_and_execute(scene, predicate, on_match)
- property local_transform_matrix#
The local transform matrix of the object.
Setting this property also decomposes the matrix into its constituent position, quaternion, and scale components. However, decomposition of matrices with skew / shear components (non-uniform scaling) might have unexpected results.
- property position#
The position of the object in object space.
- property quaternion#
The quaternion of the object in object space.
- remove(*objs: Object3D) None#
Remove one or more objects from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes any matching objects from their parent’s children list.
- Parameters:
*objs – one or more Object3D instances to remove
- Raises:
ValueError – if any of the objects to remove is this object itself
ValueError – if any of the objects is not found in the scene graph
- remove_by_name(name: str) None#
Remove all objects with the given name from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes all objects matching the given name from their parent’s children lists.
- Parameters:
name – the name of the objects to remove
- Raises:
ValueError – if attempting to remove this object itself by name
ValueError – if no objects with the given name are found
- remove_by_uuid(target_uuid: str) None#
Remove the object with the given UUID from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes the object matching the given UUID from its parent’s children list. UUIDs should be unique, so only one match is expected.
- Parameters:
target_uuid – the UUID of the object to remove
- Raises:
ValueError – if attempting to remove this object itself by UUID
ValueError – if no object with the given UUID is found
- property rotation#
The rotation of the object in object space.
- property scale#
The scale of the object in object space.
- set_default_material(material: MeshMaterial)#
Sets the material of the mesh.
- Parameters:
material (MeshMaterial) – the material to set as the default
- traverse(include_self=True)#
Traverse the scene graph.
- property uuid#
The unique ID of the object.
- class fiftyone.core.threed.mesh.GltfMesh(name: str, gltf_path: str, default_material: MeshMaterial | None = None, visible=True, position: Vector3 | List[float] | Tuple[float] | array | None = None, scale: Vector3 | List[float] | Tuple[float] | array | None = None, quaternion: Quaternion | None = None)#
Bases:
MeshRepresents a gLTF mesh.
- Parameters:
name (str) – the name of the mesh
gltf_path (str) – the path to the
.gltfor.glbfile. The path may be either absolute or relative to the directory containing the.fo3dfilematerial (
fiftyone.core.threed.MeshMaterial, optional) – the default material for the mesh if gLTF file does not contain material information. Defaults tofiftyone.core.threed.MeshStandardMaterialvisible (True) – default visibility of the mesh in the scene
position (None) – the position of the mesh in object space
quaternion (None) – the quaternion of the mesh in object space
scale (None) – the scale of the mesh in object space
- Raises:
ValueError – if
gltf_pathdoes not end with ‘.gltf’ or.glb
Methods:
add(*objs)Add one or more objects as children of this one.
as_dict()Converts the object to a dict.
clear()Remove all children from this object.
find_and_execute(node, predicate, on_match)Recursively search the scene graph and execute an action on matching nodes.
remove(*objs)Remove one or more objects from the scene graph recursively.
remove_by_name(name)Remove all objects with the given name from the scene graph recursively.
remove_by_uuid(target_uuid)Remove the object with the given UUID from the scene graph recursively.
set_default_material(material)Sets the material of the mesh.
traverse([include_self])Traverse the scene graph.
Attributes:
The local transform matrix of the object.
The position of the object in object space.
The quaternion of the object in object space.
The rotation of the object in object space.
The scale of the object in object space.
The unique ID of the object.
- as_dict()#
Converts the object to a dict.
- clear() None#
Remove all children from this object.
- find_and_execute(node: Object3D, predicate, on_match, stop_on_first_match: bool = False) bool#
Recursively search the scene graph and execute an action on matching nodes.
This is a generic method for traversing the scene graph and performing operations on nodes that match a given predicate. It can be used for finding and removing nodes, collecting nodes, updating nodes, etc.
The traversal continues into the subtrees of both matching and non-matching nodes. For matching nodes, the subtree is traversed when on_match returns True and stop_on_first_match is False.
- Parameters:
node – the node to start searching from
predicate – a function that takes a child Object3D and returns
criteria (True if it matches the search)
on_match – a function called when a match is found, takes
(parent
searching (child) and returns True to continue)
to (False)
stop
stop_on_first_match – if True, stop searching after first match
processed (is)
- Returns:
True if a match was found and we should stop, False otherwise
Example
# Find all nodes with a specific name and collect them matches = [] def predicate(child):
return child.name == “target”
- def on_match(parent, child):
matches.append(child) return True # continue searching
scene.find_and_execute(scene, predicate, on_match)
- property local_transform_matrix#
The local transform matrix of the object.
Setting this property also decomposes the matrix into its constituent position, quaternion, and scale components. However, decomposition of matrices with skew / shear components (non-uniform scaling) might have unexpected results.
- property position#
The position of the object in object space.
- property quaternion#
The quaternion of the object in object space.
- remove(*objs: Object3D) None#
Remove one or more objects from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes any matching objects from their parent’s children list.
- Parameters:
*objs – one or more Object3D instances to remove
- Raises:
ValueError – if any of the objects to remove is this object itself
ValueError – if any of the objects is not found in the scene graph
- remove_by_name(name: str) None#
Remove all objects with the given name from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes all objects matching the given name from their parent’s children lists.
- Parameters:
name – the name of the objects to remove
- Raises:
ValueError – if attempting to remove this object itself by name
ValueError – if no objects with the given name are found
- remove_by_uuid(target_uuid: str) None#
Remove the object with the given UUID from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes the object matching the given UUID from its parent’s children list. UUIDs should be unique, so only one match is expected.
- Parameters:
target_uuid – the UUID of the object to remove
- Raises:
ValueError – if attempting to remove this object itself by UUID
ValueError – if no object with the given UUID is found
- property rotation#
The rotation of the object in object space.
- property scale#
The scale of the object in object space.
- set_default_material(material: MeshMaterial)#
Sets the material of the mesh.
- Parameters:
material (MeshMaterial) – the material to set as the default
- traverse(include_self=True)#
Traverse the scene graph.
- property uuid#
The unique ID of the object.
- class fiftyone.core.threed.mesh.PlyMesh(name: str, ply_path: str, is_point_cloud: bool = False, center_geometry: bool = True, default_material: MeshMaterial | None = None, visible=True, position: Vector3 | List[float] | Tuple[float] | array | None = None, scale: Vector3 | List[float] | Tuple[float] | array | None = None, quaternion: Quaternion | None = None)#
Bases:
MeshRepresents a PLY mesh. A PLY mesh can be a point cloud or a mesh.
- Parameters:
name (str) – the name of the mesh
ply_path (str) – the path to the
.plyfile. The path may be either absolute or relative to the directory containing the.fo3dfileis_point_cloud (bool) – whether the PLY file is a point cloud. Defaults to
Falsecenter_geometry (bool) – whether to center the geometry. Defaults to
Truematerial (
fiftyone.core.threed.MeshMaterial, optional) – default material for the mesh if PLY file does not contain vertex colors. Defaults tofiftyone.core.threed.MeshStandardMaterial. If the PLY file contains vertex colors, the material is ignored and vertex colors are usedvisible (True) – default visibility of the mesh in the scene
position (None) – the position of the mesh in object space
quaternion (None) – the quaternion of the mesh in object space
scale (None) – the scale of the mesh in object space
- Raises:
ValueError – if
ply_pathdoes not end with.ply
Methods:
add(*objs)Add one or more objects as children of this one.
as_dict()Converts the object to a dict.
clear()Remove all children from this object.
find_and_execute(node, predicate, on_match)Recursively search the scene graph and execute an action on matching nodes.
remove(*objs)Remove one or more objects from the scene graph recursively.
remove_by_name(name)Remove all objects with the given name from the scene graph recursively.
remove_by_uuid(target_uuid)Remove the object with the given UUID from the scene graph recursively.
set_default_material(material)Sets the material of the mesh.
traverse([include_self])Traverse the scene graph.
Attributes:
The local transform matrix of the object.
The position of the object in object space.
The quaternion of the object in object space.
The rotation of the object in object space.
The scale of the object in object space.
The unique ID of the object.
- as_dict()#
Converts the object to a dict.
- clear() None#
Remove all children from this object.
- find_and_execute(node: Object3D, predicate, on_match, stop_on_first_match: bool = False) bool#
Recursively search the scene graph and execute an action on matching nodes.
This is a generic method for traversing the scene graph and performing operations on nodes that match a given predicate. It can be used for finding and removing nodes, collecting nodes, updating nodes, etc.
The traversal continues into the subtrees of both matching and non-matching nodes. For matching nodes, the subtree is traversed when on_match returns True and stop_on_first_match is False.
- Parameters:
node – the node to start searching from
predicate – a function that takes a child Object3D and returns
criteria (True if it matches the search)
on_match – a function called when a match is found, takes
(parent
searching (child) and returns True to continue)
to (False)
stop
stop_on_first_match – if True, stop searching after first match
processed (is)
- Returns:
True if a match was found and we should stop, False otherwise
Example
# Find all nodes with a specific name and collect them matches = [] def predicate(child):
return child.name == “target”
- def on_match(parent, child):
matches.append(child) return True # continue searching
scene.find_and_execute(scene, predicate, on_match)
- property local_transform_matrix#
The local transform matrix of the object.
Setting this property also decomposes the matrix into its constituent position, quaternion, and scale components. However, decomposition of matrices with skew / shear components (non-uniform scaling) might have unexpected results.
- property position#
The position of the object in object space.
- property quaternion#
The quaternion of the object in object space.
- remove(*objs: Object3D) None#
Remove one or more objects from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes any matching objects from their parent’s children list.
- Parameters:
*objs – one or more Object3D instances to remove
- Raises:
ValueError – if any of the objects to remove is this object itself
ValueError – if any of the objects is not found in the scene graph
- remove_by_name(name: str) None#
Remove all objects with the given name from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes all objects matching the given name from their parent’s children lists.
- Parameters:
name – the name of the objects to remove
- Raises:
ValueError – if attempting to remove this object itself by name
ValueError – if no objects with the given name are found
- remove_by_uuid(target_uuid: str) None#
Remove the object with the given UUID from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes the object matching the given UUID from its parent’s children list. UUIDs should be unique, so only one match is expected.
- Parameters:
target_uuid – the UUID of the object to remove
- Raises:
ValueError – if attempting to remove this object itself by UUID
ValueError – if no object with the given UUID is found
- property rotation#
The rotation of the object in object space.
- property scale#
The scale of the object in object space.
- set_default_material(material: MeshMaterial)#
Sets the material of the mesh.
- Parameters:
material (MeshMaterial) – the material to set as the default
- traverse(include_self=True)#
Traverse the scene graph.
- property uuid#
The unique ID of the object.
- class fiftyone.core.threed.mesh.StlMesh(name: str, stl_path: str, default_material: MeshMaterial | None = None, visible=True, position: Vector3 | List[float] | Tuple[float] | array | None = None, scale: Vector3 | List[float] | Tuple[float] | array | None = None, quaternion: Quaternion | None = None)#
Bases:
MeshRepresents an STL mesh.
- Parameters:
name (str) – the name of the mesh
stl_path (str) – the path to the
.stlfile. The path may be either absolute or relative to the directory containing the.fo3dfilematerial (
fiftyone.core.threed.MeshMaterial, optional) – default material for the mesh. Defaults tofiftyone.core.threed.MeshStandardMaterialvisible (True) – default visibility of the mesh in the scene
position (None) – the position of the mesh in object space
quaternion (None) – the quaternion of the mesh in object space
scale (None) – the scale of the mesh in object space
- Raises:
ValueError – if
stl_pathdoes not end with.stl
Methods:
add(*objs)Add one or more objects as children of this one.
as_dict()Converts the object to a dict.
clear()Remove all children from this object.
find_and_execute(node, predicate, on_match)Recursively search the scene graph and execute an action on matching nodes.
remove(*objs)Remove one or more objects from the scene graph recursively.
remove_by_name(name)Remove all objects with the given name from the scene graph recursively.
remove_by_uuid(target_uuid)Remove the object with the given UUID from the scene graph recursively.
set_default_material(material)Sets the material of the mesh.
traverse([include_self])Traverse the scene graph.
Attributes:
The local transform matrix of the object.
The position of the object in object space.
The quaternion of the object in object space.
The rotation of the object in object space.
The scale of the object in object space.
The unique ID of the object.
- as_dict()#
Converts the object to a dict.
- clear() None#
Remove all children from this object.
- find_and_execute(node: Object3D, predicate, on_match, stop_on_first_match: bool = False) bool#
Recursively search the scene graph and execute an action on matching nodes.
This is a generic method for traversing the scene graph and performing operations on nodes that match a given predicate. It can be used for finding and removing nodes, collecting nodes, updating nodes, etc.
The traversal continues into the subtrees of both matching and non-matching nodes. For matching nodes, the subtree is traversed when on_match returns True and stop_on_first_match is False.
- Parameters:
node – the node to start searching from
predicate – a function that takes a child Object3D and returns
criteria (True if it matches the search)
on_match – a function called when a match is found, takes
(parent
searching (child) and returns True to continue)
to (False)
stop
stop_on_first_match – if True, stop searching after first match
processed (is)
- Returns:
True if a match was found and we should stop, False otherwise
Example
# Find all nodes with a specific name and collect them matches = [] def predicate(child):
return child.name == “target”
- def on_match(parent, child):
matches.append(child) return True # continue searching
scene.find_and_execute(scene, predicate, on_match)
- property local_transform_matrix#
The local transform matrix of the object.
Setting this property also decomposes the matrix into its constituent position, quaternion, and scale components. However, decomposition of matrices with skew / shear components (non-uniform scaling) might have unexpected results.
- property position#
The position of the object in object space.
- property quaternion#
The quaternion of the object in object space.
- remove(*objs: Object3D) None#
Remove one or more objects from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes any matching objects from their parent’s children list.
- Parameters:
*objs – one or more Object3D instances to remove
- Raises:
ValueError – if any of the objects to remove is this object itself
ValueError – if any of the objects is not found in the scene graph
- remove_by_name(name: str) None#
Remove all objects with the given name from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes all objects matching the given name from their parent’s children lists.
- Parameters:
name – the name of the objects to remove
- Raises:
ValueError – if attempting to remove this object itself by name
ValueError – if no objects with the given name are found
- remove_by_uuid(target_uuid: str) None#
Remove the object with the given UUID from the scene graph recursively.
This method searches recursively through the entire scene graph starting from this object and removes the object matching the given UUID from its parent’s children list. UUIDs should be unique, so only one match is expected.
- Parameters:
target_uuid – the UUID of the object to remove
- Raises:
ValueError – if attempting to remove this object itself by UUID
ValueError – if no object with the given UUID is found
- property rotation#
The rotation of the object in object space.
- property scale#
The scale of the object in object space.
- set_default_material(material: MeshMaterial)#
Sets the material of the mesh.
- Parameters:
material (MeshMaterial) – the material to set as the default
- traverse(include_self=True)#
Traverse the scene graph.
- property uuid#
The unique ID of the object.