Fix warnings on MSVC
This commit is contained in:
parent
97cb72502d
commit
39aa39e385
|
@ -34,7 +34,7 @@ namespace reactphysics3d {
|
||||||
|
|
||||||
// Class declarations
|
// Class declarations
|
||||||
class ContactManifold;
|
class ContactManifold;
|
||||||
class ContactManifoldInfo;
|
struct ContactManifoldInfo;
|
||||||
struct ContactPointInfo;
|
struct ContactPointInfo;
|
||||||
class CollisionBody;
|
class CollisionBody;
|
||||||
class ContactPoint;
|
class ContactPoint;
|
||||||
|
|
|
@ -34,7 +34,7 @@
|
||||||
namespace reactphysics3d {
|
namespace reactphysics3d {
|
||||||
|
|
||||||
// Declarations
|
// Declarations
|
||||||
class ContactManifoldInfo;
|
struct ContactManifoldInfo;
|
||||||
struct NarrowPhaseInfoBatch;
|
struct NarrowPhaseInfoBatch;
|
||||||
class ConvexShape;
|
class ConvexShape;
|
||||||
class Profiler;
|
class Profiler;
|
||||||
|
|
|
@ -33,7 +33,7 @@
|
||||||
namespace reactphysics3d {
|
namespace reactphysics3d {
|
||||||
|
|
||||||
class CollisionDetectionSystem;
|
class CollisionDetectionSystem;
|
||||||
class ContactManifoldInfo;
|
struct ContactManifoldInfo;
|
||||||
class DefaultPoolAllocator;
|
class DefaultPoolAllocator;
|
||||||
class OverlappingPair;
|
class OverlappingPair;
|
||||||
struct NarrowPhaseInfoBatch;
|
struct NarrowPhaseInfoBatch;
|
||||||
|
|
|
@ -37,7 +37,7 @@ namespace reactphysics3d {
|
||||||
// Declarations
|
// Declarations
|
||||||
class CollisionShape;
|
class CollisionShape;
|
||||||
struct LastFrameCollisionInfo;
|
struct LastFrameCollisionInfo;
|
||||||
class ContactManifoldInfo;
|
struct ContactManifoldInfo;
|
||||||
struct ContactPointInfo;
|
struct ContactPointInfo;
|
||||||
|
|
||||||
// Struct NarrowPhaseInfoBatch
|
// Struct NarrowPhaseInfoBatch
|
||||||
|
|
|
@ -36,7 +36,7 @@ namespace reactphysics3d {
|
||||||
// Declarations
|
// Declarations
|
||||||
class CapsuleShape;
|
class CapsuleShape;
|
||||||
class SphereShape;
|
class SphereShape;
|
||||||
class ContactManifoldInfo;
|
struct ContactManifoldInfo;
|
||||||
struct NarrowPhaseInfoBatch;
|
struct NarrowPhaseInfoBatch;
|
||||||
class ConvexPolyhedronShape;
|
class ConvexPolyhedronShape;
|
||||||
class MemoryAllocator;
|
class MemoryAllocator;
|
||||||
|
|
|
@ -302,7 +302,7 @@ RP3D_FORCE_INLINE bool AABB::raycast(const Ray& ray, Vector3& hitPoint) const {
|
||||||
decimal tMin = decimal(0.0);
|
decimal tMin = decimal(0.0);
|
||||||
decimal tMax = DECIMAL_LARGEST;
|
decimal tMax = DECIMAL_LARGEST;
|
||||||
|
|
||||||
const decimal epsilon = 0.00001;
|
const decimal epsilon = decimal(0.00001);
|
||||||
|
|
||||||
const Vector3 rayDirection = ray.point2 - ray.point1;
|
const Vector3 rayDirection = ray.point2 - ray.point1;
|
||||||
|
|
||||||
|
|
|
@ -117,9 +117,6 @@ class HeightFieldShape : public ConcaveShape {
|
||||||
void getTriangleVerticesWithIndexPointer(int32 subPart, int32 triangleIndex,
|
void getTriangleVerticesWithIndexPointer(int32 subPart, int32 triangleIndex,
|
||||||
Vector3* outTriangleVertices) const;
|
Vector3* outTriangleVertices) const;
|
||||||
|
|
||||||
/// Return the closest inside integer grid value of a given floating grid value
|
|
||||||
int computeIntegerGridValue(decimal value) const;
|
|
||||||
|
|
||||||
/// Compute the min/max grid coords corresponding to the intersection of the AABB of the height field and the AABB to collide
|
/// Compute the min/max grid coords corresponding to the intersection of the AABB of the height field and the AABB to collide
|
||||||
void computeMinMaxGridCoordinates(int* minCoords, int* maxCoords, const AABB& aabbToCollide) const;
|
void computeMinMaxGridCoordinates(int* minCoords, int* maxCoords, const AABB& aabbToCollide) const;
|
||||||
|
|
||||||
|
@ -200,18 +197,13 @@ RP3D_FORCE_INLINE decimal HeightFieldShape::getHeightAt(int x, int y) const {
|
||||||
assert(y >= 0 && y < mNbRows);
|
assert(y >= 0 && y < mNbRows);
|
||||||
|
|
||||||
switch(mHeightDataType) {
|
switch(mHeightDataType) {
|
||||||
case HeightDataType::HEIGHT_FLOAT_TYPE : return ((float*)mHeightFieldData)[y * mNbColumns + x];
|
case HeightDataType::HEIGHT_FLOAT_TYPE : return decimal(((float*)mHeightFieldData)[y * mNbColumns + x]);
|
||||||
case HeightDataType::HEIGHT_DOUBLE_TYPE : return ((double*)mHeightFieldData)[y * mNbColumns + x];
|
case HeightDataType::HEIGHT_DOUBLE_TYPE : return decimal(((double*)mHeightFieldData)[y * mNbColumns + x]);
|
||||||
case HeightDataType::HEIGHT_INT_TYPE : return ((int*)mHeightFieldData)[y * mNbColumns + x] * mIntegerHeightScale;
|
case HeightDataType::HEIGHT_INT_TYPE : return decimal(((int*)mHeightFieldData)[y * mNbColumns + x] * mIntegerHeightScale);
|
||||||
default: assert(false); return 0;
|
default: assert(false); return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return the closest inside integer grid value of a given floating grid value
|
|
||||||
RP3D_FORCE_INLINE int HeightFieldShape::computeIntegerGridValue(decimal value) const {
|
|
||||||
return (value < decimal(0.0)) ? value - decimal(0.5) : value + decimal(0.5);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Compute the shape Id for a given triangle
|
// Compute the shape Id for a given triangle
|
||||||
RP3D_FORCE_INLINE uint32 HeightFieldShape::computeTriangleShapeId(uint32 iIndex, uint32 jIndex, uint32 secondTriangleIncrement) const {
|
RP3D_FORCE_INLINE uint32 HeightFieldShape::computeTriangleShapeId(uint32 iIndex, uint32 jIndex, uint32 secondTriangleIncrement) const {
|
||||||
|
|
||||||
|
|
|
@ -211,16 +211,23 @@ void HeightFieldShape::computeMinMaxGridCoordinates(int* minCoords, int* maxCoor
|
||||||
minPoint += translateVec;
|
minPoint += translateVec;
|
||||||
maxPoint += translateVec;
|
maxPoint += translateVec;
|
||||||
|
|
||||||
|
assert(minPoint.x >= 0);
|
||||||
|
assert(minPoint.y >= 0);
|
||||||
|
assert(minPoint.z >= 0);
|
||||||
|
assert(maxPoint.x >= 0);
|
||||||
|
assert(maxPoint.y >= 0);
|
||||||
|
assert(maxPoint.z >= 0);
|
||||||
|
|
||||||
// Convert the floating min/max coords of the AABB into closest integer
|
// Convert the floating min/max coords of the AABB into closest integer
|
||||||
// grid values (note that we use the closest grid coordinate that is out
|
// grid values (note that we use the closest grid coordinate that is out
|
||||||
// of the AABB)
|
// of the AABB)
|
||||||
minCoords[0] = computeIntegerGridValue(minPoint.x) - 1;
|
minCoords[0] = static_cast<int>(minPoint.x + 0.5) - 1;
|
||||||
minCoords[1] = computeIntegerGridValue(minPoint.y) - 1;
|
minCoords[1] = static_cast<int>(minPoint.y + 0.5) - 1;
|
||||||
minCoords[2] = computeIntegerGridValue(minPoint.z) - 1;
|
minCoords[2] = static_cast<int>(minPoint.z + 0.5) - 1;
|
||||||
|
|
||||||
maxCoords[0] = computeIntegerGridValue(maxPoint.x) + 1;
|
maxCoords[0] = static_cast<int>(maxPoint.x + 0.5) + 1;
|
||||||
maxCoords[1] = computeIntegerGridValue(maxPoint.y) + 1;
|
maxCoords[1] = static_cast<int>(maxPoint.y + 0.5) + 1;
|
||||||
maxCoords[2] = computeIntegerGridValue(maxPoint.z) + 1;
|
maxCoords[2] = static_cast<int>(maxPoint.z + 0.5) + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Raycast method with feedback information
|
// Raycast method with feedback information
|
||||||
|
|
|
@ -450,7 +450,7 @@ void CollisionDetectionSystem::computeConvexVsConcaveMiddlePhase(OverlappingPair
|
||||||
assert(!concaveShape->isConvex());
|
assert(!concaveShape->isConvex());
|
||||||
assert(overlappingPair.narrowPhaseAlgorithmType != NarrowPhaseAlgorithmType::None);
|
assert(overlappingPair.narrowPhaseAlgorithmType != NarrowPhaseAlgorithmType::None);
|
||||||
|
|
||||||
// Compute the convex shape AABB in the local-space of the convex shape
|
// Compute the convex shape AABB in the local-space of the concave shape
|
||||||
AABB aabb;
|
AABB aabb;
|
||||||
convexShape->computeAABB(aabb, convexToConcaveTransform);
|
convexShape->computeAABB(aabb, convexToConcaveTransform);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user