mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-22 07:23:52 +00:00
120 lines
3.7 KiB
C++
120 lines
3.7 KiB
C++
#include "landcreator.hpp"
|
|
|
|
#include <limits>
|
|
|
|
#include <QLabel>
|
|
#include <QSpinBox>
|
|
|
|
#include "../../model/world/commands.hpp"
|
|
#include "../../model/world/idtable.hpp"
|
|
#include "../../model/world/land.hpp"
|
|
|
|
namespace CSVWorld
|
|
{
|
|
LandCreator::LandCreator(CSMWorld::Data& data, QUndoStack& undoStack, const CSMWorld::UniversalId& id)
|
|
: GenericCreator(data, undoStack, id)
|
|
, mXLabel(nullptr)
|
|
, mYLabel(nullptr)
|
|
, mX(nullptr)
|
|
, mY(nullptr)
|
|
{
|
|
const int MaxInt = std::numeric_limits<int>::max();
|
|
const int MinInt = std::numeric_limits<int>::min();
|
|
|
|
setManualEditing(false);
|
|
|
|
mXLabel = new QLabel("X: ");
|
|
mX = new QSpinBox();
|
|
mX->setMinimum(MinInt);
|
|
mX->setMaximum(MaxInt);
|
|
insertBeforeButtons(mXLabel, false);
|
|
insertBeforeButtons(mX, true);
|
|
|
|
mYLabel = new QLabel("Y: ");
|
|
mY = new QSpinBox();
|
|
mY->setMinimum(MinInt);
|
|
mY->setMaximum(MaxInt);
|
|
insertBeforeButtons(mYLabel, false);
|
|
insertBeforeButtons(mY, true);
|
|
|
|
connect (mX, SIGNAL(valueChanged(int)), this, SLOT(coordChanged(int)));
|
|
connect (mY, SIGNAL(valueChanged(int)), this, SLOT(coordChanged(int)));
|
|
}
|
|
|
|
void LandCreator::cloneMode(const std::string& originId, const CSMWorld::UniversalId::Type type)
|
|
{
|
|
GenericCreator::cloneMode(originId, type);
|
|
|
|
int x = 0, y = 0;
|
|
CSMWorld::Land::parseUniqueRecordId(originId, x, y);
|
|
|
|
mX->setValue(x);
|
|
mY->setValue(y);
|
|
}
|
|
|
|
void LandCreator::touch(const std::vector<CSMWorld::UniversalId>& ids)
|
|
{
|
|
// Combine multiple touch commands into one "macro" command
|
|
getUndoStack().beginMacro("Touch records");
|
|
|
|
CSMWorld::IdTable& lands = dynamic_cast<CSMWorld::IdTable&>(*getData().getTableModel(CSMWorld::UniversalId::Type_Lands));
|
|
CSMWorld::IdTable& ltexs = dynamic_cast<CSMWorld::IdTable&>(*getData().getTableModel(CSMWorld::UniversalId::Type_LandTextures));
|
|
for (const CSMWorld::UniversalId& uid : ids)
|
|
{
|
|
CSMWorld::TouchLandCommand* touchCmd = new CSMWorld::TouchLandCommand(lands, ltexs, uid.getId());
|
|
getUndoStack().push(touchCmd);
|
|
}
|
|
|
|
// Execute
|
|
getUndoStack().endMacro();
|
|
}
|
|
|
|
void LandCreator::focus()
|
|
{
|
|
mX->setFocus();
|
|
}
|
|
|
|
void LandCreator::reset()
|
|
{
|
|
GenericCreator::reset();
|
|
mX->setValue(0);
|
|
mY->setValue(0);
|
|
}
|
|
|
|
std::string LandCreator::getErrors() const
|
|
{
|
|
if (getData().getLand().searchId(getId()) >= 0)
|
|
return "A land with that name already exists.";
|
|
|
|
return "";
|
|
}
|
|
|
|
std::string LandCreator::getId() const
|
|
{
|
|
return CSMWorld::Land::createUniqueRecordId(mX->value(), mY->value());
|
|
}
|
|
|
|
void LandCreator::pushCommand(std::unique_ptr<CSMWorld::CreateCommand> command, const std::string& id)
|
|
{
|
|
if (mCloneMode)
|
|
{
|
|
CSMWorld::IdTable& lands = dynamic_cast<CSMWorld::IdTable&>(*getData().getTableModel(CSMWorld::UniversalId::Type_Lands));
|
|
CSMWorld::IdTable& ltexs = dynamic_cast<CSMWorld::IdTable&>(*getData().getTableModel(CSMWorld::UniversalId::Type_LandTextures));
|
|
|
|
getUndoStack().beginMacro(("Clone " + id).c_str());
|
|
getUndoStack().push(command.release());
|
|
|
|
CSMWorld::CopyLandTexturesCommand* ltexCopy = new CSMWorld::CopyLandTexturesCommand(lands, ltexs, getClonedId(), getId());
|
|
getUndoStack().push(ltexCopy);
|
|
|
|
getUndoStack().endMacro();
|
|
}
|
|
else
|
|
getUndoStack().push (command.release());
|
|
}
|
|
|
|
void LandCreator::coordChanged(int value)
|
|
{
|
|
update();
|
|
}
|
|
}
|