Navigator improvements

- auto focus
- tooltip for buttons
- style
This commit is contained in:
Klaus Basan
2018-08-20 18:09:12 +02:00
parent 44d9fa35a4
commit 93a56d6633
3 changed files with 75 additions and 65 deletions

View File

@@ -30,6 +30,7 @@
#include <QToolButton> #include <QToolButton>
#include <QVariant> #include <QVariant>
#include <Qt> #include <Qt>
#include <QStringBuilder>
#include <QtGlobal> #include <QtGlobal>
using namespace BlackGui; using namespace BlackGui;
@@ -52,16 +53,16 @@ namespace BlackGui
// context menu // context menu
this->setContextMenuPolicy(Qt::CustomContextMenu); this->setContextMenuPolicy(Qt::CustomContextMenu);
this->m_input = new CMarginsInput(this); m_input = new CMarginsInput(this);
this->m_input->setMaximumWidth(150); m_input->setMaximumWidth(150);
this->m_marginMenuAction = new QWidgetAction(this); m_marginMenuAction = new QWidgetAction(this);
this->m_marginMenuAction->setDefaultWidget(this->m_input); m_marginMenuAction->setDefaultWidget(m_input);
this->setContextMenuPolicy(Qt::CustomContextMenu); this->setContextMenuPolicy(Qt::CustomContextMenu);
connect(this->m_input, &CMarginsInput::changedMargins, this, &CNavigatorDialog::ps_menuChangeMargins); connect(m_input, &CMarginsInput::changedMargins, this, &CNavigatorDialog::menuChangeMargins);
connect(this, &CNavigatorDialog::customContextMenuRequested, this, &CNavigatorDialog::ps_showContextMenu); connect(this, &CNavigatorDialog::customContextMenuRequested, this, &CNavigatorDialog::showContextMenu);
connect(sGui, &CGuiApplication::styleSheetsChanged, this, &CNavigatorDialog::ps_onStyleSheetsChanged, Qt::QueuedConnection); if (sGui) { connect(sGui, &CGuiApplication::styleSheetsChanged, this, &CNavigatorDialog::onStyleSheetsChanged, Qt::QueuedConnection); }
this->ps_onStyleSheetsChanged(); this->onStyleSheetsChanged();
} }
CNavigatorDialog::~CNavigatorDialog() CNavigatorDialog::~CNavigatorDialog()
@@ -69,13 +70,13 @@ namespace BlackGui
void CNavigatorDialog::buildNavigator(int columns) void CNavigatorDialog::buildNavigator(int columns)
{ {
if (this->m_firstBuild) if (m_firstBuild)
{ {
this->m_firstBuild = false; m_firstBuild = false;
this->insertOwnActions(); this->insertOwnActions();
} }
this->ps_onStyleSheetsChanged(); this->onStyleSheetsChanged();
// remove old layout // remove old layout
CGuiUtility::deleteLayout(ui->fr_NavigatorDialogInner->layout(), false); CGuiUtility::deleteLayout(ui->fr_NavigatorDialogInner->layout(), false);
@@ -90,20 +91,26 @@ namespace BlackGui
int r = 0; int r = 0;
int c = 0; int c = 0;
for (const auto &action : this->actions()) // remark:
for (QAction *action : this->actions())
{ {
if (!action) { continue; }
QToolButton *tb = new QToolButton(ui->fr_NavigatorDialogInner); QToolButton *tb = new QToolButton(ui->fr_NavigatorDialogInner);
tb->setDefaultAction(action); tb->setDefaultAction(action);
tb->setObjectName(this->objectName().append(":").append(action->objectName())); tb->setObjectName(this->objectName() % QStringLiteral(":") % action->objectName());
if (!action->text().isEmpty())
{
tb->setToolTip(action->text());
}
gridLayout->addWidget(tb, r, c++); gridLayout->addWidget(tb, r, c++);
tb->show(); tb->show();
if (c < columns) { continue; } if (c < columns) { continue; }
c = 0; c = 0;
r++; r++;
} }
this->m_currentColumns = gridLayout->columnCount(); m_currentColumns = gridLayout->columnCount();
this->adjustNavigatorSize(gridLayout); this->adjustNavigatorSize(gridLayout);
this->focusWidget();
} }
void CNavigatorDialog::reject() void CNavigatorDialog::reject()
@@ -124,7 +131,7 @@ namespace BlackGui
void CNavigatorDialog::restoreFromSettings() void CNavigatorDialog::restoreFromSettings()
{ {
const CNavigatorSettings s = this->m_settings.get(); const CNavigatorSettings s = m_settings.get();
this->setContentsMargins(s.getMargins()); this->setContentsMargins(s.getMargins());
if (this->isFrameless() != s.isFramless()) { this->toggleFrameless(); } if (this->isFrameless() != s.isFramless()) { this->toggleFrameless(); }
this->buildNavigator(s.getColumns()); this->buildNavigator(s.getColumns());
@@ -134,19 +141,20 @@ namespace BlackGui
void CNavigatorDialog::saveToSettings() void CNavigatorDialog::saveToSettings()
{ {
CNavigatorSettings s = this->m_settings.get(); CNavigatorSettings s = m_settings.get();
s.setFrameless(this->isFrameless()); s.setFrameless(this->isFrameless());
s.setMargins(this->contentsMargins()); s.setMargins(this->contentsMargins());
s.setGeometry(this->saveGeometry()); s.setGeometry(this->saveGeometry());
s.setColumns(this->m_currentColumns); s.setColumns(m_currentColumns);
const CStatusMessage m = this->m_settings.setAndSave(s); const CStatusMessage m = m_settings.setAndSave(s);
if (!m.isSuccess()) { CLogMessage::preformatted(m); } if (!m.isSuccess()) { CLogMessage::preformatted(m); }
} }
void CNavigatorDialog::ps_onStyleSheetsChanged() void CNavigatorDialog::onStyleSheetsChanged()
{ {
const QString fn(CStyleSheetUtility::fileNameNavigator()); const QString fn(CStyleSheetUtility::fileNameNavigator());
const QString qss(sGui->getStyleSheetUtility().style(fn)); const QString qss(sGui->getStyleSheetUtility().style(fn));
this->setStyleSheet("");
this->setStyleSheet(qss); this->setStyleSheet(qss);
this->adjustNavigatorSize(); this->adjustNavigatorSize();
this->repaint(); this->repaint();
@@ -178,27 +186,34 @@ namespace BlackGui
void CNavigatorDialog::windowFlagsChanged() void CNavigatorDialog::windowFlagsChanged()
{ {
if (this->m_firstBuild) { return; } if (m_firstBuild) { return; }
this->buildNavigator(this->m_currentColumns); this->buildNavigator(m_currentColumns);
} }
void CNavigatorDialog::paintEvent(QPaintEvent *event) void CNavigatorDialog::paintEvent(QPaintEvent *event)
{ {
bool s = CStyleSheetUtility::useStyleSheetInDerivedWidget(this, QStyle::PE_Widget); const bool s = CStyleSheetUtility::useStyleSheetInDerivedWidget(this, QStyle::PE_Widget);
if (s) { return; } if (s) { return; }
QDialog::paintEvent(event); QDialog::paintEvent(event);
} }
void CNavigatorDialog::ps_showContextMenu(const QPoint &pos) void CNavigatorDialog::enterEvent(QEvent *event)
{ {
QPoint globalPos = this->mapToGlobal(pos); // event called when mouse is over, acts as auto-focus
QApplication::setActiveWindow(this);
QDialog::enterEvent(event);
}
void CNavigatorDialog::showContextMenu(const QPoint &pos)
{
const QPoint globalPos = this->mapToGlobal(pos);
QScopedPointer<QMenu> contextMenu(new QMenu(this)); QScopedPointer<QMenu> contextMenu(new QMenu(this));
this->addToContextMenu(contextMenu.data()); this->addToContextMenu(contextMenu.data());
QAction *selectedItem = contextMenu.data()->exec(globalPos); QAction *selectedItem = contextMenu.data()->exec(globalPos);
Q_UNUSED(selectedItem); Q_UNUSED(selectedItem);
} }
void CNavigatorDialog::ps_changeLayout() void CNavigatorDialog::changeLayout()
{ {
QAction *a = qobject_cast<QAction *>(QObject::sender()); QAction *a = qobject_cast<QAction *>(QObject::sender());
if (!a) { return; } if (!a) { return; }
@@ -209,18 +224,18 @@ namespace BlackGui
else if (v == "2r") { buildNavigator(columnsForRows(2));} else if (v == "2r") { buildNavigator(columnsForRows(2));}
} }
void CNavigatorDialog::ps_menuChangeMargins(const QMargins &margins) void CNavigatorDialog::menuChangeMargins(const QMargins &margins)
{ {
this->setContentsMargins(margins); this->setContentsMargins(margins);
this->adjustNavigatorSize(); this->adjustNavigatorSize();
} }
void CNavigatorDialog::ps_dummy() void CNavigatorDialog::dummyFunction()
{ {
// void // void
} }
void CNavigatorDialog::ps_settingsChanged() void CNavigatorDialog::onSettingsChanged()
{ {
// void // void
} }
@@ -228,7 +243,7 @@ namespace BlackGui
void CNavigatorDialog::insertOwnActions() void CNavigatorDialog::insertOwnActions()
{ {
// add some space for frameless navigators where I can move the navigator // add some space for frameless navigators where I can move the navigator
QAction *a = new QAction(BlackMisc::CIcons::empty16(), "move navigator here", this); QAction *a = new QAction(CIcons::empty16(), "move navigator here", this);
if (this->actions().isEmpty()) if (this->actions().isEmpty())
{ {
this->addAction(a); this->addAction(a);
@@ -238,10 +253,14 @@ namespace BlackGui
this->insertAction(this->actions().first(), a); this->insertAction(this->actions().first(), a);
} }
a = new QAction(BlackMisc::CIcons::swiftLauncher16(), "Start launcher", this); bool c;
bool c = connect(a, &QAction::triggered, sGui, &CGuiApplication::startLauncher); if (sGui)
Q_ASSERT(c); {
this->addAction(a); a = new QAction(CIcons::swiftLauncher16(), "Start launcher", this);
c = connect(a, &QAction::triggered, sGui, &CGuiApplication::startLauncher);
Q_ASSERT(c);
this->addAction(a);
}
// save // save
a = new QAction(CIcons::save16(), "Save state", this); a = new QAction(CIcons::save16(), "Save state", this);
@@ -292,18 +311,18 @@ namespace BlackGui
void CNavigatorDialog::addToContextMenu(QMenu *contextMenu) const void CNavigatorDialog::addToContextMenu(QMenu *contextMenu) const
{ {
QAction *a = contextMenu->addAction(CIcons::resize16(), "1 row", this, &CNavigatorDialog::ps_changeLayout); QAction *a = contextMenu->addAction(CIcons::resize16(), "1 row", this, &CNavigatorDialog::changeLayout);
a->setData("1r"); a->setData("1r");
a = contextMenu->addAction(CIcons::resize16(), "2 rows", this, &CNavigatorDialog::ps_changeLayout); a = contextMenu->addAction(CIcons::resize16(), "2 rows", this, &CNavigatorDialog::changeLayout);
a->setData("2r"); a->setData("2r");
a = contextMenu->addAction(CIcons::resize16(), "1 column", this, &CNavigatorDialog::ps_changeLayout); a = contextMenu->addAction(CIcons::resize16(), "1 column", this, &CNavigatorDialog::changeLayout);
a->setData("1c"); a->setData("1c");
a = contextMenu->addAction(CIcons::resize16(), "2 columns", this, &CNavigatorDialog::ps_changeLayout); a = contextMenu->addAction(CIcons::resize16(), "2 columns", this, &CNavigatorDialog::changeLayout);
a->setData("2c"); a->setData("2c");
const QString frameLessActionText = this->isFrameless() ? "Normal window" : "Frameless"; const QString frameLessActionText = this->isFrameless() ? "Normal window" : "Frameless";
contextMenu->addAction(BlackMisc::CIcons::tableSheet16(), frameLessActionText, this, SLOT(toggleFrameless())); contextMenu->addAction(CIcons::tableSheet16(), frameLessActionText, this, SLOT(toggleFrameless()));
contextMenu->addAction("Adjust margins", this, &CNavigatorDialog::ps_dummy); contextMenu->addAction("Adjust margins", this, &CNavigatorDialog::dummyFunction);
contextMenu->addAction(this->m_marginMenuAction); contextMenu->addAction(m_marginMenuAction);
contextMenu->addSeparator(); contextMenu->addSeparator();
contextMenu->addAction(CIcons::load16(), "Restore state", this, &CNavigatorDialog::restoreFromSettings); contextMenu->addAction(CIcons::load16(), "Restore state", this, &CNavigatorDialog::restoreFromSettings);
contextMenu->addAction(CIcons::save16(), "Save state", this, &CNavigatorDialog::saveToSettings); contextMenu->addAction(CIcons::save16(), "Save state", this, &CNavigatorDialog::saveToSettings);

View File

@@ -49,7 +49,7 @@ namespace BlackGui
CNavigatorDialog(QWidget *parent = nullptr); CNavigatorDialog(QWidget *parent = nullptr);
//! Destructor //! Destructor
virtual ~CNavigatorDialog(); virtual ~CNavigatorDialog() override;
//! Navigator //! Navigator
void buildNavigator(int columns); void buildNavigator(int columns);
@@ -75,9 +75,6 @@ namespace BlackGui
void saveToSettings(); void saveToSettings();
protected: protected:
//! Style sheet has changed
void ps_onStyleSheetsChanged();
//! \name Base class events //! \name Base class events
//! @{ //! @{
virtual void mouseMoveEvent(QMouseEvent *event) override; virtual void mouseMoveEvent(QMouseEvent *event) override;
@@ -85,25 +82,28 @@ namespace BlackGui
virtual void changeEvent(QEvent *evt) override; virtual void changeEvent(QEvent *evt) override;
virtual void windowFlagsChanged() override; virtual void windowFlagsChanged() override;
virtual void paintEvent(QPaintEvent *event) override; virtual void paintEvent(QPaintEvent *event) override;
virtual void enterEvent(QEvent *event) override;
//! @} //! @}
private slots: private:
//! Context menu //! Margins context menu
void ps_showContextMenu(const QPoint &pos); void menuChangeMargins(const QMargins &margins);
//! Change the layout //! Change the layout
void ps_changeLayout(); void changeLayout();
//! Margins context menu
void ps_menuChangeMargins(const QMargins &margins);
//! Dummy slot //! Dummy slot
void ps_dummy(); void dummyFunction();
//! Context menu
void showContextMenu(const QPoint &pos);
//! Style sheet has changed
void onStyleSheetsChanged();
//! Changed settigs //! Changed settigs
void ps_settingsChanged(); void onSettingsChanged();
private:
//! Insert own actions //! Insert own actions
void insertOwnActions(); void insertOwnActions();
@@ -124,7 +124,7 @@ namespace BlackGui
int m_currentColumns = 1; int m_currentColumns = 1;
QWidgetAction *m_marginMenuAction = nullptr; //!< menu widget(!) action for margin widget QWidgetAction *m_marginMenuAction = nullptr; //!< menu widget(!) action for margin widget
CMarginsInput *m_input = nullptr; //!< margins widget CMarginsInput *m_input = nullptr; //!< margins widget
BlackMisc::CSetting<BlackGui::Settings::TNavigator> m_settings { this, &CNavigatorDialog::ps_settingsChanged }; BlackMisc::CSetting<BlackGui::Settings::TNavigator> m_settings { this, &CNavigatorDialog::onSettingsChanged };
}; };
} // ns } // ns
} // ns } // ns

View File

@@ -49,15 +49,6 @@
<verstretch>0</verstretch> <verstretch>0</verstretch>
</sizepolicy> </sizepolicy>
</property> </property>
<property name="frameShape">
<enum>QFrame::NoFrame</enum>
</property>
<property name="frameShadow">
<enum>QFrame::Plain</enum>
</property>
<property name="lineWidth">
<number>1</number>
</property>
</widget> </widget>
</item> </item>
</layout> </layout>