Add option to always show menu bar instead of toolbar
For those who like keyboard navigation at the expense of aesthetics.
This commit is contained in:
parent
f6605bc3f8
commit
1303771b58
@ -613,6 +613,8 @@ Application::Application(int &argc, char **argv) : QApplication(argc, argv)
|
|||||||
// Remembered state
|
// Remembered state
|
||||||
m_settings->registerSetting("LastUsedGroupForNewInstance", QString());
|
m_settings->registerSetting("LastUsedGroupForNewInstance", QString());
|
||||||
|
|
||||||
|
m_settings->registerSetting("MenuBarInsteadOfToolBar", false);
|
||||||
|
|
||||||
QString defaultMonospace;
|
QString defaultMonospace;
|
||||||
int defaultSize = 11;
|
int defaultSize = 11;
|
||||||
#ifdef Q_OS_WIN32
|
#ifdef Q_OS_WIN32
|
||||||
|
@ -309,6 +309,7 @@ public:
|
|||||||
void createMainToolbar(QMainWindow *MainWindow)
|
void createMainToolbar(QMainWindow *MainWindow)
|
||||||
{
|
{
|
||||||
mainToolBar = TranslatedToolbar(MainWindow);
|
mainToolBar = TranslatedToolbar(MainWindow);
|
||||||
|
mainToolBar->setVisible(menuBar->isNativeMenuBar() || !APPLICATION->settings()->get("MenuBarInsteadOfToolBar").toBool());
|
||||||
mainToolBar->setObjectName(QStringLiteral("mainToolBar"));
|
mainToolBar->setObjectName(QStringLiteral("mainToolBar"));
|
||||||
mainToolBar->setMovable(true);
|
mainToolBar->setMovable(true);
|
||||||
mainToolBar->setAllowedAreas(Qt::TopToolBarArea | Qt::BottomToolBarArea);
|
mainToolBar->setAllowedAreas(Qt::TopToolBarArea | Qt::BottomToolBarArea);
|
||||||
@ -471,8 +472,7 @@ public:
|
|||||||
void createMenuBar(MainWindow *MainWindow)
|
void createMenuBar(MainWindow *MainWindow)
|
||||||
{
|
{
|
||||||
menuBar = new QMenuBar(MainWindow);
|
menuBar = new QMenuBar(MainWindow);
|
||||||
// There's already a toolbar, so hide this menu bar by default unless 'alt' is pressed on systems without native menu bar
|
menuBar->setVisible(APPLICATION->settings()->get("MenuBarInsteadOfToolBar").toBool());
|
||||||
menuBar->setVisible(false);
|
|
||||||
createMenuActions(MainWindow);
|
createMenuActions(MainWindow);
|
||||||
|
|
||||||
// TODO: only enable options while an instance is selected (if applicable)
|
// TODO: only enable options while an instance is selected (if applicable)
|
||||||
@ -909,10 +909,10 @@ public:
|
|||||||
MainWindow->setAccessibleName(BuildConfig.LAUNCHER_NAME);
|
MainWindow->setAccessibleName(BuildConfig.LAUNCHER_NAME);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
createMainToolbar(MainWindow);
|
|
||||||
|
|
||||||
createMenuBar(dynamic_cast<class MainWindow *>(MainWindow));
|
createMenuBar(dynamic_cast<class MainWindow *>(MainWindow));
|
||||||
|
|
||||||
|
createMainToolbar(MainWindow);
|
||||||
|
|
||||||
centralWidget = new QWidget(MainWindow);
|
centralWidget = new QWidget(MainWindow);
|
||||||
centralWidget->setObjectName(QStringLiteral("centralWidget"));
|
centralWidget->setObjectName(QStringLiteral("centralWidget"));
|
||||||
horizontalLayout = new QHBoxLayout(centralWidget);
|
horizontalLayout = new QHBoxLayout(centralWidget);
|
||||||
@ -1135,7 +1135,7 @@ MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new MainWindow
|
|||||||
#ifndef Q_OS_MAC
|
#ifndef Q_OS_MAC
|
||||||
void MainWindow::keyReleaseEvent(QKeyEvent *event)
|
void MainWindow::keyReleaseEvent(QKeyEvent *event)
|
||||||
{
|
{
|
||||||
if(event->key()==Qt::Key_Alt)
|
if(event->key()==Qt::Key_Alt && !APPLICATION->settings()->get("MenuBarInsteadOfToolBar").toBool())
|
||||||
ui->menuBar->setVisible(!ui->menuBar->isVisible());
|
ui->menuBar->setVisible(!ui->menuBar->isVisible());
|
||||||
else
|
else
|
||||||
QMainWindow::keyReleaseEvent(event);
|
QMainWindow::keyReleaseEvent(event);
|
||||||
@ -1294,6 +1294,12 @@ void MainWindow::showInstanceContextMenu(const QPoint &pos)
|
|||||||
myMenu.exec(view->mapToGlobal(pos));
|
myMenu.exec(view->mapToGlobal(pos));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MainWindow::updateMainToolBar()
|
||||||
|
{
|
||||||
|
ui->menuBar->setVisible(APPLICATION->settings()->get("MenuBarInsteadOfToolBar").toBool());
|
||||||
|
ui->mainToolBar->setVisible(ui->menuBar->isNativeMenuBar() || !APPLICATION->settings()->get("MenuBarInsteadOfToolBar").toBool());
|
||||||
|
}
|
||||||
|
|
||||||
void MainWindow::updateToolsMenu()
|
void MainWindow::updateToolsMenu()
|
||||||
{
|
{
|
||||||
QToolButton *launchButton = dynamic_cast<QToolButton*>(ui->instanceToolBar->widgetForAction(ui->actionLaunchInstance));
|
QToolButton *launchButton = dynamic_cast<QToolButton*>(ui->instanceToolBar->widgetForAction(ui->actionLaunchInstance));
|
||||||
@ -1966,6 +1972,7 @@ void MainWindow::globalSettingsClosed()
|
|||||||
APPLICATION->instances()->loadList();
|
APPLICATION->instances()->loadList();
|
||||||
proxymodel->invalidate();
|
proxymodel->invalidate();
|
||||||
proxymodel->sort(0);
|
proxymodel->sort(0);
|
||||||
|
updateMainToolBar();
|
||||||
updateToolsMenu();
|
updateToolsMenu();
|
||||||
updateStatusCenter();
|
updateStatusCenter();
|
||||||
update();
|
update();
|
||||||
|
@ -151,6 +151,8 @@ private slots:
|
|||||||
|
|
||||||
void showInstanceContextMenu(const QPoint &);
|
void showInstanceContextMenu(const QPoint &);
|
||||||
|
|
||||||
|
void updateMainToolBar();
|
||||||
|
|
||||||
void updateToolsMenu();
|
void updateToolsMenu();
|
||||||
|
|
||||||
void instanceActivated(QModelIndex);
|
void instanceActivated(QModelIndex);
|
||||||
|
@ -41,6 +41,7 @@
|
|||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QTextCharFormat>
|
#include <QTextCharFormat>
|
||||||
|
#include <QMenuBar>
|
||||||
|
|
||||||
#include "updater/UpdateChecker.h"
|
#include "updater/UpdateChecker.h"
|
||||||
|
|
||||||
@ -322,6 +323,8 @@ void LauncherPage::applySettings()
|
|||||||
APPLICATION->setApplicationTheme(newAppTheme, false);
|
APPLICATION->setApplicationTheme(newAppTheme, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
s->set("MenuBarInsteadOfToolBar", ui->preferMenuBarCheckBox->isChecked());
|
||||||
|
|
||||||
// Console settings
|
// Console settings
|
||||||
s->set("ShowConsole", ui->showConsoleCheck->isChecked());
|
s->set("ShowConsole", ui->showConsoleCheck->isChecked());
|
||||||
s->set("AutoCloseConsole", ui->autoCloseConsoleCheck->isChecked());
|
s->set("AutoCloseConsole", ui->autoCloseConsoleCheck->isChecked());
|
||||||
@ -410,6 +413,10 @@ void LauncherPage::loadSettings()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Toolbar/menu bar settings (not applicable if native menu bar is present)
|
||||||
|
ui->toolsBox->setVisible(!QMenuBar().isNativeMenuBar());
|
||||||
|
ui->preferMenuBarCheckBox->setChecked(s->get("MenuBarInsteadOfToolBar").toBool());
|
||||||
|
|
||||||
// Console settings
|
// Console settings
|
||||||
ui->showConsoleCheck->setChecked(s->get("ShowConsole").toBool());
|
ui->showConsoleCheck->setChecked(s->get("ShowConsole").toBool());
|
||||||
ui->autoCloseConsoleCheck->setChecked(s->get("AutoCloseConsole").toBool());
|
ui->autoCloseConsoleCheck->setChecked(s->get("AutoCloseConsole").toBool());
|
||||||
|
@ -290,6 +290,16 @@
|
|||||||
</item>
|
</item>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item row="1" column="0">
|
||||||
|
<widget class="QLabel" name="label_4">
|
||||||
|
<property name="text">
|
||||||
|
<string>Colors</string>
|
||||||
|
</property>
|
||||||
|
<property name="buddy">
|
||||||
|
<cstring>themeComboBoxColors</cstring>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
<item row="1" column="1">
|
<item row="1" column="1">
|
||||||
<widget class="QComboBox" name="themeComboBoxColors">
|
<widget class="QComboBox" name="themeComboBoxColors">
|
||||||
<property name="sizePolicy">
|
<property name="sizePolicy">
|
||||||
@ -303,13 +313,25 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="0">
|
</layout>
|
||||||
<widget class="QLabel" name="label_4">
|
</widget>
|
||||||
<property name="text">
|
</item>
|
||||||
<string>Colors</string>
|
<item>
|
||||||
|
<widget class="QGroupBox" name="toolsBox">
|
||||||
|
<property name="sizePolicy">
|
||||||
|
<sizepolicy hsizetype="Preferred" vsizetype="Preferred">
|
||||||
|
<horstretch>0</horstretch>
|
||||||
|
<verstretch>0</verstretch>
|
||||||
|
</sizepolicy>
|
||||||
</property>
|
</property>
|
||||||
<property name="buddy">
|
<property name="title">
|
||||||
<cstring>themeComboBoxColors</cstring>
|
<string>Tools</string>
|
||||||
|
</property>
|
||||||
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
|
<item>
|
||||||
|
<widget class="QCheckBox" name="preferMenuBarCheckBox">
|
||||||
|
<property name="text">
|
||||||
|
<string>Always show menu bar instead of tool bar (more keyboard friendly, less pretty)</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user