2015-08-16 18:55:02 +12:00
|
|
|
#include "coordinateconverter.hpp"
|
|
|
|
|
|
|
|
#include <components/esm/loadcell.hpp>
|
|
|
|
#include <components/esm/loadland.hpp>
|
|
|
|
|
|
|
|
namespace MWMechanics
|
|
|
|
{
|
|
|
|
CoordinateConverter::CoordinateConverter(const ESM::Cell* cell)
|
|
|
|
: mCellX(0), mCellY(0)
|
|
|
|
{
|
|
|
|
if (cell->isExterior())
|
|
|
|
{
|
|
|
|
mCellX = cell->mData.mX * ESM::Land::REAL_SIZE;
|
|
|
|
mCellY = cell->mData.mY * ESM::Land::REAL_SIZE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-09-12 14:17:46 +12:00
|
|
|
void CoordinateConverter::toWorld(ESM::Pathgrid::Point& point)
|
2015-08-16 18:55:02 +12:00
|
|
|
{
|
|
|
|
point.mX += mCellX;
|
|
|
|
point.mY += mCellY;
|
|
|
|
}
|
|
|
|
|
2015-09-12 14:17:46 +12:00
|
|
|
void CoordinateConverter::toWorld(osg::Vec3f& point)
|
2015-08-16 18:55:02 +12:00
|
|
|
{
|
|
|
|
point.x() += static_cast<float>(mCellX);
|
|
|
|
point.y() += static_cast<float>(mCellY);
|
|
|
|
}
|
|
|
|
|
2015-09-12 14:17:46 +12:00
|
|
|
void CoordinateConverter::toLocal(osg::Vec3f& point)
|
2015-08-16 18:55:02 +12:00
|
|
|
{
|
|
|
|
point.x() -= static_cast<float>(mCellX);
|
|
|
|
point.y() -= static_cast<float>(mCellY);
|
|
|
|
}
|
|
|
|
|
2015-09-12 14:17:46 +12:00
|
|
|
osg::Vec3f CoordinateConverter::toLocalVec3(const ESM::Pathgrid::Point& point)
|
2015-08-16 18:55:02 +12:00
|
|
|
{
|
|
|
|
return osg::Vec3f(
|
|
|
|
static_cast<float>(point.mX - mCellX),
|
|
|
|
static_cast<float>(point.mY - mCellY),
|
|
|
|
static_cast<float>(point.mZ));
|
|
|
|
}
|
|
|
|
}
|