diff options
| author | Ben Boeckel <MathStuf@gmail.com> | 2008-05-26 01:32:07 +0000 |
|---|---|---|
| committer | Ben Boeckel <MathStuf@gmail.com> | 2008-05-26 01:32:07 +0000 |
| commit | ff8c440c3a2aeb0e1abc6f93e9dd7775533382ff (patch) | |
| tree | 302ac68425cecc61d429c64cf8676ad37d1d4f12 /pokemodr/models/MapModel.cpp | |
| parent | 7e3bf1853184f96eb5be47dd78ebe21fdc170a01 (diff) | |
| download | sigen-ff8c440c3a2aeb0e1abc6f93e9dd7775533382ff.tar.gz sigen-ff8c440c3a2aeb0e1abc6f93e9dd7775533382ff.tar.xz sigen-ff8c440c3a2aeb0e1abc6f93e9dd7775533382ff.zip | |
[FIX] Context menus added
[FIX] No more copy/cut/paste for objects; only available from context menus
[FIX] Can now add objects during runtime
git-svn-id: https://pokegen.svn.sourceforge.net/svnroot/pokegen/trunk@174 6ecfd1a5-f3ed-3746-8530-beee90d26b22
Diffstat (limited to 'pokemodr/models/MapModel.cpp')
| -rw-r--r-- | pokemodr/models/MapModel.cpp | 32 |
1 files changed, 27 insertions, 5 deletions
diff --git a/pokemodr/models/MapModel.cpp b/pokemodr/models/MapModel.cpp index 5a0e76a0..609c9a90 100644 --- a/pokemodr/models/MapModel.cpp +++ b/pokemodr/models/MapModel.cpp @@ -33,10 +33,12 @@ // Qt includes #include <QFile> +// KDE includes +#include <KMenu> + MapModel::MapModel(BaseModel* parent, Map* map) : GroupObjectModel(parent, map) { - setupData(); } MapModel::~MapModel() @@ -58,6 +60,12 @@ QVariant MapModel::data(int role) const QWidget* widget = new MapUI(static_cast<Map*>(m_object), NULL); return QVariant::fromValue(widget); } + else if (role == BaseModel::ContextMenuRole) + { + KMenu* menu = new KMenu; + menu->addAction("Delete Map", this, SLOT(deleteSelf())); + return QVariant::fromValue(static_cast<void*>(menu)); + } return GroupObjectModel::data(role); } @@ -85,10 +93,24 @@ bool MapModel::setData(const QVariant& value, int role) return false; } +void MapModel::addObject(Object* /*object*/) +{ +} + +void MapModel::deleteObject(BaseModel* /*model*/) +{ +} + +void MapModel::deleteSelf() +{ +// static_cast<GroupModel*>(m_parent)->deleteObject(this); +} + void MapModel::setupData() { - m_objects.append(new MapEffectGroupModel(this, static_cast<Map*>(m_object))); - m_objects.append(new MapTrainerGroupModel(this, static_cast<Map*>(m_object))); - m_objects.append(new MapWarpGroupModel(this, static_cast<Map*>(m_object))); - m_objects.append(new MapWildListGroupModel(this, static_cast<Map*>(m_object))); + Map* map = static_cast<Map*>(m_object); + m_objects.append(new MapEffectGroupModel(this, map)); + m_objects.append(new MapTrainerGroupModel(this, map)); + m_objects.append(new MapWarpGroupModel(this, map)); + m_objects.append(new MapWildListGroupModel(this, map)); } |
