Commit 17cdf125d83978445407004964e1ec45eebeba27
- Diff rendering mode:
- inline
- side by side
src/tiled/tilesetdock.cpp
(78 / 0)
|   | |||
| 37 | 37 | #include <QStackedWidget> | |
| 38 | 38 | #include <QTabBar> | |
| 39 | 39 | #include <QVBoxLayout> | |
| 40 | #include <QMenu> | ||
| 40 | 41 | ||
| 42 | #include "newtilesetdialog.h" | ||
| 43 | #include "tmxmapreader.h" | ||
| 44 | #include <QFileDialog> | ||
| 45 | |||
| 41 | 46 | using namespace Tiled; | |
| 42 | 47 | using namespace Tiled::Internal; | |
| 43 | 48 | ||
| … | … | ||
| 64 | 64 | ||
| 65 | 65 | mTabBar->setTabsClosable(true); | |
| 66 | 66 | mTabBar->setMovable(true); | |
| 67 | mTabBar->setContextMenuPolicy(Qt::CustomContextMenu); | ||
| 67 | 68 | ||
| 68 | 69 | connect(mTabBar, SIGNAL(currentChanged(int)), | |
| 69 | 70 | mViewStack, SLOT(setCurrentIndex(int))); | |
| … | … | ||
| 72 | 72 | this, SLOT(removeTileset(int))); | |
| 73 | 73 | connect(mTabBar, SIGNAL(tabMoved(int,int)), | |
| 74 | 74 | this, SLOT(moveTileset(int,int))); | |
| 75 | connect(mTabBar, SIGNAL(customContextMenuRequested(const QPoint&)), | ||
| 76 | this, SLOT(tabContext(const QPoint&))); | ||
| 75 | 77 | ||
| 76 | 78 | connect(TilesetManager::instance(), SIGNAL(tilesetChanged(Tileset*)), | |
| 77 | 79 | this, SLOT(tilesetChanged(Tileset*))); | |
| … | … | ||
| 133 | 133 | TilesetView *view = new TilesetView(mMapDocument); | |
| 134 | 134 | view->setModel(new TilesetModel(tileset, view)); | |
| 135 | 135 | ||
| 136 | connect(view, SIGNAL(reloadRequested(QString)), | ||
| 137 | TilesetManager::instance(), | ||
| 138 | SLOT(reloadRequested(QString))); | ||
| 139 | |||
| 136 | 140 | connect(view->selectionModel(), | |
| 137 | 141 | SIGNAL(selectionChanged(QItemSelection,QItemSelection)), | |
| 138 | 142 | SLOT(selectionChanged())); | |
| … | … | ||
| 286 | 286 | QUndoCommand *command = new MoveTileset(mMapDocument, from, to); | |
| 287 | 287 | mMapDocument->undoStack()->push(command); | |
| 288 | 288 | } | |
| 289 | |||
| 290 | // TODO: remove duplication, and probably move into a specialization of MapDocumentHandler relating to tilesets. | ||
| 291 | void TilesetDock::tabContext(const QPoint &point) | ||
| 292 | { | ||
| 293 | if (point.isNull()) | ||
| 294 | return; | ||
| 295 | |||
| 296 | int index = mTabBar->tabAt(point); | ||
| 297 | |||
| 298 | QMenu menu(mTabBar); | ||
| 299 | |||
| 300 | QAction *actionNewTileset = menu.addAction(tr("New Tileset...")); | ||
| 301 | actionNewTileset->setIcon(QIcon(QLatin1String(":/images/16x16/document-new.png"))); | ||
| 302 | QAction *actionAddExternalTileset = menu.addAction(tr("Add External Tileset...")); | ||
| 303 | |||
| 304 | connect(actionNewTileset, SIGNAL(triggered()), this, SLOT(newTileset())); | ||
| 305 | connect(actionAddExternalTileset, SIGNAL(triggered()), this, SLOT(addExternalTileset())); | ||
| 306 | |||
| 307 | if (index == -1) { | ||
| 308 | menu.exec(mTabBar->mapToGlobal(point)); | ||
| 309 | } else { | ||
| 310 | menu.addSeparator(); | ||
| 311 | mTabBar->setCurrentIndex(index); | ||
| 312 | tilesetViewAt(index)->contextMenu(menu, mTabBar->mapToGlobal(point), true); | ||
| 313 | } | ||
| 314 | } | ||
| 315 | |||
| 316 | void TilesetDock::newTileset() | ||
| 317 | { | ||
| 318 | if (!mMapDocument) | ||
| 319 | return; | ||
| 320 | |||
| 321 | Map *map = mMapDocument->map(); | ||
| 322 | |||
| 323 | //NewTilesetDialog newTileset(fileDialogStartLocation(), this); | ||
| 324 | NewTilesetDialog newTileset(QString(), this); | ||
| 325 | newTileset.setTileWidth(map->tileWidth()); | ||
| 326 | newTileset.setTileHeight(map->tileHeight()); | ||
| 327 | |||
| 328 | if (Tileset *tileset = newTileset.createTileset()) | ||
| 329 | mMapDocument->undoStack()->push(new AddTileset(mMapDocument, tileset)); | ||
| 330 | } | ||
| 331 | |||
| 332 | void TilesetDock::addExternalTileset() | ||
| 333 | { | ||
| 334 | if (!mMapDocument) | ||
| 335 | return; | ||
| 336 | |||
| 337 | //const QString start = fileDialogStartLocation(); | ||
| 338 | const QString start; | ||
| 339 | const QString fileName = | ||
| 340 | QFileDialog::getOpenFileName(this, tr("Add External Tileset"), | ||
| 341 | start, | ||
| 342 | tr("Tiled tileset files (*.tsx)")); | ||
| 343 | if (fileName.isEmpty()) | ||
| 344 | return; | ||
| 345 | |||
| 346 | TmxMapReader reader; | ||
| 347 | if (Tileset *tileset = reader.readTileset(fileName)) { | ||
| 348 | mMapDocument->undoStack()->push(new AddTileset(mMapDocument, tileset)); | ||
| 349 | } else { | ||
| 350 | QMessageBox::critical(this, tr("Error Reading Tileset"), | ||
| 351 | reader.errorString()); | ||
| 352 | } | ||
| 353 | } | ||
| 354 | |||
| 289 | 355 | ||
| 290 | 356 | void TilesetDock::setCurrentTiles(TileLayer *tiles) | |
| 291 | 357 | { |
src/tiled/tilesetdock.h
(3 / 0)
|   | |||
| 77 | 77 | void removeTileset(int index); | |
| 78 | 78 | void moveTileset(int from, int to); | |
| 79 | 79 | ||
| 80 | void tabContext(const QPoint &point); | ||
| 81 | void newTileset(); | ||
| 82 | void addExternalTileset(); | ||
| 80 | 83 | private: | |
| 81 | 84 | void setCurrentTiles(TileLayer *tiles); | |
| 82 | 85 | void retranslateUi(); |
src/tiled/tilesetmanager.cpp
(14 / 1)
|   | |||
| 22 | 22 | #include "tilesetmanager.h" | |
| 23 | 23 | ||
| 24 | 24 | #include "tileset.h" | |
| 25 | |||
| 25 | #include <QString> | ||
| 26 | #include <QMessageBox> | ||
| 26 | 27 | #include <QFileSystemWatcher> | |
| 27 | 28 | ||
| 28 | 29 | using namespace Tiled; | |
| … | … | ||
| 145 | 145 | ||
| 146 | 146 | void TilesetManager::fileChangedTimeout() | |
| 147 | 147 | { | |
| 148 | mChangedFilesTimer.stop(); | ||
| 148 | 149 | foreach (Tileset *tileset, tilesets()) { | |
| 149 | 150 | if (mChangedFiles.contains(tileset->imageSource())) { | |
| 150 | 151 | tileset->loadFromImage(tileset->imageSource()); | |
| … | … | ||
| 154 | 154 | } | |
| 155 | 155 | ||
| 156 | 156 | mChangedFiles.clear(); | |
| 157 | } | ||
| 158 | |||
| 159 | void TilesetManager::reloadRequested(const QString &path) | ||
| 160 | { | ||
| 161 | /* | ||
| 162 | * Use a one-shot timer since GIMP (for example) seems to generate many | ||
| 163 | * file changes during a save, and some of the intermediate attempts to | ||
| 164 | * reload the tileset images actually fail (at least for .png files). | ||
| 165 | */ | ||
| 166 | mChangedFiles.insert(path); | ||
| 167 | mChangedFilesTimer.start(); | ||
| 157 | 168 | } |
src/tiled/tilesetmanager.h
(1 / 0)
|   | |||
| 118 | 118 | private slots: | |
| 119 | 119 | void fileChanged(const QString &path); | |
| 120 | 120 | void fileChangedTimeout(); | |
| 121 | void reloadRequested(const QString &path); | ||
| 121 | 122 | ||
| 122 | 123 | private: | |
| 123 | 124 | Q_DISABLE_COPY(TilesetManager) |
src/tiled/tilesetview.cpp
(36 / 1)
|   | |||
| 39 | 39 | #include <QPainter> | |
| 40 | 40 | #include <QUndoCommand> | |
| 41 | 41 | #include <QWheelEvent> | |
| 42 | #include <QKeyEvent> | ||
| 42 | 43 | ||
| 43 | 44 | using namespace Tiled; | |
| 44 | 45 | using namespace Tiled::Internal; | |
| … | … | ||
| 214 | 214 | SLOT(editTileProperties())); | |
| 215 | 215 | } | |
| 216 | 216 | ||
| 217 | contextMenu(menu, event->globalPos(), false); | ||
| 218 | } | ||
| 219 | |||
| 220 | void TilesetView::contextMenu(QMenu& menu, const QPoint& position, bool fromTabBar) | ||
| 221 | { | ||
| 222 | const TilesetModel *m = tilesetModel(); | ||
| 223 | const bool isExternal = m->tileset()->isExternal(); | ||
| 224 | |||
| 217 | 225 | QIcon exportIcon(QLatin1String(":images/16x16/document-export.png")); | |
| 218 | 226 | QIcon importIcon(QLatin1String(":images/16x16/document-import.png")); | |
| 219 | 227 | ||
| … | … | ||
| 238 | 238 | connect(exportTileset, SIGNAL(triggered()), SLOT(exportTileset())); | |
| 239 | 239 | connect(importTileset, SIGNAL(triggered()), SLOT(importTileset())); | |
| 240 | 240 | ||
| 241 | menu.exec(event->globalPos()); | ||
| 241 | menu.addSeparator(); | ||
| 242 | |||
| 243 | QAction *reloadAction = menu.addAction(tr("Reload")); | ||
| 244 | connect(reloadAction, SIGNAL(triggered()), SLOT(requestReload())); | ||
| 245 | |||
| 246 | menu.exec(position); | ||
| 247 | } | ||
| 248 | |||
| 249 | void TilesetView::keyPressEvent(QKeyEvent *event) | ||
| 250 | { | ||
| 251 | if (event->key() == Qt::Key_F5) { | ||
| 252 | Tileset *tileset = tilesetModel()->tileset(); | ||
| 253 | if (tileset) { | ||
| 254 | emit reloadRequested(tileset->imageSource()); | ||
| 255 | return; | ||
| 256 | } | ||
| 257 | } | ||
| 258 | |||
| 259 | QTableView::keyPressEvent(event); | ||
| 260 | } | ||
| 261 | |||
| 262 | void TilesetView::requestReload() | ||
| 263 | { | ||
| 264 | Tileset *tileset = tilesetModel()->tileset(); | ||
| 265 | if (tileset) { | ||
| 266 | emit reloadRequested(tileset->imageSource()); | ||
| 267 | } | ||
| 242 | 268 | } | |
| 243 | 269 | ||
| 244 | 270 | void TilesetView::editTileProperties() |
src/tiled/tilesetview.h
(7 / 0)
|   | |||
| 51 | 51 | TilesetModel *tilesetModel() const | |
| 52 | 52 | { return static_cast<TilesetModel *>(model()); } | |
| 53 | 53 | ||
| 54 | void contextMenu(QMenu& menu, const QPoint& point, bool fromTabBar); | ||
| 55 | |||
| 54 | 56 | protected: | |
| 55 | 57 | void wheelEvent(QWheelEvent *event); | |
| 56 | 58 | void contextMenuEvent(QContextMenuEvent *event); | |
| 59 | void keyPressEvent(QKeyEvent *event); | ||
| 57 | 60 | ||
| 61 | signals: | ||
| 62 | void reloadRequested(const QString &path); | ||
| 63 | |||
| 58 | 64 | private slots: | |
| 59 | 65 | void editTileProperties(); | |
| 60 | 66 | void exportTileset(); | |
| 61 | 67 | void importTileset(); | |
| 68 | void requestReload(); | ||
| 62 | 69 | ||
| 63 | 70 | void adjustScale(); | |
| 64 | 71 |

