From cb235cf14222896b4acdac937b63bd8212a28ef8 Mon Sep 17 00:00:00 2001 From: Michael Maltese Date: Fri, 26 May 2017 19:14:20 -0700 Subject: [PATCH 1/2] DolphinQt2: use GridLayout for ControllersWindow FormLayout is not intended for this sort of dialog: > QFormLayout is a convenience layout class that lays out its children > in a two-column form. The left column consists of labels and the right > column consists of "field" widgets (line editors, spin boxes, etc.). --- .../DolphinQt2/Config/ControllersWindow.cpp | 94 ++++++------------- .../DolphinQt2/Config/ControllersWindow.h | 7 +- 2 files changed, 33 insertions(+), 68 deletions(-) diff --git a/Source/Core/DolphinQt2/Config/ControllersWindow.cpp b/Source/Core/DolphinQt2/Config/ControllersWindow.cpp index 84490433f5..3e0a6ac432 100644 --- a/Source/Core/DolphinQt2/Config/ControllersWindow.cpp +++ b/Source/Core/DolphinQt2/Config/ControllersWindow.cpp @@ -7,14 +7,13 @@ #include #include #include -#include +#include #include #include #include #include #include #include -#include #include #include @@ -86,16 +85,15 @@ ControllersWindow::ControllersWindow(QWidget* parent) : QDialog(parent) void ControllersWindow::CreateGamecubeLayout() { m_gc_box = new QGroupBox(tr("GameCube Controllers")); - m_gc_layout = new QFormLayout(); + m_gc_layout = new QGridLayout(); + m_gc_layout->setVerticalSpacing(7); + m_gc_layout->setColumnStretch(1, 1); for (size_t i = 0; i < m_gc_groups.size(); i++) { + auto* gc_label = new QLabel(tr("Controller %1").arg(i + 1)); auto* gc_box = m_gc_controller_boxes[i] = new QComboBox(); auto* gc_button = m_gc_buttons[i] = new QPushButton(tr("Configure")); - auto* gc_group = m_gc_groups[i] = new QHBoxLayout(); - - gc_box->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed); - gc_button->setSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed); for (const auto& item : {tr("None"), tr("Standard Controller"), tr("GameCube Adapter for Wii U"), @@ -104,47 +102,18 @@ void ControllersWindow::CreateGamecubeLayout() gc_box->addItem(item); } - gc_group->addItem(new QSpacerItem(42, 1)); - gc_group->addWidget(gc_box); - gc_group->addWidget(gc_button); - - m_gc_layout->addRow(tr("Controller %1").arg(i + 1), gc_group); + int controller_row = m_gc_layout->rowCount(); + m_gc_layout->addWidget(gc_label, controller_row, 0); + m_gc_layout->addWidget(gc_box, controller_row, 1); + m_gc_layout->addWidget(gc_button, controller_row, 2); } m_gc_box->setLayout(m_gc_layout); } -static QHBoxLayout* CreateSubItem(QWidget* label, QWidget* widget) -{ - QHBoxLayout* hbox = new QHBoxLayout(); - hbox->addItem(new QSpacerItem(25, 1)); - - if (label != nullptr) - hbox->addWidget(label); - - if (widget != nullptr) - hbox->addWidget(widget); - - return hbox; -} - -static QHBoxLayout* CreateSubItem(QWidget* label, QLayoutItem* item) -{ - QHBoxLayout* hbox = new QHBoxLayout(); - hbox->addItem(new QSpacerItem(25, 1)); - - if (label != nullptr) - hbox->addWidget(label); - - if (item != nullptr) - hbox->addItem(item); - - return hbox; -} - void ControllersWindow::CreateWiimoteLayout() { m_wiimote_box = new QGroupBox(tr("Wii Remotes")); - m_wiimote_layout = new QFormLayout(); + m_wiimote_layout = new QGridLayout(); m_wiimote_passthrough = new QRadioButton(tr("Use Bluetooth Passthrough")); m_wiimote_sync = new QPushButton(tr("Sync")); m_wiimote_reset = new QPushButton(tr("Reset")); @@ -156,28 +125,28 @@ void ControllersWindow::CreateWiimoteLayout() m_wiimote_real_balance_board = new QCheckBox(tr("Real Balance Board")); m_wiimote_speaker_data = new QCheckBox(tr("Enable Speaker Data")); - m_wiimote_layout->setLabelAlignment(Qt::AlignLeft); + m_wiimote_layout->setVerticalSpacing(7); + m_wiimote_layout->setColumnStretch(1, 1); // Passthrough BT + m_wiimote_layout->addWidget(m_wiimote_passthrough, m_wiimote_layout->rowCount(), 0, 1, -1); - m_wiimote_layout->addRow(m_wiimote_passthrough); + int sync_row = m_wiimote_layout->rowCount(); + m_wiimote_layout->addWidget(m_wiimote_pt_labels[0], sync_row, 0, 1, 2); + m_wiimote_layout->addWidget(m_wiimote_sync, sync_row, 2); - m_wiimote_sync->setSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed); - m_wiimote_reset->setSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed); - m_wiimote_refresh->setSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed); - - m_wiimote_layout->addRow(CreateSubItem(m_wiimote_pt_labels[0], m_wiimote_sync)); - m_wiimote_layout->addRow(CreateSubItem(m_wiimote_pt_labels[1], m_wiimote_reset)); + int reset_row = m_wiimote_layout->rowCount(); + m_wiimote_layout->addWidget(m_wiimote_pt_labels[1], reset_row, 0, 1, 2); + m_wiimote_layout->addWidget(m_wiimote_reset, reset_row, 2); // Emulated BT - m_wiimote_layout->addRow(m_wiimote_emu); + m_wiimote_layout->addWidget(m_wiimote_emu, m_wiimote_layout->rowCount(), 0, 1, -1); for (size_t i = 0; i < m_wiimote_groups.size(); i++) { auto* wm_label = m_wiimote_labels[i] = new QLabel(tr("Wii Remote %1").arg(i + 1)); auto* wm_box = m_wiimote_boxes[i] = new QComboBox(); auto* wm_button = m_wiimote_buttons[i] = new QPushButton(tr("Configure")); - auto* wm_group = m_wiimote_groups[i] = new QHBoxLayout(); for (const auto& item : {tr("None"), tr("Emulated Wii Remote"), tr("Real Wii Remote"), tr("Hybrid Wii Remote")}) @@ -185,21 +154,18 @@ void ControllersWindow::CreateWiimoteLayout() wm_box->addItem(item); } - wm_button->setSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed); - wm_box->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed); - - wm_group->addItem(new QSpacerItem(25, 1)); - wm_group->addWidget(wm_label); - wm_group->addItem(new QSpacerItem(10, 1)); - wm_group->addWidget(wm_box); - wm_group->addWidget(wm_button); - - m_wiimote_layout->addRow(wm_group); + int wm_row = m_wiimote_layout->rowCount(); + m_wiimote_layout->addWidget(wm_label, wm_row, 0); + m_wiimote_layout->addWidget(wm_box, wm_row, 1); + m_wiimote_layout->addWidget(wm_button, wm_row, 2); } - m_wiimote_layout->addRow(CreateSubItem(m_wiimote_continuous_scanning, m_wiimote_refresh)); - m_wiimote_layout->addRow(CreateSubItem(nullptr, m_wiimote_real_balance_board)); - m_wiimote_layout->addRow(CreateSubItem(m_wiimote_speaker_data, new QSpacerItem(1, 35))); + int continuous_scanning_row = m_wiimote_layout->rowCount(); + m_wiimote_layout->addWidget(m_wiimote_continuous_scanning, continuous_scanning_row, 0, 1, 2); + m_wiimote_layout->addWidget(m_wiimote_refresh, continuous_scanning_row, 2); + + m_wiimote_layout->addWidget(m_wiimote_real_balance_board, m_wiimote_layout->rowCount(), 0, 1, -1); + m_wiimote_layout->addWidget(m_wiimote_speaker_data, m_wiimote_layout->rowCount(), 0, 1, -1); m_wiimote_box->setLayout(m_wiimote_layout); } diff --git a/Source/Core/DolphinQt2/Config/ControllersWindow.h b/Source/Core/DolphinQt2/Config/ControllersWindow.h index 09ebb6fe9a..e8359596a9 100644 --- a/Source/Core/DolphinQt2/Config/ControllersWindow.h +++ b/Source/Core/DolphinQt2/Config/ControllersWindow.h @@ -13,13 +13,12 @@ class QDialogButtonBox; class QCheckBox; class QComboBox; class QHBoxLayout; -class QFormLayout; +class QGridLayout; class QGroupBox; class QLabel; class QVBoxLayout; class QPushButton; class QRadioButton; -class QSpacerItem; class ControllersWindow final : public QDialog { @@ -54,7 +53,7 @@ private: // Gamecube std::array m_gc_mappings; QGroupBox* m_gc_box; - QFormLayout* m_gc_layout; + QGridLayout* m_gc_layout; std::array m_gc_controller_boxes; std::array m_gc_buttons; std::array m_gc_groups; @@ -62,7 +61,7 @@ private: // Wii Remote std::array m_wiimote_mappings; QGroupBox* m_wiimote_box; - QFormLayout* m_wiimote_layout; + QGridLayout* m_wiimote_layout; std::array m_wiimote_labels; std::array m_wiimote_boxes; std::array m_wiimote_buttons; From 0cc88342d60cf20aa9866509c1cf0b91973b9ce9 Mon Sep 17 00:00:00 2001 From: Michael Maltese Date: Sat, 27 May 2017 03:05:00 -0700 Subject: [PATCH 2/2] DolphinQt2: add indentation back to ControllerWindow --- .../DolphinQt2/Config/ControllersWindow.cpp | 71 +++++++++++++++---- 1 file changed, 56 insertions(+), 15 deletions(-) diff --git a/Source/Core/DolphinQt2/Config/ControllersWindow.cpp b/Source/Core/DolphinQt2/Config/ControllersWindow.cpp index 3e0a6ac432..40cd5cdeb6 100644 --- a/Source/Core/DolphinQt2/Config/ControllersWindow.cpp +++ b/Source/Core/DolphinQt2/Config/ControllersWindow.cpp @@ -2,6 +2,7 @@ // Licensed under GPLv2+ // Refer to the license.txt file included. +#include #include #include #include @@ -14,6 +15,7 @@ #include #include #include +#include #include #include @@ -110,10 +112,49 @@ void ControllersWindow::CreateGamecubeLayout() m_gc_box->setLayout(m_gc_layout); } +static int GetRadioButtonIndicatorWidth() +{ + const QStyle* style = QApplication::style(); + QStyleOptionButton opt; + + // TODO: why does the macOS style act different? Is it because of the magic with + // Cocoa widgets it does behind the scenes? + if (style->objectName() == QStringLiteral("macintosh")) + return style->subElementRect(QStyle::SE_RadioButtonIndicator, &opt).width(); + + return style->subElementRect(QStyle::SE_RadioButtonContents, &opt).left(); +} + +static int GetLayoutHorizontalSpacing(const QGridLayout* layout) +{ + // TODO: shouldn't layout->horizontalSpacing() do all this? Why does it return -1? + int hspacing = layout->horizontalSpacing(); + if (hspacing >= 0) + return hspacing; + + // According to docs, this is the fallback if horizontalSpacing() isn't set. + auto style = layout->parentWidget()->style(); + hspacing = style->pixelMetric(QStyle::PM_LayoutHorizontalSpacing); + if (hspacing >= 0) + return hspacing; + + // Docs claim this is deprecated, but on macOS with Qt 5.8 this is the only one that actually + // works. + float pixel_ratio = QGuiApplication::primaryScreen()->devicePixelRatio(); + hspacing = pixel_ratio * style->pixelMetric(QStyle::PM_DefaultLayoutSpacing); + if (hspacing >= 0) + return hspacing; + + // Ripped from qtbase/src/widgets/styles/qcommonstyle.cpp + return pixel_ratio * 6; +} + void ControllersWindow::CreateWiimoteLayout() { - m_wiimote_box = new QGroupBox(tr("Wii Remotes")); m_wiimote_layout = new QGridLayout(); + m_wiimote_box = new QGroupBox(tr("Wii Remotes")); + m_wiimote_box->setLayout(m_wiimote_layout); + m_wiimote_passthrough = new QRadioButton(tr("Use Bluetooth Passthrough")); m_wiimote_sync = new QPushButton(tr("Sync")); m_wiimote_reset = new QPushButton(tr("Reset")); @@ -126,18 +167,20 @@ void ControllersWindow::CreateWiimoteLayout() m_wiimote_speaker_data = new QCheckBox(tr("Enable Speaker Data")); m_wiimote_layout->setVerticalSpacing(7); - m_wiimote_layout->setColumnStretch(1, 1); + m_wiimote_layout->setColumnMinimumWidth(0, GetRadioButtonIndicatorWidth() - + GetLayoutHorizontalSpacing(m_wiimote_layout)); + m_wiimote_layout->setColumnStretch(2, 1); // Passthrough BT m_wiimote_layout->addWidget(m_wiimote_passthrough, m_wiimote_layout->rowCount(), 0, 1, -1); int sync_row = m_wiimote_layout->rowCount(); - m_wiimote_layout->addWidget(m_wiimote_pt_labels[0], sync_row, 0, 1, 2); - m_wiimote_layout->addWidget(m_wiimote_sync, sync_row, 2); + m_wiimote_layout->addWidget(m_wiimote_pt_labels[0], sync_row, 1, 1, 2); + m_wiimote_layout->addWidget(m_wiimote_sync, sync_row, 3); int reset_row = m_wiimote_layout->rowCount(); - m_wiimote_layout->addWidget(m_wiimote_pt_labels[1], reset_row, 0, 1, 2); - m_wiimote_layout->addWidget(m_wiimote_reset, reset_row, 2); + m_wiimote_layout->addWidget(m_wiimote_pt_labels[1], reset_row, 1, 1, 2); + m_wiimote_layout->addWidget(m_wiimote_reset, reset_row, 3); // Emulated BT m_wiimote_layout->addWidget(m_wiimote_emu, m_wiimote_layout->rowCount(), 0, 1, -1); @@ -155,19 +198,17 @@ void ControllersWindow::CreateWiimoteLayout() } int wm_row = m_wiimote_layout->rowCount(); - m_wiimote_layout->addWidget(wm_label, wm_row, 0); - m_wiimote_layout->addWidget(wm_box, wm_row, 1); - m_wiimote_layout->addWidget(wm_button, wm_row, 2); + m_wiimote_layout->addWidget(wm_label, wm_row, 1); + m_wiimote_layout->addWidget(wm_box, wm_row, 2); + m_wiimote_layout->addWidget(wm_button, wm_row, 3); } int continuous_scanning_row = m_wiimote_layout->rowCount(); - m_wiimote_layout->addWidget(m_wiimote_continuous_scanning, continuous_scanning_row, 0, 1, 2); - m_wiimote_layout->addWidget(m_wiimote_refresh, continuous_scanning_row, 2); + m_wiimote_layout->addWidget(m_wiimote_continuous_scanning, continuous_scanning_row, 1, 1, 2); + m_wiimote_layout->addWidget(m_wiimote_refresh, continuous_scanning_row, 3); - m_wiimote_layout->addWidget(m_wiimote_real_balance_board, m_wiimote_layout->rowCount(), 0, 1, -1); - m_wiimote_layout->addWidget(m_wiimote_speaker_data, m_wiimote_layout->rowCount(), 0, 1, -1); - - m_wiimote_box->setLayout(m_wiimote_layout); + m_wiimote_layout->addWidget(m_wiimote_real_balance_board, m_wiimote_layout->rowCount(), 1, 1, -1); + m_wiimote_layout->addWidget(m_wiimote_speaker_data, m_wiimote_layout->rowCount(), 1, 1, -1); } void ControllersWindow::CreateAdvancedLayout()