|
|
@ -1136,8 +1136,8 @@ namespace CSMWorld
|
|
|
|
template <typename ESXRecordT>
|
|
|
|
template <typename ESXRecordT>
|
|
|
|
struct TeleportColumn : public Column<ESXRecordT>
|
|
|
|
struct TeleportColumn : public Column<ESXRecordT>
|
|
|
|
{
|
|
|
|
{
|
|
|
|
TeleportColumn()
|
|
|
|
TeleportColumn(int flags)
|
|
|
|
: Column<ESXRecordT>(Columns::ColumnId_Teleport, ColumnBase::Display_Boolean)
|
|
|
|
: Column<ESXRecordT>(Columns::ColumnId_Teleport, ColumnBase::Display_Boolean, flags)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -1165,6 +1165,8 @@ namespace CSMWorld
|
|
|
|
|
|
|
|
|
|
|
|
QVariant get(const Record<ESXRecordT>& record) const override
|
|
|
|
QVariant get(const Record<ESXRecordT>& record) const override
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!record.get().mTeleport)
|
|
|
|
|
|
|
|
return QVariant();
|
|
|
|
return QString::fromUtf8(record.get().mDestCell.c_str());
|
|
|
|
return QString::fromUtf8(record.get().mDestCell.c_str());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -1309,17 +1311,21 @@ namespace CSMWorld
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ESM::Position ESXRecordT::*mPosition;
|
|
|
|
ESM::Position ESXRecordT::*mPosition;
|
|
|
|
int mIndex;
|
|
|
|
int mIndex;
|
|
|
|
|
|
|
|
bool mIsDoor;
|
|
|
|
|
|
|
|
|
|
|
|
PosColumn(ESM::Position ESXRecordT::*position, int index, bool door)
|
|
|
|
PosColumn(ESM::Position ESXRecordT::*position, int index, bool door)
|
|
|
|
: Column<ESXRecordT>((door ? Columns::ColumnId_DoorPositionXPos : Columns::ColumnId_PositionXPos) + index,
|
|
|
|
: Column<ESXRecordT>((door ? Columns::ColumnId_DoorPositionXPos : Columns::ColumnId_PositionXPos) + index,
|
|
|
|
ColumnBase::Display_Float)
|
|
|
|
ColumnBase::Display_Float)
|
|
|
|
, mPosition(position)
|
|
|
|
, mPosition(position)
|
|
|
|
, mIndex(index)
|
|
|
|
, mIndex(index)
|
|
|
|
|
|
|
|
, mIsDoor(door)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
QVariant get(const Record<ESXRecordT>& record) const override
|
|
|
|
QVariant get(const Record<ESXRecordT>& record) const override
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!record.get().mTeleport && mIsDoor)
|
|
|
|
|
|
|
|
return QVariant();
|
|
|
|
const ESM::Position& position = record.get().*mPosition;
|
|
|
|
const ESM::Position& position = record.get().*mPosition;
|
|
|
|
return position.pos[mIndex];
|
|
|
|
return position.pos[mIndex];
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -1343,17 +1349,21 @@ namespace CSMWorld
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ESM::Position ESXRecordT::*mPosition;
|
|
|
|
ESM::Position ESXRecordT::*mPosition;
|
|
|
|
int mIndex;
|
|
|
|
int mIndex;
|
|
|
|
|
|
|
|
bool mIsDoor;
|
|
|
|
|
|
|
|
|
|
|
|
RotColumn(ESM::Position ESXRecordT::*position, int index, bool door)
|
|
|
|
RotColumn(ESM::Position ESXRecordT::*position, int index, bool door)
|
|
|
|
: Column<ESXRecordT>((door ? Columns::ColumnId_DoorPositionXRot : Columns::ColumnId_PositionXRot) + index,
|
|
|
|
: Column<ESXRecordT>((door ? Columns::ColumnId_DoorPositionXRot : Columns::ColumnId_PositionXRot) + index,
|
|
|
|
ColumnBase::Display_Double)
|
|
|
|
ColumnBase::Display_Double)
|
|
|
|
, mPosition(position)
|
|
|
|
, mPosition(position)
|
|
|
|
, mIndex(index)
|
|
|
|
, mIndex(index)
|
|
|
|
|
|
|
|
, mIsDoor(door)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
QVariant get(const Record<ESXRecordT>& record) const override
|
|
|
|
QVariant get(const Record<ESXRecordT>& record) const override
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!record.get().mTeleport && mIsDoor)
|
|
|
|
|
|
|
|
return QVariant();
|
|
|
|
const ESM::Position& position = record.get().*mPosition;
|
|
|
|
const ESM::Position& position = record.get().*mPosition;
|
|
|
|
return osg::RadiansToDegrees(position.rot[mIndex]);
|
|
|
|
return osg::RadiansToDegrees(position.rot[mIndex]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|