2020-06-11 23:23:30 +02:00
|
|
|
#ifndef OPENMW_COMPONENTS_MISC_COORDINATECONVERTER_H
|
|
|
|
#define OPENMW_COMPONENTS_MISC_COORDINATECONVERTER_H
|
|
|
|
|
2023-01-27 18:40:15 +01:00
|
|
|
#include <components/esm/esmbridge.hpp>
|
2022-01-22 15:58:41 +01:00
|
|
|
#include <components/esm3/loadcell.hpp>
|
|
|
|
#include <components/esm3/loadpgrd.hpp>
|
2023-01-27 01:13:17 +01:00
|
|
|
#include <components/esm4/loadcell.hpp>
|
2023-08-12 16:09:17 +02:00
|
|
|
#include <components/misc/constants.hpp>
|
2020-06-11 23:23:30 +02:00
|
|
|
|
|
|
|
namespace Misc
|
|
|
|
{
|
|
|
|
/// \brief convert coordinates between world and local cell
|
|
|
|
class CoordinateConverter
|
|
|
|
{
|
|
|
|
public:
|
2023-08-12 16:09:17 +02:00
|
|
|
explicit CoordinateConverter(int cellX, int cellY)
|
|
|
|
: mCellX(cellX)
|
|
|
|
, mCellY(cellY)
|
2023-01-28 12:07:47 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2020-06-11 23:23:30 +02:00
|
|
|
/// in-place conversion from local to world
|
|
|
|
void toWorld(ESM::Pathgrid::Point& point) const
|
|
|
|
{
|
|
|
|
point.mX += mCellX;
|
|
|
|
point.mY += mCellY;
|
|
|
|
}
|
|
|
|
|
2023-01-23 21:06:50 +01:00
|
|
|
/// in-place conversion from world to local
|
|
|
|
void toLocal(ESM::Pathgrid::Point& point) const
|
|
|
|
{
|
|
|
|
point.mX -= mCellX;
|
|
|
|
point.mY -= mCellY;
|
|
|
|
}
|
|
|
|
|
2020-06-11 23:23:30 +02:00
|
|
|
ESM::Pathgrid::Point toWorldPoint(ESM::Pathgrid::Point point) const
|
|
|
|
{
|
|
|
|
toWorld(point);
|
|
|
|
return point;
|
|
|
|
}
|
|
|
|
|
2023-01-23 21:06:50 +01:00
|
|
|
ESM::Pathgrid::Point toLocalPoint(ESM::Pathgrid::Point point) const
|
|
|
|
{
|
|
|
|
toLocal(point);
|
|
|
|
return point;
|
|
|
|
}
|
|
|
|
|
2020-06-11 23:23:30 +02:00
|
|
|
/// in-place conversion from local to world
|
|
|
|
void toWorld(osg::Vec3f& point) const
|
|
|
|
{
|
|
|
|
point.x() += static_cast<float>(mCellX);
|
|
|
|
point.y() += static_cast<float>(mCellY);
|
|
|
|
}
|
|
|
|
|
|
|
|
/// in-place conversion from world to local
|
|
|
|
void toLocal(osg::Vec3f& point) const
|
|
|
|
{
|
|
|
|
point.x() -= static_cast<float>(mCellX);
|
|
|
|
point.y() -= static_cast<float>(mCellY);
|
|
|
|
}
|
|
|
|
|
|
|
|
osg::Vec3f toLocalVec3(const osg::Vec3f& point) const
|
|
|
|
{
|
|
|
|
return osg::Vec3f(
|
|
|
|
point.x() - static_cast<float>(mCellX), point.y() - static_cast<float>(mCellY), point.z());
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
int mCellX;
|
|
|
|
int mCellY;
|
|
|
|
};
|
2023-08-12 16:09:17 +02:00
|
|
|
|
|
|
|
template <class T>
|
|
|
|
CoordinateConverter makeCoordinateConverterImpl(const T& cell)
|
|
|
|
{
|
|
|
|
if (cell.isExterior())
|
|
|
|
return CoordinateConverter(cell.sSize * cell.getGridX(), cell.sSize * cell.getGridY());
|
|
|
|
return CoordinateConverter(0, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline CoordinateConverter makeCoordinateConverter(const ESM::Cell& cell)
|
|
|
|
{
|
|
|
|
return makeCoordinateConverterImpl(cell);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline CoordinateConverter makeCoordinateConverter(const ESM4::Cell& cell)
|
|
|
|
{
|
|
|
|
return makeCoordinateConverterImpl(cell);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline CoordinateConverter makeCoordinateConverter(const ESM::CellVariant& cell)
|
|
|
|
{
|
|
|
|
return visit([](const auto& v) { return makeCoordinateConverterImpl(v); }, cell);
|
|
|
|
}
|
2020-06-11 23:23:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|