From 1c79d5311c198f49ce3efea7f536daa85b424dfa Mon Sep 17 00:00:00 2001 From: Nelsson Huotari Date: Thu, 10 May 2018 21:58:36 +0300 Subject: [PATCH] Brush history menu --- .../opencs/view/render/terraintexturemode.cpp | 7 ++ .../opencs/view/render/terraintexturemode.hpp | 2 +- .../view/widget/scenetooltexturebrush.cpp | 72 ++++++++++++++++++- .../view/widget/scenetooltexturebrush.hpp | 12 ++-- 4 files changed, 87 insertions(+), 6 deletions(-) diff --git a/apps/opencs/view/render/terraintexturemode.cpp b/apps/opencs/view/render/terraintexturemode.cpp index 33822291b9..ea68cfa934 100644 --- a/apps/opencs/view/render/terraintexturemode.cpp +++ b/apps/opencs/view/render/terraintexturemode.cpp @@ -54,9 +54,11 @@ void CSVRender::TerrainTextureMode::activate(CSVWidget::SceneToolbar* toolbar) connect(mTextureBrushScenetool->mTextureBrushWindow, SIGNAL(passBrushSize(int)), this, SLOT(setBrushSize(int))); connect(mTextureBrushScenetool->mTextureBrushWindow, SIGNAL(passBrushShape(int)), this, SLOT(setBrushShape(int))); connect(mTextureBrushScenetool->mTextureBrushWindow->mSizeSliders->mBrushSizeSlider, SIGNAL(valueChanged(int)), this, SLOT(setBrushSize(int))); + connect(mTextureBrushScenetool, SIGNAL(passTextureId(std::string)), this, SLOT(setBrushTexture(std::string))); connect(mTextureBrushScenetool, SIGNAL(passEvent(QDropEvent*)), this, SLOT(handleDropEvent(QDropEvent*))); connect(this, SIGNAL(passBrushTexture(std::string)), mTextureBrushScenetool->mTextureBrushWindow, SLOT(setBrushTexture(std::string))); + connect(this, SIGNAL(passBrushTexture(std::string)), mTextureBrushScenetool, SLOT(updateBrushHistory(std::string))); } EditMode::activate(toolbar); @@ -500,3 +502,8 @@ void CSVRender::TerrainTextureMode::setBrushShape(int brushShape) { mBrushShape = brushShape; } + +void CSVRender::TerrainTextureMode::setBrushTexture(std::string brushTexture) +{ + mBrushTexture = brushTexture; +} diff --git a/apps/opencs/view/render/terraintexturemode.hpp b/apps/opencs/view/render/terraintexturemode.hpp index 084f4c6374..e1538e2439 100644 --- a/apps/opencs/view/render/terraintexturemode.hpp +++ b/apps/opencs/view/render/terraintexturemode.hpp @@ -92,7 +92,7 @@ namespace CSVRender void handleDropEvent(QDropEvent *event); void setBrushSize(int brushSize); void setBrushShape(int brushShape); - + void setBrushTexture(std::string brushShape); }; } diff --git a/apps/opencs/view/widget/scenetooltexturebrush.cpp b/apps/opencs/view/widget/scenetooltexturebrush.cpp index 07682cbca6..9909634151 100644 --- a/apps/opencs/view/widget/scenetooltexturebrush.cpp +++ b/apps/opencs/view/widget/scenetooltexturebrush.cpp @@ -15,6 +15,10 @@ #include #include #include +#include +#include +#include +#include #include "scenetool.hpp" @@ -133,13 +137,40 @@ void CSVWidget::SceneToolTextureBrush::adjustToolTips() } CSVWidget::SceneToolTextureBrush::SceneToolTextureBrush (SceneToolbar *parent, const QString& toolTip) -: SceneTool (parent), +: SceneTool (parent, Type_TopAction), mToolTip (toolTip), + mBrushHistory{"L0#0"}, mTextureBrushWindow(new TextureBrushWindow(this)) { setAcceptDrops(true); connect(mTextureBrushWindow, SIGNAL(passBrushShape(int)), this, SLOT(setButtonIcon(int))); setButtonIcon(mTextureBrushWindow->mBrushShape); + + mPanel = new QFrame (this, Qt::Popup); + + QHBoxLayout *layout = new QHBoxLayout (mPanel); + + layout->setContentsMargins (QMargins (0, 0, 0, 0)); + + mTable = new QTableWidget (0, 2, this); + + mTable->setShowGrid (true); + mTable->verticalHeader()->hide(); + mTable->horizontalHeader()->hide(); +#if QT_VERSION >= QT_VERSION_CHECK(5,0,0) + mTable->horizontalHeader()->setSectionResizeMode (0, QHeaderView::Stretch); + mTable->horizontalHeader()->setSectionResizeMode (1, QHeaderView::ResizeToContents); +#else + mTable->horizontalHeader()->setResizeMode (0, QHeaderView::Stretch); + mTable->horizontalHeader()->setResizeMode (1, QHeaderView::ResizeToContents); +#endif + mTable->setSelectionMode (QAbstractItemView::NoSelection); + + layout->addWidget (mTable); + + connect (mTable, SIGNAL (clicked (const QModelIndex&)), + this, SLOT (clicked (const QModelIndex&))); + } void CSVWidget::SceneToolTextureBrush::setButtonIcon (int brushShape) @@ -172,6 +203,45 @@ void CSVWidget::SceneToolTextureBrush::setButtonIcon (int brushShape) void CSVWidget::SceneToolTextureBrush::showPanel (const QPoint& position) { + updatePanel(); + mPanel->move (position); + mPanel->show(); +} + +void CSVWidget::SceneToolTextureBrush::updatePanel() +{ + mTable->setRowCount (mBrushHistory.size()); + + mTable->setItem (0, 1, new QTableWidgetItem ( + QApplication::style()->standardIcon (QStyle::SP_TitleBarCloseButton), "")); + + for (int i = mBrushHistory.size()-1; i >= 0; --i) + { + mTable->setItem (i, 0, new QTableWidgetItem (QString::fromStdString(mBrushHistory[i]))); + } +} + +void CSVWidget::SceneToolTextureBrush::updateBrushHistory (const std::string& brushTexture) +{ + mBrushHistory.insert(mBrushHistory.begin(), brushTexture); + if(mBrushHistory.size() > 5) mBrushHistory.pop_back(); +} + +void CSVWidget::SceneToolTextureBrush::clicked (const QModelIndex& index) +{ + if (index.column()==0) + { + std::string brushTexture = mBrushHistory[index.row()]; + std::swap(mBrushHistory[index.row()], mBrushHistory[0]); + mTextureBrushWindow->setBrushTexture(brushTexture); + emit passTextureId(brushTexture); + updatePanel(); + mPanel->hide(); + } + else if (index.column()==1) + { + mPanel->hide(); + } } void CSVWidget::SceneToolTextureBrush::activate () diff --git a/apps/opencs/view/widget/scenetooltexturebrush.hpp b/apps/opencs/view/widget/scenetooltexturebrush.hpp index 1bf15ead9e..982ccc3aaa 100644 --- a/apps/opencs/view/widget/scenetooltexturebrush.hpp +++ b/apps/opencs/view/widget/scenetooltexturebrush.hpp @@ -16,10 +16,7 @@ #include "scenetool.hpp" -/*namespace CSVRender -{ - class TerrainTextureMode; -}*/ +class QTableWidget; namespace CSVWidget { @@ -79,6 +76,9 @@ namespace CSVWidget Q_OBJECT QString mToolTip; + QFrame *mPanel; + QTableWidget *mTable; + std::vector mBrushHistory; private: @@ -89,6 +89,7 @@ namespace CSVWidget SceneToolTextureBrush (SceneToolbar *parent, const QString& toolTip); virtual void showPanel (const QPoint& position); + void updatePanel (); TextureBrushWindow *mTextureBrushWindow; @@ -97,11 +98,14 @@ namespace CSVWidget public slots: void setButtonIcon(int brushShape); + void updateBrushHistory (const std::string& mBrushTexture); + void clicked (const QModelIndex& index); virtual void activate(); signals: void passEvent(QDropEvent *event); void passEvent(QDragEnterEvent *event); + void passTextureId(std::string brushTexture); }; }