2023-01-10 15:26:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/**************************************************************************/  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/*  soft_body.cpp                                                         */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**************************************************************************/  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/*                         This file is part of:                          */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/*                             GODOT ENGINE                               */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/*                        https://godotengine.org                         */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**************************************************************************/  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur.                  */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/*                                                                        */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* Permission is hereby granted, free of charge, to any person obtaining  */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* a copy of this software and associated documentation files (the        */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* "Software"), to deal in the Software without restriction, including    */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* without limitation the rights to use, copy, modify, merge, publish,    */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* distribute, sublicense, and/or sell copies of the Software, and to     */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* permit persons to whom the Software is furnished to do so, subject to  */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* the following conditions:                                              */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/*                                                                        */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* The above copyright notice and this permission notice shall be         */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* included in all copies or substantial portions of the Software.        */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/*                                                                        */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,        */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF     */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY   */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,   */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE      */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.                 */  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								/**************************************************************************/  
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "soft_body.h" 
  
						 
					
						
							
								
									
										
										
										
											2018-10-24 16:32:55 -03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  "core/list.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "core/object.h" 
  
						 
					
						
							
								
									
										
										
										
											2018-09-11 18:13:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  "core/os/os.h" 
  
						 
					
						
							
								
									
										
										
										
											2018-10-24 16:32:55 -03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  "core/rid.h" 
  
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# include  "scene/3d/collision_object.h" 
  
						 
					
						
							
								
									
										
										
										
											2018-10-24 16:32:55 -03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  "scene/3d/physics_body.h" 
  
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# include  "scene/3d/skeleton.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "servers/physics_server.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								SoftBodyVisualServerHandler : : SoftBodyVisualServerHandler ( )  { }  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBodyVisualServerHandler : : prepare ( RID  p_mesh ,  int  p_surface )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									clear ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ERR_FAIL_COND ( ! p_mesh . is_valid ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									mesh  =  p_mesh ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									surface  =  p_surface ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									const  uint32_t  surface_format  =  VS : : get_singleton ( ) - > mesh_surface_get_format ( mesh ,  surface ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									const  int  surface_vertex_len  =  VS : : get_singleton ( ) - > mesh_surface_get_array_len ( mesh ,  p_surface ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									const  int  surface_index_len  =  VS : : get_singleton ( ) - > mesh_surface_get_array_index_len ( mesh ,  p_surface ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									uint32_t  surface_offsets [ VS : : ARRAY_MAX ] ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-16 20:41:43 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									uint32_t  surface_strides [ VS : : ARRAY_MAX ] ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									buffer  =  VS : : get_singleton ( ) - > mesh_surface_get_array ( mesh ,  surface ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-16 20:41:43 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									VS : : get_singleton ( ) - > mesh_surface_make_offsets_from_format ( surface_format ,  surface_vertex_len ,  surface_index_len ,  surface_offsets ,  surface_strides ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ERR_FAIL_COND ( surface_strides [ VS : : ARRAY_VERTEX ]  ! =  surface_strides [ VS : : ARRAY_NORMAL ] ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									stride  =  surface_strides [ VS : : ARRAY_VERTEX ] ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									offset_vertices  =  surface_offsets [ VS : : ARRAY_VERTEX ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									offset_normal  =  surface_offsets [ VS : : ARRAY_NORMAL ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBodyVisualServerHandler : : clear ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( mesh . is_valid ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										buffer . resize ( 0 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									mesh  =  RID ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBodyVisualServerHandler : : open ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									write_buffer  =  buffer . write ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBodyVisualServerHandler : : close ( )  {  
						 
					
						
							
								
									
										
										
										
											2019-07-05 18:08:43 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									write_buffer . release ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBodyVisualServerHandler : : commit_changes ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									VS : : get_singleton ( ) - > mesh_surface_update_region ( mesh ,  surface ,  0 ,  buffer ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBodyVisualServerHandler : : set_vertex ( int  p_vertex_id ,  const  void  * p_vector3 )  {  
						 
					
						
							
								
									
										
										
										
											2021-04-29 12:34:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									memcpy ( & write_buffer [ p_vertex_id  *  stride  +  offset_vertices ] ,  p_vector3 ,  sizeof ( float )  *  3 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBodyVisualServerHandler : : set_normal ( int  p_vertex_id ,  const  void  * p_vector3 )  {  
						 
					
						
							
								
									
										
										
										
											2021-03-08 12:58:13 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									Vector2  normal_oct  =  VisualServer : : get_singleton ( ) - > norm_to_oct ( * ( Vector3  * ) p_vector3 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									int16_t  v_normal [ 2 ]  =  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										( int16_t ) CLAMP ( normal_oct . x  *  32767 ,  - 32768 ,  32767 ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										( int16_t ) CLAMP ( normal_oct . y  *  32767 ,  - 32768 ,  32767 ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									memcpy ( & write_buffer [ p_vertex_id  *  stride  +  offset_normal ] ,  v_normal ,  sizeof ( uint16_t )  *  2 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBodyVisualServerHandler : : set_aabb ( const  AABB  & p_aabb )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									VS : : get_singleton ( ) - > mesh_set_custom_aabb ( mesh ,  p_aabb ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								SoftBody : : PinnedPoint : : PinnedPoint ( )  :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										point_index ( - 1 ) , 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-04 16:00:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										spatial_attachment ( nullptr )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								SoftBody : : PinnedPoint : : PinnedPoint ( const  PinnedPoint  & obj_tocopy )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									point_index  =  obj_tocopy . point_index ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									spatial_attachment_path  =  obj_tocopy . spatial_attachment_path ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									spatial_attachment  =  obj_tocopy . spatial_attachment ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									offset  =  obj_tocopy . offset ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-03-02 13:32:29 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								SoftBody : : PinnedPoint  SoftBody : : PinnedPoint : : operator = ( const  PinnedPoint  & obj )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									point_index  =  obj . point_index ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									spatial_attachment_path  =  obj . spatial_attachment_path ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									spatial_attachment  =  obj . spatial_attachment ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									offset  =  obj . offset ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  * this ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : _update_pickable ( )  {  
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ! is_inside_tree ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										return ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-31 16:29:41 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									bool  pickable  =  ray_pickable  & &  is_visible_in_tree ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_set_ray_pickable ( physics_rid ,  pickable ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bool  SoftBody : : _set ( const  StringName  & p_name ,  const  Variant  & p_value )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									String  name  =  p_name ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									String  which  =  name . get_slicec ( ' / ' ,  0 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( " pinned_points "  = =  which )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  _set_property_pinned_points_indices ( p_value ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  else  if  ( " attachments "  = =  which )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										int  idx  =  name . get_slicec ( ' / ' ,  1 ) . to_int ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										String  what  =  name . get_slicec ( ' / ' ,  2 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  _set_property_pinned_points_attachment ( idx ,  what ,  p_value ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bool  SoftBody : : _get ( const  StringName  & p_name ,  Variant  & r_ret )  const  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									String  name  =  p_name ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									String  which  =  name . get_slicec ( ' / ' ,  0 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( " pinned_points "  = =  which )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										Array  arr_ret ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										const  int  pinned_points_indices_size  =  pinned_points . size ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										PoolVector < PinnedPoint > : : Read  r  =  pinned_points . read ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										arr_ret . resize ( pinned_points_indices_size ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										for  ( int  i  =  0 ;  i  <  pinned_points_indices_size ;  + + i )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											arr_ret [ i ]  =  r [ i ] . point_index ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										r_ret  =  arr_ret ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  else  if  ( " attachments "  = =  which )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										int  idx  =  name . get_slicec ( ' / ' ,  1 ) . to_int ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										String  what  =  name . get_slicec ( ' / ' ,  2 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  _get_property_pinned_points ( idx ,  what ,  r_ret ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : _get_property_list ( List < PropertyInfo >  * p_list )  const  {  
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									const  int  pinned_points_indices_size  =  pinned_points . size ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-05-18 12:43:36 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									p_list - > push_back ( PropertyInfo ( Variant : : POOL_INT_ARRAY ,  PNAME ( " pinned_points " ) ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( int  i  =  0 ;  i  <  pinned_points_indices_size ;  + + i )  { 
							 
						 
					
						
							
								
									
										
										
										
											2022-06-10 14:15:44 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										const  String  prefix  =  vformat ( " %s/%d/ " ,  PNAME ( " attachments " ) ,  i ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-05-18 12:43:36 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										p_list - > push_back ( PropertyInfo ( Variant : : INT ,  prefix  +  PNAME ( " point_index " ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										p_list - > push_back ( PropertyInfo ( Variant : : NODE_PATH ,  prefix  +  PNAME ( " spatial_attachment_path " ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										p_list - > push_back ( PropertyInfo ( Variant : : VECTOR3 ,  prefix  +  PNAME ( " offset " ) ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bool  SoftBody : : _set_property_pinned_points_indices ( const  Array  & p_indices )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									const  int  p_indices_size  =  p_indices . size ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									{  // Remove the pined points on physics server that will be removed by resize
 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										PoolVector < PinnedPoint > : : Read  r  =  pinned_points . read ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( p_indices_size  <  pinned_points . size ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											for  ( int  i  =  pinned_points . size ( )  -  1 ;  i  > =  p_indices_size ;  - - i )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
												pin_point ( r [ i ] . point_index ,  false ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									pinned_points . resize ( p_indices_size ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									PoolVector < PinnedPoint > : : Write  w  =  pinned_points . write ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									int  point_index ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( int  i  =  0 ;  i  <  p_indices_size ;  + + i )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										point_index  =  p_indices . get ( i ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( w [ i ] . point_index  ! =  point_index )  { 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if  ( - 1  ! =  w [ i ] . point_index )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
												pin_point ( w [ i ] . point_index ,  false ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											w [ i ] . point_index  =  point_index ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											pin_point ( w [ i ] . point_index ,  true ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bool  SoftBody : : _set_property_pinned_points_attachment ( int  p_item ,  const  String  & p_what ,  const  Variant  & p_value )  {  
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( pinned_points . size ( )  < =  p_item )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										return  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( " spatial_attachment_path "  = =  p_what )  { 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										PoolVector < PinnedPoint > : : Write  w  =  pinned_points . write ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										pin_point ( w [ p_item ] . point_index ,  true ,  p_value ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										_make_cache_dirty ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  else  if  ( " offset "  = =  p_what )  { 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										PoolVector < PinnedPoint > : : Write  w  =  pinned_points . write ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										w [ p_item ] . offset  =  p_value ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bool  SoftBody : : _get_property_pinned_points ( int  p_item ,  const  String  & p_what ,  Variant  & r_ret )  const  {  
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( pinned_points . size ( )  < =  p_item )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										return  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									PoolVector < PinnedPoint > : : Read  r  =  pinned_points . read ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( " point_index "  = =  p_what )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										r_ret  =  r [ p_item ] . point_index ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  else  if  ( " spatial_attachment_path "  = =  p_what )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										r_ret  =  r [ p_item ] . spatial_attachment_path ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									}  else  if  ( " offset "  = =  p_what )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										r_ret  =  r [ p_item ] . offset ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : _changed_callback ( Object  * p_changed ,  const  char  * p_prop )  {  
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									_prepare_physics_server ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									_reset_points_offsets ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# ifdef TOOLS_ENABLED 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( p_changed  = =  this )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										update_configuration_warning ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# endif 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : _notification ( int  p_what )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									switch  ( p_what )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										case  NOTIFICATION_ENTER_WORLD :  { 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if  ( Engine : : get_singleton ( ) - > is_editor_hint ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
												add_change_receptor ( this ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											RID  space  =  get_world ( ) - > get_space ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											PhysicsServer : : get_singleton ( ) - > soft_body_set_space ( physics_rid ,  space ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											_prepare_physics_server ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										}  break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										case  NOTIFICATION_READY :  { 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if  ( ! parent_collision_ignore . is_empty ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
												add_collision_exception_with ( get_node ( parent_collision_ignore ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										case  NOTIFICATION_TRANSFORM_CHANGED :  { 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if  ( Engine : : get_singleton ( ) - > is_editor_hint ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												_reset_points_offsets ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												return ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											PhysicsServer : : get_singleton ( ) - > soft_body_set_transform ( physics_rid ,  get_global_transform ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											set_notify_transform ( false ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											// Required to be top level with Transform at center of world in order to modify VisualServer only to support custom Transform
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											set_as_toplevel ( true ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											set_transform ( Transform ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											set_notify_transform ( true ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  break ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										case  NOTIFICATION_VISIBILITY_CHANGED :  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											_update_pickable ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										case  NOTIFICATION_EXIT_WORLD :  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											PhysicsServer : : get_singleton ( ) - > soft_body_set_space ( physics_rid ,  RID ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# ifdef TOOLS_ENABLED 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( p_what  = =  NOTIFICATION_LOCAL_TRANSFORM_CHANGED )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( Engine : : get_singleton ( ) - > is_editor_hint ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											update_configuration_warning ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# endif 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : _bind_methods ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " _draw_soft_mesh " ) ,  & SoftBody : : _draw_soft_mesh ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-22 11:32:21 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_physics_enabled " ,  " enabled " ) ,  & SoftBody : : set_physics_enabled ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " is_physics_enabled " ) ,  & SoftBody : : is_physics_enabled ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_collision_mask " ,  " collision_mask " ) ,  & SoftBody : : set_collision_mask ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_collision_mask " ) ,  & SoftBody : : get_collision_mask ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_collision_layer " ,  " collision_layer " ) ,  & SoftBody : : set_collision_layer ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_collision_layer " ) ,  & SoftBody : : get_collision_layer ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_collision_mask_bit " ,  " bit " ,  " value " ) ,  & SoftBody : : set_collision_mask_bit ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_collision_mask_bit " ,  " bit " ) ,  & SoftBody : : get_collision_mask_bit ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_collision_layer_bit " ,  " bit " ,  " value " ) ,  & SoftBody : : set_collision_layer_bit ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_collision_layer_bit " ,  " bit " ) ,  & SoftBody : : get_collision_layer_bit ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_parent_collision_ignore " ,  " parent_collision_ignore " ) ,  & SoftBody : : set_parent_collision_ignore ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_parent_collision_ignore " ) ,  & SoftBody : : get_parent_collision_ignore ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-10-24 16:32:55 -03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_collision_exceptions " ) ,  & SoftBody : : get_collision_exceptions ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " add_collision_exception_with " ,  " body " ) ,  & SoftBody : : add_collision_exception_with ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " remove_collision_exception_with " ,  " body " ) ,  & SoftBody : : remove_collision_exception_with ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_simulation_precision " ,  " simulation_precision " ) ,  & SoftBody : : set_simulation_precision ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_simulation_precision " ) ,  & SoftBody : : get_simulation_precision ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_total_mass " ,  " mass " ) ,  & SoftBody : : set_total_mass ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_total_mass " ) ,  & SoftBody : : get_total_mass ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_linear_stiffness " ,  " linear_stiffness " ) ,  & SoftBody : : set_linear_stiffness ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_linear_stiffness " ) ,  & SoftBody : : get_linear_stiffness ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_areaAngular_stiffness " ,  " areaAngular_stiffness " ) ,  & SoftBody : : set_areaAngular_stiffness ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_areaAngular_stiffness " ) ,  & SoftBody : : get_areaAngular_stiffness ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_volume_stiffness " ,  " volume_stiffness " ) ,  & SoftBody : : set_volume_stiffness ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_volume_stiffness " ) ,  & SoftBody : : get_volume_stiffness ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_pressure_coefficient " ,  " pressure_coefficient " ) ,  & SoftBody : : set_pressure_coefficient ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_pressure_coefficient " ) ,  & SoftBody : : get_pressure_coefficient ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_pose_matching_coefficient " ,  " pose_matching_coefficient " ) ,  & SoftBody : : set_pose_matching_coefficient ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_pose_matching_coefficient " ) ,  & SoftBody : : get_pose_matching_coefficient ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_damping_coefficient " ,  " damping_coefficient " ) ,  & SoftBody : : set_damping_coefficient ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_damping_coefficient " ) ,  & SoftBody : : get_damping_coefficient ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_drag_coefficient " ,  " drag_coefficient " ) ,  & SoftBody : : set_drag_coefficient ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_drag_coefficient " ) ,  & SoftBody : : get_drag_coefficient ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-09-17 11:25:31 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " get_point_transform " ,  " point_index " ) ,  & SoftBody : : get_point_transform ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_point_pinned " ,  " point_index " ,  " pinned " ,  " attachment_path " ) ,  & SoftBody : : pin_point ,  DEFVAL ( NodePath ( ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " is_point_pinned " ,  " point_index " ) ,  & SoftBody : : is_point_pinned ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " set_ray_pickable " ,  " ray_pickable " ) ,  & SoftBody : : set_ray_pickable ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ClassDB : : bind_method ( D_METHOD ( " is_ray_pickable " ) ,  & SoftBody : : is_ray_pickable ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-22 11:32:21 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : BOOL ,  " physics_enabled " ) ,  " set_physics_enabled " ,  " is_physics_enabled " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									ADD_GROUP ( " Collision " ,  " collision_ " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : INT ,  " collision_layer " ,  PROPERTY_HINT_LAYERS_3D_PHYSICS ) ,  " set_collision_layer " ,  " get_collision_layer " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : INT ,  " collision_mask " ,  PROPERTY_HINT_LAYERS_3D_PHYSICS ) ,  " set_collision_mask " ,  " get_collision_mask " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : NODE_PATH ,  " parent_collision_ignore " ,  PROPERTY_HINT_PROPERTY_OF_VARIANT_TYPE ,  " Parent collision object " ) ,  " set_parent_collision_ignore " ,  " get_parent_collision_ignore " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : INT ,  " simulation_precision " ,  PROPERTY_HINT_RANGE ,  " 1,100,1 " ) ,  " set_simulation_precision " ,  " get_simulation_precision " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : REAL ,  " total_mass " ,  PROPERTY_HINT_RANGE ,  " 0.01,10000,1 " ) ,  " set_total_mass " ,  " get_total_mass " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : REAL ,  " linear_stiffness " ,  PROPERTY_HINT_RANGE ,  " 0,1,0.01 " ) ,  " set_linear_stiffness " ,  " get_linear_stiffness " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : REAL ,  " areaAngular_stiffness " ,  PROPERTY_HINT_RANGE ,  " 0,1,0.01 " ) ,  " set_areaAngular_stiffness " ,  " get_areaAngular_stiffness " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : REAL ,  " volume_stiffness " ,  PROPERTY_HINT_RANGE ,  " 0,1,0.01 " ) ,  " set_volume_stiffness " ,  " get_volume_stiffness " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : REAL ,  " pressure_coefficient " ) ,  " set_pressure_coefficient " ,  " get_pressure_coefficient " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : REAL ,  " damping_coefficient " ,  PROPERTY_HINT_RANGE ,  " 0,1,0.01 " ) ,  " set_damping_coefficient " ,  " get_damping_coefficient " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : REAL ,  " drag_coefficient " ,  PROPERTY_HINT_RANGE ,  " 0,1,0.01 " ) ,  " set_drag_coefficient " ,  " get_drag_coefficient " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : REAL ,  " pose_matching_coefficient " ,  PROPERTY_HINT_RANGE ,  " 0,1,0.01 " ) ,  " set_pose_matching_coefficient " ,  " get_pose_matching_coefficient " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-31 16:29:41 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ADD_PROPERTY ( PropertyInfo ( Variant : : BOOL ,  " ray_pickable " ) ,  " set_ray_pickable " ,  " is_ray_pickable " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								String  SoftBody : : get_configuration_warning ( )  const  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									String  warning  =  MeshInstance : : get_configuration_warning ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( mesh . is_null ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( ! warning . empty ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											warning  + =  " \n \n " ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-03-25 01:54:29 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										warning  + =  TTR ( " This body will be ignored until you set a mesh. " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									Transform  t  =  get_transform ( ) ; 
							 
						 
					
						
							
								
									
										
										
											
												Fix many errors found by PVS-Studio
Fix errors 2, 3, 4, 6, 8, 9, 11, 12, 13, 14, and 15.
											 
										 
										
											2018-11-27 21:58:00 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ( ABS ( t . basis . get_axis ( 0 ) . length ( )  -  1.0 )  >  0.05  | |  ABS ( t . basis . get_axis ( 1 ) . length ( )  -  1.0 )  >  0.05  | |  ABS ( t . basis . get_axis ( 2 ) . length ( )  -  1.0 )  >  0.05 ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( ! warning . empty ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											warning  + =  " \n \n " ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-28 21:15:04 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										warning  + =  TTR ( " Size changes to SoftBody will be overridden by the physics engine when running. \n Change the size in children collision shapes instead. " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  warning ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-30 17:45:27 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								void  SoftBody : : _update_physics_server ( )  {  
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ! simulation_started )  { 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-30 17:45:27 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-30 17:45:27 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									_update_cache_pin_points_datas ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// Submit bone attachment
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									const  int  pinned_points_indices_size  =  pinned_points . size ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PoolVector < PinnedPoint > : : Read  r  =  pinned_points . read ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( int  i  =  0 ;  i  <  pinned_points_indices_size ;  + + i )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( r [ i ] . spatial_attachment )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											PhysicsServer : : get_singleton ( ) - > soft_body_move_point ( physics_rid ,  r [ i ] . point_index ,  r [ i ] . spatial_attachment - > get_global_transform ( ) . xform ( r [ i ] . offset ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : _draw_soft_mesh ( )  {  
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( mesh . is_null ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										return ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									RID  mesh_rid  =  mesh - > get_rid ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( owned_mesh  ! =  mesh_rid )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										_become_mesh_owner ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										mesh_rid  =  mesh - > get_rid ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										PhysicsServer : : get_singleton ( ) - > soft_body_set_mesh ( physics_rid ,  mesh ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-06 23:25:14 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ! visual_server_handler . is_ready ( mesh_rid ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										visual_server_handler . prepare ( mesh_rid ,  0 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/// Necessary in order to render the mesh correctly (Soft body nodes are in global space)
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										simulation_started  =  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										call_deferred ( " set_as_toplevel " ,  true ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										call_deferred ( " set_transform " ,  Transform ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-30 17:45:27 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									_update_physics_server ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									visual_server_handler . open ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_update_visual_server ( physics_rid ,  & visual_server_handler ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									visual_server_handler . close ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									visual_server_handler . commit_changes ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								void  SoftBody : : _prepare_physics_server ( )  {  
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( Engine : : get_singleton ( ) - > is_editor_hint ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( mesh . is_valid ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											PhysicsServer : : get_singleton ( ) - > soft_body_set_mesh ( physics_rid ,  mesh ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-04 16:00:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											PhysicsServer : : get_singleton ( ) - > soft_body_set_mesh ( physics_rid ,  nullptr ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										return ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( mesh . is_valid ( )  & &  physics_enabled )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( owned_mesh  ! =  mesh - > get_rid ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											_become_mesh_owner ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										PhysicsServer : : get_singleton ( ) - > soft_body_set_mesh ( physics_rid ,  mesh ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										VS : : get_singleton ( ) - > connect ( " frame_pre_draw " ,  this ,  " _draw_soft_mesh " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-04 16:00:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										PhysicsServer : : get_singleton ( ) - > soft_body_set_mesh ( physics_rid ,  nullptr ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-29 00:40:36 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( VS : : get_singleton ( ) - > is_connected ( " frame_pre_draw " ,  this ,  " _draw_soft_mesh " ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											VS : : get_singleton ( ) - > disconnect ( " frame_pre_draw " ,  this ,  " _draw_soft_mesh " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								void  SoftBody : : _become_mesh_owner ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									Vector < Ref < Material > >  copy_materials ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									copy_materials . append_array ( materials ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ERR_FAIL_COND ( ! mesh - > get_surface_count ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-28 20:32:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									// Get current mesh array and create new mesh array with necessary flag for softbody
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									Array  surface_arrays  =  mesh - > surface_get_arrays ( 0 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									Array  surface_blend_arrays  =  mesh - > surface_get_blend_shape_arrays ( 0 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									uint32_t  surface_format  =  mesh - > surface_get_format ( 0 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									surface_format  & =  ~ ( Mesh : : ARRAY_COMPRESS_VERTEX  |  Mesh : : ARRAY_COMPRESS_NORMAL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									surface_format  | =  Mesh : : ARRAY_FLAG_USE_DYNAMIC_UPDATE ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									Ref < ArrayMesh >  soft_mesh ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									soft_mesh . instance ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									soft_mesh - > add_surface_from_arrays ( Mesh : : PRIMITIVE_TRIANGLES ,  surface_arrays ,  surface_blend_arrays ,  surface_format ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									soft_mesh - > surface_set_material ( 0 ,  mesh - > surface_get_material ( 0 ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									set_mesh ( soft_mesh ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									for  ( int  i  =  copy_materials . size ( )  -  1 ;  0  < =  i ;  - - i )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										set_surface_material ( i ,  copy_materials [ i ] ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									owned_mesh  =  soft_mesh - > get_rid ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_collision_mask ( uint32_t  p_mask )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									collision_mask  =  p_mask ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_set_collision_mask ( physics_rid ,  p_mask ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								uint32_t  SoftBody : : get_collision_mask ( )  const  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  collision_mask ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_collision_layer ( uint32_t  p_layer )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									collision_layer  =  p_layer ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_set_collision_layer ( physics_rid ,  p_layer ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								uint32_t  SoftBody : : get_collision_layer ( )  const  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  collision_layer ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_collision_mask_bit ( int  p_bit ,  bool  p_value )  {  
						 
					
						
							
								
									
										
										
										
											2021-04-30 17:58:06 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ERR_FAIL_INDEX_MSG ( p_bit ,  32 ,  " Collision mask bit must be between 0 and 31 inclusive. " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									uint32_t  mask  =  get_collision_mask ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( p_value )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										mask  | =  1  < <  p_bit ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										mask  & =  ~ ( 1  < <  p_bit ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									set_collision_mask ( mask ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bool  SoftBody : : get_collision_mask_bit ( int  p_bit )  const  {  
						 
					
						
							
								
									
										
										
										
											2021-04-30 17:58:06 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ERR_FAIL_INDEX_V_MSG ( p_bit ,  32 ,  false ,  " Collision mask bit must be between 0 and 31 inclusive. " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									return  get_collision_mask ( )  &  ( 1  < <  p_bit ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_collision_layer_bit ( int  p_bit ,  bool  p_value )  {  
						 
					
						
							
								
									
										
										
										
											2021-04-30 17:58:06 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ERR_FAIL_INDEX_MSG ( p_bit ,  32 ,  " Collision layer bit must be between 0 and 31 inclusive. " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									uint32_t  layer  =  get_collision_layer ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( p_value )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										layer  | =  1  < <  p_bit ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										layer  & =  ~ ( 1  < <  p_bit ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									set_collision_layer ( layer ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bool  SoftBody : : get_collision_layer_bit ( int  p_bit )  const  {  
						 
					
						
							
								
									
										
										
										
											2021-04-30 17:58:06 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ERR_FAIL_INDEX_V_MSG ( p_bit ,  32 ,  false ,  " Collision layer bit must be between 0 and 31 inclusive. " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									return  get_collision_layer ( )  &  ( 1  < <  p_bit ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_parent_collision_ignore ( const  NodePath  & p_parent_collision_ignore )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									parent_collision_ignore  =  p_parent_collision_ignore ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const  NodePath  & SoftBody : : get_parent_collision_ignore ( )  const  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  parent_collision_ignore ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-22 11:32:21 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								void  SoftBody : : set_physics_enabled ( bool  p_enabled )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( p_enabled  = =  physics_enabled )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									physics_enabled  =  p_enabled ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( is_inside_tree ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2021-10-20 10:45:32 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										_prepare_physics_server ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-06-22 11:32:21 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bool  SoftBody : : is_physics_enabled ( )  const  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  physics_enabled ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_pinned_points_indices ( PoolVector < SoftBody : : PinnedPoint >  p_pinned_points_indices )  {  
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									pinned_points  =  p_pinned_points_indices ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PoolVector < PinnedPoint > : : Read  w  =  pinned_points . read ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( int  i  =  pinned_points . size ( )  -  1 ;  0  < =  i ;  - - i )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										pin_point ( p_pinned_points_indices [ i ] . point_index ,  true ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								PoolVector < SoftBody : : PinnedPoint >  SoftBody : : get_pinned_points_indices ( )  {  
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  pinned_points ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-10-24 16:32:55 -03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Array  SoftBody : : get_collision_exceptions ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									List < RID >  exceptions ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_get_collision_exceptions ( physics_rid ,  & exceptions ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									Array  ret ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( List < RID > : : Element  * E  =  exceptions . front ( ) ;  E ;  E  =  E - > next ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										RID  body  =  E - > get ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ObjectID  instance_id  =  PhysicsServer : : get_singleton ( ) - > body_get_object_instance_id ( body ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										Object  * obj  =  ObjectDB : : get_instance ( instance_id ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										PhysicsBody  * physics_body  =  Object : : cast_to < PhysicsBody > ( obj ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ret . append ( physics_body ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  ret ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : add_collision_exception_with ( Node  * p_node )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ERR_FAIL_NULL ( p_node ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									CollisionObject  * collision_object  =  Object : : cast_to < CollisionObject > ( p_node ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-19 17:37:42 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ERR_FAIL_COND_MSG ( ! collision_object ,  " Collision exception only works between two nodes that inherit from CollisionObject (such as Area or PhysicsBody). " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_add_collision_exception ( physics_rid ,  collision_object - > get_rid ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : remove_collision_exception_with ( Node  * p_node )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ERR_FAIL_NULL ( p_node ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									CollisionObject  * collision_object  =  Object : : cast_to < CollisionObject > ( p_node ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-19 17:37:42 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									ERR_FAIL_COND_MSG ( ! collision_object ,  " Collision exception only works between two nodes that inherit from CollisionObject (such as Area or PhysicsBody). " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_remove_collision_exception ( physics_rid ,  collision_object - > get_rid ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								int  SoftBody : : get_simulation_precision ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  PhysicsServer : : get_singleton ( ) - > soft_body_get_simulation_precision ( physics_rid ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_simulation_precision ( int  p_simulation_precision )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_set_simulation_precision ( physics_rid ,  p_simulation_precision ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								real_t  SoftBody : : get_total_mass ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  PhysicsServer : : get_singleton ( ) - > soft_body_get_total_mass ( physics_rid ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_total_mass ( real_t  p_total_mass )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_set_total_mass ( physics_rid ,  p_total_mass ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_linear_stiffness ( real_t  p_linear_stiffness )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_set_linear_stiffness ( physics_rid ,  p_linear_stiffness ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								real_t  SoftBody : : get_linear_stiffness ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  PhysicsServer : : get_singleton ( ) - > soft_body_get_linear_stiffness ( physics_rid ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_areaAngular_stiffness ( real_t  p_areaAngular_stiffness )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_set_areaAngular_stiffness ( physics_rid ,  p_areaAngular_stiffness ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								real_t  SoftBody : : get_areaAngular_stiffness ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  PhysicsServer : : get_singleton ( ) - > soft_body_get_areaAngular_stiffness ( physics_rid ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_volume_stiffness ( real_t  p_volume_stiffness )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_set_volume_stiffness ( physics_rid ,  p_volume_stiffness ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								real_t  SoftBody : : get_volume_stiffness ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  PhysicsServer : : get_singleton ( ) - > soft_body_get_volume_stiffness ( physics_rid ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								real_t  SoftBody : : get_pressure_coefficient ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  PhysicsServer : : get_singleton ( ) - > soft_body_get_pressure_coefficient ( physics_rid ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_pose_matching_coefficient ( real_t  p_pose_matching_coefficient )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_set_pose_matching_coefficient ( physics_rid ,  p_pose_matching_coefficient ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								real_t  SoftBody : : get_pose_matching_coefficient ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  PhysicsServer : : get_singleton ( ) - > soft_body_get_pose_matching_coefficient ( physics_rid ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_pressure_coefficient ( real_t  p_pressure_coefficient )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_set_pressure_coefficient ( physics_rid ,  p_pressure_coefficient ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								real_t  SoftBody : : get_damping_coefficient ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  PhysicsServer : : get_singleton ( ) - > soft_body_get_damping_coefficient ( physics_rid ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_damping_coefficient ( real_t  p_damping_coefficient )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_set_damping_coefficient ( physics_rid ,  p_damping_coefficient ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								real_t  SoftBody : : get_drag_coefficient ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  PhysicsServer : : get_singleton ( ) - > soft_body_get_drag_coefficient ( physics_rid ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_drag_coefficient ( real_t  p_drag_coefficient )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_set_drag_coefficient ( physics_rid ,  p_drag_coefficient ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Vector3  SoftBody : : get_point_transform ( int  p_point_index )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  PhysicsServer : : get_singleton ( ) - > soft_body_get_point_global_position ( physics_rid ,  p_point_index ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : pin_point_toggle ( int  p_point_index )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									pin_point ( p_point_index ,  ! ( - 1  ! =  _has_pinned_point ( p_point_index ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : pin_point ( int  p_point_index ,  bool  pin ,  const  NodePath  & p_spatial_attachment_path )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									_pin_point_on_physics_server ( p_point_index ,  pin ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( pin )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										_add_pinned_point ( p_point_index ,  p_spatial_attachment_path ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										_remove_pinned_point ( p_point_index ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bool  SoftBody : : is_point_pinned ( int  p_point_index )  const  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  - 1  ! =  _has_pinned_point ( p_point_index ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : set_ray_pickable ( bool  p_ray_pickable )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ray_pickable  =  p_ray_pickable ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									_update_pickable ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								bool  SoftBody : : is_ray_pickable ( )  const  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  ray_pickable ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								SoftBody : : SoftBody ( )  :  
						 
					
						
							
								
									
										
										
										
											2021-11-09 12:00:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										physics_rid ( RID_PRIME ( PhysicsServer : : get_singleton ( ) - > soft_body_create ( ) ) ) , 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										collision_mask ( 1 ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										collision_layer ( 1 ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										simulation_started ( false ) , 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-31 16:29:41 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										pinned_points_cache_dirty ( true ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ray_pickable ( true )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > body_attach_object_instance_id ( physics_rid ,  get_instance_id ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								SoftBody : : ~ SoftBody ( )  {  
						 
					
						
							
								
									
										
										
										
											2019-07-02 17:23:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > free ( physics_rid ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : reset_softbody_pin ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_remove_all_pinned_points ( physics_rid ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									PoolVector < PinnedPoint > : : Read  pps  =  pinned_points . read ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( int  i  =  pinned_points . size ( )  -  1 ;  0  <  i ;  - - i )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										PhysicsServer : : get_singleton ( ) - > soft_body_pin_point ( physics_rid ,  pps [ i ] . point_index ,  true ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								void  SoftBody : : _make_cache_dirty ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									pinned_points_cache_dirty  =  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								void  SoftBody : : _update_cache_pin_points_datas ( )  {  
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ! pinned_points_cache_dirty )  { 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									pinned_points_cache_dirty  =  false ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									PoolVector < PinnedPoint > : : Write  w  =  pinned_points . write ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( int  i  =  pinned_points . size ( )  -  1 ;  0  < =  i ;  - - i )  { 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( ! w [ i ] . spatial_attachment_path . is_empty ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											w [ i ] . spatial_attachment  =  Object : : cast_to < Spatial > ( get_node ( w [ i ] . spatial_attachment_path ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ! w [ i ] . spatial_attachment )  { 
							 
						 
					
						
							
								
									
										
										
										
											2020-11-20 09:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											ERR_PRINT ( " Spatial node not defined in the pinned point, this is undefined behavior for SoftBody! " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : _pin_point_on_physics_server ( int  p_point_index ,  bool  pin )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PhysicsServer : : get_singleton ( ) - > soft_body_pin_point ( physics_rid ,  p_point_index ,  pin ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : _add_pinned_point ( int  p_point_index ,  const  NodePath  & p_spatial_attachment_path )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SoftBody : : PinnedPoint  * pinned_point ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( - 1  = =  _get_pinned_point ( p_point_index ,  pinned_point ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// Create new
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										PinnedPoint  pp ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										pp . point_index  =  p_point_index ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										pp . spatial_attachment_path  =  p_spatial_attachment_path ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ! p_spatial_attachment_path . is_empty ( )  & &  has_node ( p_spatial_attachment_path ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											pp . spatial_attachment  =  Object : : cast_to < Spatial > ( get_node ( p_spatial_attachment_path ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											pp . offset  =  ( pp . spatial_attachment - > get_global_transform ( ) . affine_inverse ( )  *  get_global_transform ( ) ) . xform ( PhysicsServer : : get_singleton ( ) - > soft_body_get_point_global_position ( physics_rid ,  pp . point_index ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										pinned_points . push_back ( pp ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										pinned_point - > point_index  =  p_point_index ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										pinned_point - > spatial_attachment_path  =  p_spatial_attachment_path ; 
							 
						 
					
						
							
								
									
										
										
										
											2018-07-27 19:10:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( ! p_spatial_attachment_path . is_empty ( )  & &  has_node ( p_spatial_attachment_path ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											pinned_point - > spatial_attachment  =  Object : : cast_to < Spatial > ( get_node ( p_spatial_attachment_path ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											pinned_point - > offset  =  ( pinned_point - > spatial_attachment - > get_global_transform ( ) . affine_inverse ( )  *  get_global_transform ( ) ) . xform ( PhysicsServer : : get_singleton ( ) - > soft_body_get_point_global_position ( physics_rid ,  pinned_point - > point_index ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								void  SoftBody : : _reset_points_offsets ( )  {  
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( ! Engine : : get_singleton ( ) - > is_editor_hint ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										return ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PoolVector < PinnedPoint > : : Read  r  =  pinned_points . read ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									PoolVector < PinnedPoint > : : Write  w  =  pinned_points . write ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( int  i  =  pinned_points . size ( )  -  1 ;  0  < =  i ;  - - i )  { 
							 
						 
					
						
							
								
									
										
										
										
											2021-03-18 16:22:53 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( ! r [ i ] . spatial_attachment )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( ! r [ i ] . spatial_attachment_path . is_empty ( )  & &  has_node ( r [ i ] . spatial_attachment_path ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												w [ i ] . spatial_attachment  =  Object : : cast_to < Spatial > ( get_node ( r [ i ] . spatial_attachment_path ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if  ( ! r [ i ] . spatial_attachment )  { 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											continue ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-05 12:44:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										w [ i ] . offset  =  ( r [ i ] . spatial_attachment - > get_global_transform ( ) . affine_inverse ( )  *  get_global_transform ( ) ) . xform ( PhysicsServer : : get_singleton ( ) - > soft_body_get_point_global_position ( physics_rid ,  r [ i ] . point_index ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								void  SoftBody : : _remove_pinned_point ( int  p_point_index )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									const  int  id ( _has_pinned_point ( p_point_index ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( - 1  ! =  id )  { 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										pinned_points . remove ( id ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								int  SoftBody : : _get_pinned_point ( int  p_point_index ,  SoftBody : : PinnedPoint  * & r_point )  const  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									const  int  id  =  _has_pinned_point ( p_point_index ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( - 1  = =  id )  { 
							 
						 
					
						
							
								
									
										
										
										
											2021-05-04 16:00:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										r_point  =  nullptr ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										return  - 1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										r_point  =  const_cast < SoftBody : : PinnedPoint  * > ( & pinned_points . read ( ) [ id ] ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										return  id ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								int  SoftBody : : _has_pinned_point ( int  p_point_index )  const  {  
						 
					
						
							
								
									
										
										
										
											2018-08-03 17:44:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									PoolVector < PinnedPoint > : : Read  r  =  pinned_points . read ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  ( int  i  =  pinned_points . size ( )  -  1 ;  0  < =  i ;  - - i )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-21 01:36:32 +01:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										if  ( p_point_index  = =  r [ i ] . point_index )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											return  i ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  - 1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}