Added room objects to store placed objects in rooms
This commit is contained in:
@@ -19,6 +19,7 @@ RoomPropertiesDialog::RoomPropertiesDialog(Room &room, ProjectTreeModel &project
|
||||
m_ui{std::make_unique<Ui::RoomPropertiesDialog>()},
|
||||
m_room{room},
|
||||
m_projectModel{projectModel},
|
||||
m_objects{m_room.objects},
|
||||
m_scene{std::make_unique<RoomScene>(this)},
|
||||
m_creationCode{m_room.creationCode},
|
||||
m_spinBoxSnapX{new QSpinBox{this}},
|
||||
@@ -31,6 +32,7 @@ RoomPropertiesDialog::RoomPropertiesDialog(Room &room, ProjectTreeModel &project
|
||||
|
||||
updateTitle();
|
||||
|
||||
m_ui->roomEditWidget->setObjects(&m_objects);
|
||||
m_ui->roomEditWidget->setFixedWidth(m_room.width);
|
||||
m_ui->roomEditWidget->setFixedHeight(m_room.height);
|
||||
m_ui->roomEditWidget->setSnapX(m_room.snapX);
|
||||
@@ -181,6 +183,8 @@ RoomPropertiesDialog::RoomPropertiesDialog(Room &room, ProjectTreeModel &project
|
||||
m_ui->actionIsometricGrid, &QAction::setChecked);
|
||||
connect(m_ui->roomEditWidget, &RoomEditWidget::cursorMoved,
|
||||
this, &RoomPropertiesDialog::cursorMoved);
|
||||
connect(m_ui->roomEditWidget, &RoomEditWidget::changed,
|
||||
this, &RoomPropertiesDialog::changed);
|
||||
|
||||
connect(m_menuObjects, &QMenu::aboutToShow,
|
||||
this, &RoomPropertiesDialog::objectsMenuAboutToShow);
|
||||
@@ -219,6 +223,8 @@ void RoomPropertiesDialog::accept()
|
||||
m_room.gridEnabled = m_ui->actionGridEnabled->isChecked();
|
||||
m_room.isometricGrid = m_ui->actionIsometricGrid->isChecked();
|
||||
|
||||
m_room.objects = m_objects;
|
||||
|
||||
QDialog::accept();
|
||||
}
|
||||
|
||||
|
@@ -4,6 +4,8 @@
|
||||
|
||||
#include <memory>
|
||||
|
||||
#include "projectcontainer.h"
|
||||
|
||||
class QSpinBox;
|
||||
class QLabel;
|
||||
class QMenu;
|
||||
@@ -56,6 +58,8 @@ private:
|
||||
Room &m_room;
|
||||
ProjectTreeModel &m_projectModel;
|
||||
|
||||
std::vector<Room::Object> m_objects;
|
||||
|
||||
const std::unique_ptr<RoomScene> m_scene;
|
||||
|
||||
QString m_creationCode;
|
||||
|
@@ -17,6 +17,11 @@ RoomEditWidget::RoomEditWidget(QWidget *parent) :
|
||||
setFixedSize(640, 480);
|
||||
}
|
||||
|
||||
void RoomEditWidget::setObjects(std::vector<Room::Object> *objects)
|
||||
{
|
||||
m_objects = objects;
|
||||
}
|
||||
|
||||
void RoomEditWidget::setSnapX(int snapX)
|
||||
{
|
||||
if (m_snapX == snapX)
|
||||
@@ -92,33 +97,8 @@ void RoomEditWidget::paintEvent(QPaintEvent *event)
|
||||
|
||||
QPainter painter{this};
|
||||
|
||||
if (m_draggedObject)
|
||||
{
|
||||
if (m_projectTreeModel)
|
||||
{
|
||||
QPixmap pixmap;
|
||||
const auto &object = m_draggedObject->object.get();
|
||||
if (!object.spriteName.isEmpty())
|
||||
{
|
||||
const auto iter = std::find_if(std::cbegin(m_projectTreeModel->project()->sprites), std::cend(m_projectTreeModel->project()->sprites),
|
||||
[&object](const auto &sprite){ return object.spriteName == sprite.name; });
|
||||
if (iter == std::cend(m_projectTreeModel->project()->sprites))
|
||||
qWarning() << "invalid sprite" << object.spriteName;
|
||||
else if (!iter->pixmaps.empty() && !iter->pixmaps.front().isNull())
|
||||
pixmap = iter->pixmaps.front();
|
||||
}
|
||||
|
||||
if (pixmap.isNull())
|
||||
goto noPixmap;
|
||||
|
||||
painter.drawPixmap(m_draggedObject->pos, std::move(pixmap));
|
||||
}
|
||||
else
|
||||
{
|
||||
noPixmap:
|
||||
painter.drawRect(QRect{m_draggedObject->pos, QSize{64, 64}});
|
||||
}
|
||||
}
|
||||
paintObjects(painter);
|
||||
paintDraggedObject(painter);
|
||||
|
||||
if (m_gridBrush)
|
||||
painter.fillRect(rect(), m_gridBrush->brush);
|
||||
@@ -132,7 +112,7 @@ void RoomEditWidget::mousePressEvent(QMouseEvent *event)
|
||||
{
|
||||
m_draggedObject = DraggedObject {
|
||||
.object = *m_selectedObject,
|
||||
.pos = event->pos()
|
||||
.pos = snapPoint(event->pos())
|
||||
};
|
||||
update();
|
||||
}
|
||||
@@ -144,6 +124,16 @@ void RoomEditWidget::mouseReleaseEvent(QMouseEvent *event)
|
||||
|
||||
if (m_draggedObject)
|
||||
{
|
||||
if (m_objects)
|
||||
{
|
||||
m_objects->emplace_back(Room::Object{
|
||||
.objectName = m_draggedObject->object.get().name,
|
||||
.pos = snapPoint(event->pos())
|
||||
});
|
||||
|
||||
emit changed();
|
||||
}
|
||||
|
||||
m_draggedObject = std::nullopt;
|
||||
update();
|
||||
}
|
||||
@@ -153,17 +143,16 @@ void RoomEditWidget::mouseMoveEvent(QMouseEvent *event)
|
||||
{
|
||||
QWidget::mouseMoveEvent(event);
|
||||
|
||||
emit cursorMoved(snapPoint(event->pos()));
|
||||
const auto snappedPos = snapPoint(event->pos());
|
||||
|
||||
emit cursorMoved(snappedPos);
|
||||
|
||||
if (m_draggedObject)
|
||||
{
|
||||
const auto newPos = snapPoint(event->pos());
|
||||
if (newPos != m_draggedObject->pos)
|
||||
if (snappedPos != m_draggedObject->pos)
|
||||
{
|
||||
m_draggedObject->pos = newPos;
|
||||
m_draggedObject->pos = snappedPos;
|
||||
update();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
QPoint RoomEditWidget::snapPoint(const QPoint &point) const
|
||||
@@ -173,3 +162,81 @@ QPoint RoomEditWidget::snapPoint(const QPoint &point) const
|
||||
m_snapY > 1 ? ((point.y() + (m_snapY / 2)) / m_snapY * m_snapY) : point.y(),
|
||||
};
|
||||
}
|
||||
|
||||
void RoomEditWidget::paintObjects(QPainter &painter)
|
||||
{
|
||||
if (!m_objects)
|
||||
return;
|
||||
|
||||
for (const Room::Object &object : *m_objects)
|
||||
{
|
||||
if (m_projectTreeModel)
|
||||
{
|
||||
const auto iter = std::find_if(std::cbegin(m_projectTreeModel->project()->objects), std::cend(m_projectTreeModel->project()->objects),
|
||||
[&object](const auto &obj){ return object.objectName == obj.name; });
|
||||
if (iter == std::cend(m_projectTreeModel->project()->objects))
|
||||
{
|
||||
qWarning() << "invalid object" << object.objectName;
|
||||
goto noPixmap;
|
||||
}
|
||||
|
||||
if (iter->spriteName.isEmpty())
|
||||
goto noPixmap;
|
||||
|
||||
{
|
||||
const auto iter2 = std::find_if(std::cbegin(m_projectTreeModel->project()->sprites), std::cend(m_projectTreeModel->project()->sprites),
|
||||
[&object=*iter](const auto &sprite){ return object.spriteName == sprite.name; });
|
||||
|
||||
if (iter2 == std::cend(m_projectTreeModel->project()->sprites))
|
||||
{
|
||||
qWarning() << "invalid sprite" << iter->spriteName;
|
||||
goto noPixmap;
|
||||
}
|
||||
|
||||
if (iter2->pixmaps.empty() || iter2->pixmaps.front().isNull())
|
||||
goto noPixmap;
|
||||
|
||||
painter.drawPixmap(object.pos, iter2->pixmaps.front());
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
noPixmap:
|
||||
painter.drawRect(QRect{object.pos, QSize{64, 64}});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void RoomEditWidget::paintDraggedObject(QPainter &painter)
|
||||
{
|
||||
if (!m_draggedObject)
|
||||
return;
|
||||
|
||||
if (m_projectTreeModel)
|
||||
{
|
||||
const auto &object = m_draggedObject->object.get();
|
||||
|
||||
if (object.spriteName.isEmpty())
|
||||
goto noPixmap;
|
||||
|
||||
{
|
||||
const auto iter = std::find_if(std::cbegin(m_projectTreeModel->project()->sprites), std::cend(m_projectTreeModel->project()->sprites),
|
||||
[&object](const auto &sprite){ return object.spriteName == sprite.name; });
|
||||
if (iter == std::cend(m_projectTreeModel->project()->sprites))
|
||||
{
|
||||
qWarning() << "invalid sprite" << object.spriteName;
|
||||
goto noPixmap;
|
||||
}
|
||||
|
||||
if (iter->pixmaps.empty() || iter->pixmaps.front().isNull())
|
||||
goto noPixmap;
|
||||
|
||||
painter.drawPixmap(m_draggedObject->pos, iter->pixmaps.front());
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
noPixmap:
|
||||
painter.drawRect(QRect{m_draggedObject->pos, QSize{64, 64}});
|
||||
}
|
||||
}
|
||||
|
@@ -5,6 +5,8 @@
|
||||
|
||||
#include <optional>
|
||||
|
||||
#include "projectcontainer.h"
|
||||
|
||||
struct Object;
|
||||
class ProjectTreeModel;
|
||||
|
||||
@@ -19,6 +21,10 @@ class RoomEditWidget : public QWidget
|
||||
public:
|
||||
explicit RoomEditWidget(QWidget *parent = nullptr);
|
||||
|
||||
std::vector<Room::Object> *objects() { return m_objects; }
|
||||
const std::vector<Room::Object> *objects() const { return m_objects; }
|
||||
void setObjects(std::vector<Room::Object> *objects);
|
||||
|
||||
int snapX() const { return m_snapX; }
|
||||
void setSnapX(int snapX);
|
||||
|
||||
@@ -49,6 +55,8 @@ signals:
|
||||
|
||||
void cursorMoved(const QPoint &point);
|
||||
|
||||
void changed();
|
||||
|
||||
protected:
|
||||
void paintEvent(QPaintEvent *event) override;
|
||||
void mousePressEvent(QMouseEvent *event) override;
|
||||
@@ -57,6 +65,10 @@ protected:
|
||||
|
||||
private:
|
||||
QPoint snapPoint(const QPoint &point) const;
|
||||
void paintObjects(QPainter &painter);
|
||||
void paintDraggedObject(QPainter &painter);
|
||||
|
||||
std::vector<Room::Object> *m_objects{};
|
||||
|
||||
int m_snapX{16};
|
||||
int m_snapY{16};
|
||||
|
@@ -322,6 +322,20 @@ QDataStream &operator>>(QDataStream &ds, Object &object)
|
||||
return ds;
|
||||
}
|
||||
|
||||
QDataStream &operator<<(QDataStream &ds, const Room::Object &object)
|
||||
{
|
||||
ds << object.objectName
|
||||
<< object.pos;
|
||||
return ds;
|
||||
}
|
||||
|
||||
QDataStream &operator>>(QDataStream &ds, Room::Object &object)
|
||||
{
|
||||
ds >> object.objectName
|
||||
>> object.pos;
|
||||
return ds;
|
||||
}
|
||||
|
||||
QDataStream &operator<<(QDataStream &ds, const Room &room)
|
||||
{
|
||||
ds << room.name
|
||||
@@ -334,7 +348,8 @@ QDataStream &operator<<(QDataStream &ds, const Room &room)
|
||||
<< room.snapX
|
||||
<< room.snapY
|
||||
<< room.gridEnabled
|
||||
<< room.isometricGrid;
|
||||
<< room.isometricGrid
|
||||
<< room.objects;
|
||||
return ds;
|
||||
}
|
||||
|
||||
@@ -350,7 +365,8 @@ QDataStream &operator>>(QDataStream &ds, Room &room)
|
||||
>> room.snapX
|
||||
>> room.snapY
|
||||
>> room.gridEnabled
|
||||
>> room.isometricGrid;
|
||||
>> room.isometricGrid
|
||||
>> room.objects;
|
||||
return ds;
|
||||
}
|
||||
|
||||
|
@@ -140,6 +140,13 @@ struct Room
|
||||
int snapY{16};
|
||||
bool gridEnabled{true};
|
||||
bool isometricGrid{};
|
||||
|
||||
struct Object {
|
||||
QString objectName;
|
||||
QPoint pos;
|
||||
};
|
||||
|
||||
std::vector<Object> objects;
|
||||
};
|
||||
|
||||
struct ProjectContainer
|
||||
|
Reference in New Issue
Block a user