mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-20 09:23:52 +00:00
90 lines
2.6 KiB
C++
90 lines
2.6 KiB
C++
#include "heightfield.hpp"
|
|
|
|
#include <osg/Object>
|
|
|
|
#include <BulletCollision/CollisionShapes/btHeightfieldTerrainShape.h>
|
|
#include <BulletCollision/CollisionDispatch/btCollisionObject.h>
|
|
|
|
#include <LinearMath/btTransform.h>
|
|
|
|
#include <type_traits>
|
|
|
|
namespace
|
|
{
|
|
template <class T>
|
|
auto makeHeights(const T* heights, float sqrtVerts)
|
|
-> std::enable_if_t<std::is_same<btScalar, T>::value, std::vector<btScalar>>
|
|
{
|
|
return {};
|
|
}
|
|
|
|
template <class T>
|
|
auto makeHeights(const T* heights, float sqrtVerts)
|
|
-> std::enable_if_t<!std::is_same<btScalar, T>::value, std::vector<btScalar>>
|
|
{
|
|
return std::vector<btScalar>(heights, heights + static_cast<std::ptrdiff_t>(sqrtVerts * sqrtVerts));
|
|
}
|
|
|
|
template <class T>
|
|
auto getHeights(const T* floatHeights, const std::vector<btScalar>&)
|
|
-> std::enable_if_t<std::is_same<btScalar, T>::value, const btScalar*>
|
|
{
|
|
return floatHeights;
|
|
}
|
|
|
|
template <class T>
|
|
auto getHeights(const T*, const std::vector<btScalar>& btScalarHeights)
|
|
-> std::enable_if_t<!std::is_same<btScalar, T>::value, const btScalar*>
|
|
{
|
|
return btScalarHeights.data();
|
|
}
|
|
}
|
|
|
|
namespace MWPhysics
|
|
{
|
|
HeightField::HeightField(const float* heights, int x, int y, float triSize, float sqrtVerts, float minH, float maxH, const osg::Object* holdObject)
|
|
: mHeights(makeHeights(heights, sqrtVerts))
|
|
{
|
|
mShape = new btHeightfieldTerrainShape(
|
|
sqrtVerts, sqrtVerts,
|
|
getHeights(heights, mHeights),
|
|
1,
|
|
minH, maxH, 2,
|
|
PHY_FLOAT, false
|
|
);
|
|
mShape->setUseDiamondSubdivision(true);
|
|
mShape->setLocalScaling(btVector3(triSize, triSize, 1));
|
|
|
|
btTransform transform(btQuaternion::getIdentity(),
|
|
btVector3((x+0.5f) * triSize * (sqrtVerts-1),
|
|
(y+0.5f) * triSize * (sqrtVerts-1),
|
|
(maxH+minH)*0.5f));
|
|
|
|
mCollisionObject = new btCollisionObject;
|
|
mCollisionObject->setCollisionShape(mShape);
|
|
mCollisionObject->setWorldTransform(transform);
|
|
|
|
mHoldObject = holdObject;
|
|
}
|
|
|
|
HeightField::~HeightField()
|
|
{
|
|
delete mCollisionObject;
|
|
delete mShape;
|
|
}
|
|
|
|
btCollisionObject* HeightField::getCollisionObject()
|
|
{
|
|
return mCollisionObject;
|
|
}
|
|
|
|
const btCollisionObject* HeightField::getCollisionObject() const
|
|
{
|
|
return mCollisionObject;
|
|
}
|
|
|
|
const btHeightfieldTerrainShape* HeightField::getShape() const
|
|
{
|
|
return mShape;
|
|
}
|
|
}
|