2018-07-26 17:56:21 +08:00
<?xml version="1.0" encoding="UTF-8" ?>
2023-03-01 08:44:37 +08:00
<class name= "SoftBody3D" inherits= "MeshInstance3D" version= "4.1" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "../class.xsd" >
2018-07-26 17:56:21 +08:00
<brief_description >
2018-09-17 01:52:21 +08:00
A soft mesh physics body.
2018-07-26 17:56:21 +08:00
</brief_description>
<description >
2018-09-17 01:52:21 +08:00
A deformable physics body. Used to create elastic or deformable objects such as cloth, rubber, or other flexible materials.
2022-08-26 01:35:52 +08:00
[b]Note:[/b] There are many known bugs in [SoftBody3D]. Therefore, it's not recommended to use them for things that can affect gameplay (such as a player character made entirely out of soft bodies).
2018-07-26 17:56:21 +08:00
</description>
<tutorials >
2021-11-15 17:43:07 +08:00
<link title= "SoftBody" > $DOCS_URL/tutorials/physics/soft_body.html</link>
2018-07-26 17:56:21 +08:00
</tutorials>
<methods >
<method name= "add_collision_exception_with" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "body" type= "Node" />
2018-07-26 17:56:21 +08:00
<description >
2018-09-17 01:52:21 +08:00
Adds a body to the list of bodies that this body can't collide with.
2018-07-26 17:56:21 +08:00
</description>
</method>
2018-10-25 03:32:55 +08:00
<method name= "get_collision_exceptions" >
2022-08-06 02:35:08 +08:00
<return type= "PhysicsBody3D[]" />
2018-10-25 03:32:55 +08:00
<description >
Returns an array of nodes that were added as collision exceptions for this body.
</description>
</method>
2021-08-12 07:01:38 +08:00
<method name= "get_collision_layer_value" qualifiers= "const" >
2021-07-30 21:28:05 +08:00
<return type= "bool" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "layer_number" type= "int" />
2018-07-26 17:56:21 +08:00
<description >
2022-08-10 10:00:19 +08:00
Returns whether or not the specified layer of the [member collision_layer] is enabled, given a [param layer_number] between 1 and 32.
2018-07-26 17:56:21 +08:00
</description>
</method>
2021-08-12 07:01:38 +08:00
<method name= "get_collision_mask_value" qualifiers= "const" >
2021-07-30 21:28:05 +08:00
<return type= "bool" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "layer_number" type= "int" />
2018-07-26 17:56:21 +08:00
<description >
2022-08-10 10:00:19 +08:00
Returns whether or not the specified layer of the [member collision_mask] is enabled, given a [param layer_number] between 1 and 32.
2018-07-26 17:56:21 +08:00
</description>
</method>
2021-03-25 19:19:51 +08:00
<method name= "get_physics_rid" qualifiers= "const" >
2021-07-30 21:28:05 +08:00
<return type= "RID" />
2021-03-25 19:19:51 +08:00
<description >
</description>
</method>
2021-08-31 03:48:52 +08:00
<method name= "get_point_transform" >
<return type= "Vector3" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "point_index" type= "int" />
2021-08-31 03:48:52 +08:00
<description >
Returns local translation of a vertex in the surface array.
</description>
</method>
<method name= "is_point_pinned" qualifiers= "const" >
<return type= "bool" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "point_index" type= "int" />
2021-08-31 03:48:52 +08:00
<description >
Returns [code]true[/code] if vertex is set to pinned.
</description>
</method>
2018-07-26 17:56:21 +08:00
<method name= "remove_collision_exception_with" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "body" type= "Node" />
2018-07-26 17:56:21 +08:00
<description >
2018-09-17 01:52:21 +08:00
Removes a body from the list of bodies that this body can't collide with.
2018-07-26 17:56:21 +08:00
</description>
</method>
2021-08-12 07:01:38 +08:00
<method name= "set_collision_layer_value" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "layer_number" type= "int" />
<param index= "1" name= "value" type= "bool" />
2018-07-26 17:56:21 +08:00
<description >
2022-08-10 10:00:19 +08:00
Based on [code]value[/code], enables or disables the specified layer in the [member collision_layer], given a [param layer_number] between 1 and 32.
2018-07-26 17:56:21 +08:00
</description>
</method>
2021-08-12 07:01:38 +08:00
<method name= "set_collision_mask_value" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "layer_number" type= "int" />
<param index= "1" name= "value" type= "bool" />
2018-07-26 17:56:21 +08:00
<description >
2022-08-10 10:00:19 +08:00
Based on [code]value[/code], enables or disables the specified layer in the [member collision_mask], given a [param layer_number] between 1 and 32.
2018-07-26 17:56:21 +08:00
</description>
</method>
2021-08-31 03:48:52 +08:00
<method name= "set_point_pinned" >
<return type= "void" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "point_index" type= "int" />
<param index= "1" name= "pinned" type= "bool" />
<param index= "2" name= "attachment_path" type= "NodePath" default= "NodePath("")" />
2021-08-31 03:48:52 +08:00
<description >
2022-08-10 10:00:19 +08:00
Sets the pinned state of a surface vertex. When set to [code]true[/code], the optional [param attachment_path] can define a [Node3D] the pinned vertex will be attached to.
2021-08-31 03:48:52 +08:00
</description>
</method>
2018-07-26 17:56:21 +08:00
</methods>
<members >
2019-06-29 18:38:01 +08:00
<member name= "collision_layer" type= "int" setter= "set_collision_layer" getter= "get_collision_layer" default= "1" >
2022-08-26 01:35:52 +08:00
The physics layers this SoftBody3D [b]is in[/b]. Collision objects can exist in one or more of 32 different layers. See also [member collision_mask].
2021-11-15 17:43:07 +08:00
[b]Note:[/b] Object A can detect a contact with object B only if object B is in any of the layers that object A scans. See [url=$DOCS_URL/tutorials/physics/physics_introduction.html#collision-layers-and-masks]Collision layers and masks[/url] in the documentation for more information.
2018-07-26 17:56:21 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "collision_mask" type= "int" setter= "set_collision_mask" getter= "get_collision_mask" default= "1" >
2022-08-26 01:35:52 +08:00
The physics layers this SoftBody3D [b]scans[/b]. Collision objects can scan one or more of 32 different layers. See also [member collision_layer].
2021-11-15 17:43:07 +08:00
[b]Note:[/b] Object A can detect a contact with object B only if object B is in any of the layers that object A scans. See [url=$DOCS_URL/tutorials/physics/physics_introduction.html#collision-layers-and-masks]Collision layers and masks[/url] in the documentation for more information.
2018-07-26 17:56:21 +08:00
</member>
2021-03-25 19:19:51 +08:00
<member name= "damping_coefficient" type= "float" setter= "set_damping_coefficient" getter= "get_damping_coefficient" default= "0.01" >
2018-07-26 17:56:21 +08:00
</member>
2022-08-26 01:35:52 +08:00
<member name= "disable_mode" type= "int" setter= "set_disable_mode" getter= "get_disable_mode" enum= "SoftBody3D.DisableMode" default= "0" >
2021-06-18 09:09:40 +08:00
Defines the behavior in physics when [member Node.process_mode] is set to [constant Node.PROCESS_MODE_DISABLED]. See [enum DisableMode] for more details about the different modes.
</member>
2019-06-29 18:38:01 +08:00
<member name= "drag_coefficient" type= "float" setter= "set_drag_coefficient" getter= "get_drag_coefficient" default= "0.0" >
2018-07-26 17:56:21 +08:00
</member>
2021-03-25 19:19:51 +08:00
<member name= "linear_stiffness" type= "float" setter= "set_linear_stiffness" getter= "get_linear_stiffness" default= "0.5" >
2018-07-26 17:56:21 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "parent_collision_ignore" type= "NodePath" setter= "set_parent_collision_ignore" getter= "get_parent_collision_ignore" default= "NodePath("")" >
2022-08-26 01:35:52 +08:00
[NodePath] to a [CollisionObject3D] this SoftBody3D should avoid clipping.
2018-07-26 17:56:21 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "pressure_coefficient" type= "float" setter= "set_pressure_coefficient" getter= "get_pressure_coefficient" default= "0.0" >
2018-07-26 17:56:21 +08:00
</member>
2019-11-08 15:33:48 +08:00
<member name= "ray_pickable" type= "bool" setter= "set_ray_pickable" getter= "is_ray_pickable" default= "true" >
2022-08-26 01:35:52 +08:00
If [code]true[/code], the [SoftBody3D] will respond to [RayCast3D]s.
2019-11-08 15:33:48 +08:00
</member>
2021-03-25 19:19:51 +08:00
<member name= "simulation_precision" type= "int" setter= "set_simulation_precision" getter= "get_simulation_precision" default= "5" >
2018-09-17 01:52:21 +08:00
Increasing this value will improve the resulting simulation, but can affect performance. Use with care.
2018-07-26 17:56:21 +08:00
</member>
2021-03-25 19:19:51 +08:00
<member name= "total_mass" type= "float" setter= "set_total_mass" getter= "get_total_mass" default= "1.0" >
2022-08-26 01:35:52 +08:00
The SoftBody3D's mass.
2018-07-26 17:56:21 +08:00
</member>
</members>
<constants >
2021-06-18 09:09:40 +08:00
<constant name= "DISABLE_MODE_REMOVE" value= "0" enum= "DisableMode" >
2022-08-26 01:35:52 +08:00
When [member Node.process_mode] is set to [constant Node.PROCESS_MODE_DISABLED], remove from the physics simulation to stop all physics interactions with this [SoftBody3D].
2021-06-18 09:09:40 +08:00
Automatically re-added to the physics simulation when the [Node] is processed again.
</constant>
<constant name= "DISABLE_MODE_KEEP_ACTIVE" value= "1" enum= "DisableMode" >
When [member Node.process_mode] is set to [constant Node.PROCESS_MODE_DISABLED], do not affect the physics simulation.
</constant>
2018-07-26 17:56:21 +08:00
</constants>
</class>