Panda3D
Loading...
Searching...
No Matches
physxShapeDesc.cxx
Go to the documentation of this file.
1/**
2 * PANDA 3D SOFTWARE
3 * Copyright (c) Carnegie Mellon University. All rights reserved.
4 *
5 * All use of this software is subject to the terms of the revised BSD
6 * license. You should have received a copy of this license along
7 * with this source code in a file named "LICENSE."
8 *
9 * @file physxShapeDesc.cxx
10 * @author enn0x
11 * @date 2009-09-08
12 */
13
14#include "physxShapeDesc.h"
15#include "physxManager.h"
16#include "physxMaterial.h"
17
18/**
19 * Sets a possible debug name.
20 */
22set_name(const char *name) {
23
24 _name = name ? name : "";
25 ptr()->name = _name.c_str();
26}
27
28/**
29 * This shape will become a trigger shape if this parameter is set to TRUE. It
30 * won't take part in collisions, but trigger events if some other shape
31 * passes through it.
32 */
34set_trigger(bool value) {
35
36 if (value == true) {
37 ptr()->shapeFlags |= NX_TRIGGER_ENABLE;
38 }
39 else {
40 ptr()->shapeFlags &= ~(NX_TRIGGER_ENABLE);
41 }
42}
43
44/**
45 *
46 */
47void PhysxShapeDesc::
48set_local_pos(const LPoint3f &pos) {
49
50 nassertv(!pos.is_nan());
51 ptr()->localPose.t = PhysxManager::point3_to_nxVec3(pos);
52}
53
54/**
55 *
56 */
57void PhysxShapeDesc::
58set_local_mat(const LMatrix4f &mat) {
59
60 nassertv(!mat.is_nan());
61 ptr()->localPose = PhysxManager::mat4_to_nxMat34(mat);
62}
63
64/**
65 *
66 */
67void PhysxShapeDesc::
68set_local_hpr(float h, float p, float r) {
69
70 LQuaternionf q;
71 LMatrix3f rot;
72 NxMat34 m;
73
74 q.set_hpr(LVector3f(h, p, r));
75 q.extract_to_matrix(rot);
76
77 ptr()->localPose.M = PhysxManager::mat3_to_nxMat33(rot);
78}
79
80/**
81 * Specifies by how much shapes can interpenetrate.
82 *
83 * Two shapes will interpenetrate by the sum of their skin widths. This means
84 * that their graphical representations should be adjusted so that they just
85 * touch when the shapes are interpenetrating.
86 *
87 * The default skin width is the 'physx-skin-width' parameter.
88 *
89 * A skin width sum of zero for two bodies is not permitted because it will
90 * lead to an unstable simulation.
91 *
92 * If your simulation jitters because resting bodies occasionally lose
93 * contact, increasing the size of your collision volumes and the skin width
94 * may improve things.
95 */
97set_skin_width(float skinWidth) {
98
99 nassertv(skinWidth >= 0.0f);
100 ptr()->skinWidth = skinWidth;
101}
102
103/**
104 *
105 */
106void PhysxShapeDesc::
107set_shape_flag(const PhysxShapeFlag flag, bool value) {
108
109 if (value == true) {
110 ptr()->shapeFlags |= flag;
111 }
112 else {
113 ptr()->shapeFlags &= ~(flag);
114 }
115}
116
117/**
118 * Sets the mass of this individual shape when computing mass inertial
119 * properties for a rigidbody. When mass<=0.0 then density and volume
120 * determine the mass. Note that this will only be used if the body has a
121 * zero inertia tensor, or if you call PhysxActor::update_mass_from_shapes
122 * explicitly.
123 */
125set_mass(float mass) {
126
127 ptr()->mass = mass;
128}
129
130/**
131 * Sets the density of this individual shape when computing mass inertial
132 * properties for a rigidbody (unless a valid mass >0.0 is provided). Note
133 * that this will only be used if the body has a zero inertia tensor, or if
134 * you call PhysxActor::update_mass_from_shapes explicitly.
135 */
137set_density(float density) {
138
139 nassertv(density > 0.0f);
140 ptr()->density = density;
141}
142
143/**
144 *
145 */
146void PhysxShapeDesc::
147set_group(unsigned short group) {
148
149 ptr()->group = group;
150}
151
152/**
153 *
154 */
155const char *PhysxShapeDesc::
156get_name() const {
157
158 return ptr()->name;
159}
160
161/**
162 *
163 */
164LPoint3f PhysxShapeDesc::
165get_local_pos() const {
166
167 return PhysxManager::nxVec3_to_point3(ptr()->localPose.t);
168}
169
170/**
171 *
172 */
173LMatrix4f PhysxShapeDesc::
174get_local_mat() const {
175
176 return PhysxManager::nxMat34_to_mat4(ptr()->localPose);
177}
178
179/**
180 *
181 */
182float PhysxShapeDesc::
183get_skin_width() const {
184
185 return ptr()->skinWidth;
186}
187
188/**
189 *
190 */
191bool PhysxShapeDesc::
192get_shape_flag(const PhysxShapeFlag flag) const {
193
194 return (ptr()->shapeFlags & flag) ? true : false;
195}
196
197/**
198 *
199 */
200float PhysxShapeDesc::
201get_mass() const {
202
203 return ptr()->mass;
204}
205
206/**
207 *
208 */
209float PhysxShapeDesc::
210get_density() const {
211
212 return ptr()->density;
213}
214
215/**
216 *
217 */
218unsigned short PhysxShapeDesc::
219get_group() const {
220
221 return ptr()->group;
222}
223
224/**
225 *
226 */
227void PhysxShapeDesc::
228set_material(const PhysxMaterial &material) {
229
230 ptr()->materialIndex = material.ptr()->getMaterialIndex();
231}
232
233/**
234 *
235 */
236void PhysxShapeDesc::
237set_material_index(unsigned short index) {
238
239 ptr()->materialIndex = index;
240}
241
242/**
243 *
244 */
245unsigned short PhysxShapeDesc::
246get_material_index() const {
247
248 return ptr()->materialIndex;
249}
static NxVec3 point3_to_nxVec3(const LPoint3f &p)
Converts from LPoint3f to NxVec3.
static NxMat34 mat4_to_nxMat34(const LMatrix4f &m)
Converts from LMatrix4f to NxMat34.
static LPoint3f nxVec3_to_point3(const NxVec3 &p)
Converts from NxVec3 to LPoint3f.
static NxMat33 mat3_to_nxMat33(const LMatrix3f &m)
Converts from LMatrix3f to NxMat33.
static LMatrix4f nxMat34_to_mat4(const NxMat34 &m)
Converts from NxMat34 to LMatrix4f.
A class for describing a shape's surface properties.
void set_density(float density)
Sets the density of this individual shape when computing mass inertial properties for a rigidbody (un...
void set_mass(float mass)
Sets the mass of this individual shape when computing mass inertial properties for a rigidbody.
void set_skin_width(float skinWidth)
Specifies by how much shapes can interpenetrate.
void set_trigger(bool value)
This shape will become a trigger shape if this parameter is set to TRUE.
void set_name(const char *name)
Sets a possible debug name.
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.