2019-02-28 20:03:42 +00:00
|
|
|
#ifndef OPENMW_COMPONENTS_MISC_CONVERT_H
|
|
|
|
#define OPENMW_COMPONENTS_MISC_CONVERT_H
|
2015-05-12 01:02:15 +00:00
|
|
|
|
2024-02-27 19:47:46 +00:00
|
|
|
#include <components/esm/position.hpp>
|
2022-01-22 14:58:41 +00:00
|
|
|
#include <components/esm3/loadpgrd.hpp>
|
2020-06-11 21:23:30 +00:00
|
|
|
|
2022-09-22 18:26:05 +00:00
|
|
|
#include <LinearMath/btQuaternion.h>
|
2019-02-28 20:03:42 +00:00
|
|
|
#include <LinearMath/btTransform.h>
|
2015-05-12 01:02:15 +00:00
|
|
|
#include <LinearMath/btVector3.h>
|
|
|
|
#include <osg/Quat>
|
2022-09-22 18:26:05 +00:00
|
|
|
#include <osg/Vec3f>
|
2015-05-12 01:02:15 +00:00
|
|
|
|
2022-01-22 21:44:02 +00:00
|
|
|
namespace Misc::Convert
|
2015-05-12 01:02:15 +00:00
|
|
|
{
|
2019-02-28 20:03:42 +00:00
|
|
|
inline osg::Vec3f makeOsgVec3f(const float* values)
|
|
|
|
{
|
|
|
|
return osg::Vec3f(values[0], values[1], values[2]);
|
|
|
|
}
|
|
|
|
|
2020-06-11 21:23:30 +00:00
|
|
|
inline osg::Vec3f makeOsgVec3f(const ESM::Pathgrid::Point& value)
|
|
|
|
{
|
|
|
|
return osg::Vec3f(value.mX, value.mY, value.mZ);
|
|
|
|
}
|
|
|
|
|
2015-05-12 01:02:15 +00:00
|
|
|
inline btVector3 toBullet(const osg::Vec3f& vec)
|
|
|
|
{
|
|
|
|
return btVector3(vec.x(), vec.y(), vec.z());
|
|
|
|
}
|
|
|
|
|
|
|
|
inline btQuaternion toBullet(const osg::Quat& quat)
|
|
|
|
{
|
|
|
|
return btQuaternion(quat.x(), quat.y(), quat.z(), quat.w());
|
|
|
|
}
|
|
|
|
|
|
|
|
inline osg::Vec3f toOsg(const btVector3& vec)
|
|
|
|
{
|
|
|
|
return osg::Vec3f(vec.x(), vec.y(), vec.z());
|
|
|
|
}
|
|
|
|
|
|
|
|
inline osg::Quat toOsg(const btQuaternion& quat)
|
|
|
|
{
|
|
|
|
return osg::Quat(quat.x(), quat.y(), quat.z(), quat.w());
|
|
|
|
}
|
2021-06-28 21:35:34 +00:00
|
|
|
|
|
|
|
inline osg::Quat makeOsgQuat(const float (&rotation)[3])
|
|
|
|
{
|
2022-09-22 18:26:05 +00:00
|
|
|
return osg::Quat(rotation[2], osg::Vec3f(0, 0, -1)) * osg::Quat(rotation[1], osg::Vec3f(0, -1, 0))
|
2021-06-28 21:35:34 +00:00
|
|
|
* osg::Quat(rotation[0], osg::Vec3f(-1, 0, 0));
|
|
|
|
}
|
|
|
|
|
|
|
|
inline osg::Quat makeOsgQuat(const ESM::Position& position)
|
|
|
|
{
|
|
|
|
return makeOsgQuat(position.rot);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline btQuaternion makeBulletQuaternion(const float (&rotation)[3])
|
|
|
|
{
|
2022-09-22 18:26:05 +00:00
|
|
|
return btQuaternion(btVector3(0, 0, -1), rotation[2]) * btQuaternion(btVector3(0, -1, 0), rotation[1])
|
2021-06-28 21:35:34 +00:00
|
|
|
* btQuaternion(btVector3(-1, 0, 0), rotation[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline btQuaternion makeBulletQuaternion(const ESM::Position& position)
|
|
|
|
{
|
|
|
|
return makeBulletQuaternion(position.rot);
|
|
|
|
}
|
2021-11-04 00:57:27 +00:00
|
|
|
|
|
|
|
inline btTransform makeBulletTransform(const ESM::Position& position)
|
|
|
|
{
|
|
|
|
return btTransform(makeBulletQuaternion(position), toBullet(position.asVec3()));
|
|
|
|
}
|
2022-01-31 23:22:53 +00:00
|
|
|
|
|
|
|
inline osg::Vec2f toOsgXY(const btVector3& value)
|
|
|
|
{
|
|
|
|
return osg::Vec2f(static_cast<float>(value.x()), static_cast<float>(value.y()));
|
|
|
|
}
|
2019-02-28 20:03:42 +00:00
|
|
|
}
|
2015-05-12 01:02:15 +00:00
|
|
|
|
2022-01-31 23:22:53 +00:00
|
|
|
#endif
|