Merge pull request #6436 from spycrab/qt_layout

Qt: Improve spacing
This commit is contained in:
Anthony 2018-03-17 09:57:51 -07:00 committed by GitHub
commit 87c6ed3e00
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
14 changed files with 116 additions and 51 deletions

View File

@ -102,6 +102,7 @@ set(SRCS
QtUtils/ImageConverter.cpp QtUtils/ImageConverter.cpp
QtUtils/ListTabWidget.cpp QtUtils/ListTabWidget.cpp
QtUtils/WindowActivationEventFilter.cpp QtUtils/WindowActivationEventFilter.cpp
QtUtils/WrapInScrollArea.cpp
QtUtils/AspectRatioWidget.cpp QtUtils/AspectRatioWidget.cpp
Settings/AdvancedPane.cpp Settings/AdvancedPane.cpp
Settings/AudioPane.cpp Settings/AudioPane.cpp

View File

@ -30,6 +30,7 @@
#include "Core/NetPlayProto.h" #include "Core/NetPlayProto.h"
#include "DolphinQt2/Config/Mapping/GCPadWiiUConfigDialog.h" #include "DolphinQt2/Config/Mapping/GCPadWiiUConfigDialog.h"
#include "DolphinQt2/Config/Mapping/MappingWindow.h" #include "DolphinQt2/Config/Mapping/MappingWindow.h"
#include "DolphinQt2/QtUtils/WrapInScrollArea.h"
#include "DolphinQt2/Settings.h" #include "DolphinQt2/Settings.h"
#include "UICommon/UICommon.h" #include "UICommon/UICommon.h"
@ -221,15 +222,15 @@ void ControllersWindow::CreateAdvancedLayout()
void ControllersWindow::CreateMainLayout() void ControllersWindow::CreateMainLayout()
{ {
m_main_layout = new QVBoxLayout(); auto* layout = new QVBoxLayout();
m_button_box = new QDialogButtonBox(QDialogButtonBox::Ok); m_button_box = new QDialogButtonBox(QDialogButtonBox::Ok);
m_main_layout->addWidget(m_gc_box); layout->addWidget(m_gc_box);
m_main_layout->addWidget(m_wiimote_box); layout->addWidget(m_wiimote_box);
m_main_layout->addWidget(m_advanced_box); layout->addWidget(m_advanced_box);
m_main_layout->addWidget(m_button_box); layout->addWidget(m_button_box);
setLayout(m_main_layout); WrapInScrollArea(this, layout);
} }
void ControllersWindow::ConnectWidgets() void ControllersWindow::ConnectWidgets()

View File

@ -47,7 +47,6 @@ private:
void LoadSettings(); void LoadSettings();
// Main // Main
QVBoxLayout* m_main_layout;
QDialogButtonBox* m_button_box; QDialogButtonBox* m_button_box;
// Gamecube // Gamecube

View File

@ -64,7 +64,9 @@ void GeckoCodeWidget::CreateWidgets()
m_add_code = new QPushButton(tr("&Add New Code...")); m_add_code = new QPushButton(tr("&Add New Code..."));
m_edit_code = new QPushButton(tr("&Edit Code...")); m_edit_code = new QPushButton(tr("&Edit Code..."));
m_remove_code = new QPushButton(tr("&Remove Code")); m_remove_code = new QPushButton(tr("&Remove Code"));
m_download_codes = new QPushButton(tr("Download Codes (WiiRD Database)")); m_download_codes = new QPushButton(tr("Download Codes"));
m_download_codes->setToolTip(tr("Download Codes from the WiiRD Database"));
m_download_codes->setEnabled(!m_game_id.empty()); m_download_codes->setEnabled(!m_game_id.empty());
m_edit_code->setEnabled(false); m_edit_code->setEnabled(false);

View File

@ -18,6 +18,7 @@
#include "DolphinQt2/Config/Graphics/HacksWidget.h" #include "DolphinQt2/Config/Graphics/HacksWidget.h"
#include "DolphinQt2/Config/Graphics/SoftwareRendererWidget.h" #include "DolphinQt2/Config/Graphics/SoftwareRendererWidget.h"
#include "DolphinQt2/MainWindow.h" #include "DolphinQt2/MainWindow.h"
#include "DolphinQt2/QtUtils/WrapInScrollArea.h"
GraphicsWindow::GraphicsWindow(X11Utils::XRRConfiguration* xrr_config, MainWindow* parent) GraphicsWindow::GraphicsWindow(X11Utils::XRRConfiguration* xrr_config, MainWindow* parent)
: QDialog(parent), m_xrr_config(xrr_config) : QDialog(parent), m_xrr_config(xrr_config)
@ -67,14 +68,14 @@ void GraphicsWindow::CreateMainLayout()
if (SConfig::GetInstance().m_strVideoBackend != "Software Renderer") if (SConfig::GetInstance().m_strVideoBackend != "Software Renderer")
{ {
m_tab_widget->addTab(m_general_widget, tr("General")); m_tab_widget->addTab(GetWrappedWidget(m_general_widget, this, 250), tr("General"));
m_tab_widget->addTab(m_enhancements_widget, tr("Enhancements")); m_tab_widget->addTab(GetWrappedWidget(m_enhancements_widget, this, 250), tr("Enhancements"));
m_tab_widget->addTab(m_hacks_widget, tr("Hacks")); m_tab_widget->addTab(GetWrappedWidget(m_hacks_widget, this, 250), tr("Hacks"));
m_tab_widget->addTab(m_advanced_widget, tr("Advanced")); m_tab_widget->addTab(GetWrappedWidget(m_advanced_widget, this, 250), tr("Advanced"));
} }
else else
{ {
m_tab_widget->addTab(m_software_renderer, tr("Software Renderer")); m_tab_widget->addTab(GetWrappedWidget(m_software_renderer, this, 250), tr("Software Renderer"));
} }
setLayout(main_layout); setLayout(main_layout);

View File

@ -22,8 +22,10 @@
InfoWidget::InfoWidget(const UICommon::GameFile& game) : m_game(game) InfoWidget::InfoWidget(const UICommon::GameFile& game) : m_game(game)
{ {
QVBoxLayout* layout = new QVBoxLayout(); QVBoxLayout* layout = new QVBoxLayout();
layout->addWidget(CreateISODetails()); layout->addWidget(CreateISODetails());
layout->addWidget(CreateBannerDetails()); layout->addWidget(CreateBannerDetails());
setLayout(layout); setLayout(layout);
} }
@ -32,8 +34,15 @@ QGroupBox* InfoWidget::CreateISODetails()
QGroupBox* group = new QGroupBox(tr("ISO Details")); QGroupBox* group = new QGroupBox(tr("ISO Details"));
QFormLayout* layout = new QFormLayout; QFormLayout* layout = new QFormLayout;
QLineEdit* file_path = CreateValueDisplay(m_game.GetFilePath()); QLineEdit* file_path = CreateValueDisplay(
QLineEdit* internal_name = CreateValueDisplay(m_game.GetInternalName()); QStringLiteral("%1 (%2)")
.arg(QString::fromStdString(m_game.GetFilePath()))
.arg(QString::fromStdString(UICommon::FormatSize(m_game.GetFileSize()))));
QLineEdit* internal_name =
CreateValueDisplay(tr("%1 (Disc %2, Revision %3)")
.arg(QString::fromStdString(m_game.GetInternalName()))
.arg(m_game.GetDiscNumber())
.arg(m_game.GetRevision()));
QString game_id_string = QString::fromStdString(m_game.GetGameID()); QString game_id_string = QString::fromStdString(m_game.GetGameID());
if (const u64 title_id = m_game.GetTitleID()) if (const u64 title_id = m_game.GetTitleID())
@ -41,24 +50,16 @@ QGroupBox* InfoWidget::CreateISODetails()
QLineEdit* game_id = CreateValueDisplay(game_id_string); QLineEdit* game_id = CreateValueDisplay(game_id_string);
QLineEdit* country = CreateValueDisplay(DiscIO::GetName(m_game.GetCountry(), true)); QLineEdit* country = CreateValueDisplay(DiscIO::GetName(m_game.GetCountry(), true));
QLineEdit* maker = CreateValueDisplay(m_game.GetMaker()); QLineEdit* maker = CreateValueDisplay(m_game.GetMaker() + " (0x" + m_game.GetMakerID() + ")");
QLineEdit* maker_id = CreateValueDisplay("0x" + m_game.GetMakerID());
QLineEdit* disc_number = CreateValueDisplay(QString::number(m_game.GetDiscNumber()));
QLineEdit* revision = CreateValueDisplay(QString::number(m_game.GetRevision()));
QLineEdit* apploader_date = CreateValueDisplay(m_game.GetApploaderDate()); QLineEdit* apploader_date = CreateValueDisplay(m_game.GetApploaderDate());
QLineEdit* iso_size = CreateValueDisplay(UICommon::FormatSize(m_game.GetFileSize()));
QWidget* checksum = CreateChecksumComputer(); QWidget* checksum = CreateChecksumComputer();
layout->addRow(tr("File Path:"), file_path); layout->addRow(tr("Name:"), internal_name);
layout->addRow(tr("Internal Name:"), internal_name); layout->addRow(tr("File:"), file_path);
layout->addRow(tr("Game ID:"), game_id); layout->addRow(tr("Game ID:"), game_id);
layout->addRow(tr("Country:"), country); layout->addRow(tr("Country:"), country);
layout->addRow(tr("Maker:"), maker); layout->addRow(tr("Maker:"), maker);
layout->addRow(tr("Maker ID:"), maker_id);
layout->addRow(tr("Disc Number:"), disc_number);
layout->addRow(tr("Revision:"), revision);
layout->addRow(tr("Apploader Date:"), apploader_date); layout->addRow(tr("Apploader Date:"), apploader_date);
layout->addRow(tr("ISO Size:"), iso_size);
layout->addRow(tr("MD5 Checksum:"), checksum); layout->addRow(tr("MD5 Checksum:"), checksum);
group->setLayout(layout); group->setLayout(layout);
@ -70,10 +71,8 @@ QGroupBox* InfoWidget::CreateBannerDetails()
QGroupBox* group = new QGroupBox(tr("Banner Details")); QGroupBox* group = new QGroupBox(tr("Banner Details"));
QFormLayout* layout = new QFormLayout; QFormLayout* layout = new QFormLayout;
m_long_name = CreateValueDisplay(); m_name = CreateValueDisplay();
m_short_name = CreateValueDisplay(); m_maker = CreateValueDisplay();
m_short_maker = CreateValueDisplay();
m_long_maker = CreateValueDisplay();
m_description = new QTextEdit(); m_description = new QTextEdit();
m_description->setReadOnly(true); m_description->setReadOnly(true);
CreateLanguageSelector(); CreateLanguageSelector();
@ -81,15 +80,13 @@ QGroupBox* InfoWidget::CreateBannerDetails()
layout->addRow(tr("Show Language:"), m_language_selector); layout->addRow(tr("Show Language:"), m_language_selector);
if (m_game.GetPlatform() == DiscIO::Platform::GAMECUBE_DISC) if (m_game.GetPlatform() == DiscIO::Platform::GAMECUBE_DISC)
{ {
layout->addRow(tr("Short Name:"), m_short_name); layout->addRow(tr("Name:"), m_name);
layout->addRow(tr("Short Maker:"), m_short_maker); layout->addRow(tr("Maker:"), m_maker);
layout->addRow(tr("Long Name:"), m_long_name);
layout->addRow(tr("Long Maker:"), m_long_maker);
layout->addRow(tr("Description:"), m_description); layout->addRow(tr("Description:"), m_description);
} }
else if (DiscIO::IsWii(m_game.GetPlatform())) else if (DiscIO::IsWii(m_game.GetPlatform()))
{ {
layout->addRow(tr("Name:"), m_long_name); layout->addRow(tr("Name:"), m_name);
} }
QPixmap banner = ToQPixmap(m_game.GetBannerImage()); QPixmap banner = ToQPixmap(m_game.GetBannerImage());
@ -156,10 +153,8 @@ void InfoWidget::ChangeLanguage()
{ {
DiscIO::Language language = DiscIO::Language language =
static_cast<DiscIO::Language>(m_language_selector->currentData().toInt()); static_cast<DiscIO::Language>(m_language_selector->currentData().toInt());
m_short_name->setText(QString::fromStdString(m_game.GetShortName(language))); m_name->setText(QString::fromStdString(m_game.GetLongName(language)));
m_short_maker->setText(QString::fromStdString(m_game.GetShortMaker(language))); m_maker->setText(QString::fromStdString(m_game.GetLongMaker(language)));
m_long_name->setText(QString::fromStdString(m_game.GetLongName(language)));
m_long_maker->setText(QString::fromStdString(m_game.GetLongMaker(language)));
m_description->setText(QString::fromStdString(m_game.GetDescription(language))); m_description->setText(QString::fromStdString(m_game.GetDescription(language)));
} }

View File

@ -38,9 +38,7 @@ private:
UICommon::GameFile m_game; UICommon::GameFile m_game;
QLineEdit* m_checksum_result; QLineEdit* m_checksum_result;
QComboBox* m_language_selector; QComboBox* m_language_selector;
QLineEdit* m_long_name; QLineEdit* m_name;
QLineEdit* m_short_name; QLineEdit* m_maker;
QLineEdit* m_short_maker;
QLineEdit* m_long_maker;
QTextEdit* m_description; QTextEdit* m_description;
}; };

View File

@ -63,6 +63,10 @@ MappingButton::MappingButton(MappingWidget* widget, ControlReference* ref, bool
}); });
m_timer->start(1000 / 30); m_timer->start(1000 / 30);
setMaximumHeight(24);
setMaximumWidth(200);
setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed);
} }
void MappingButton::Connect() void MappingButton::Connect()

View File

@ -80,7 +80,6 @@ QGroupBox* MappingWidget::CreateGroupBox(const QString& name, ControllerEmu::Con
for (auto& numeric : group->numeric_settings) for (auto& numeric : group->numeric_settings)
{ {
auto* spinbox = new MappingNumeric(this, numeric.get()); auto* spinbox = new MappingNumeric(this, numeric.get());
spinbox->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed);
form_layout->addRow(QString::fromStdString(numeric->m_name), spinbox); form_layout->addRow(QString::fromStdString(numeric->m_name), spinbox);
m_numerics.push_back(spinbox); m_numerics.push_back(spinbox);
} }
@ -88,7 +87,6 @@ QGroupBox* MappingWidget::CreateGroupBox(const QString& name, ControllerEmu::Con
for (auto& boolean : group->boolean_settings) for (auto& boolean : group->boolean_settings)
{ {
auto* checkbox = new MappingBool(this, boolean.get()); auto* checkbox = new MappingBool(this, boolean.get());
checkbox->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed);
form_layout->addRow(checkbox); form_layout->addRow(checkbox);
m_bools.push_back(checkbox); m_bools.push_back(checkbox);
} }

View File

@ -31,6 +31,7 @@
#include "DolphinQt2/Config/Mapping/WiimoteEmuExtension.h" #include "DolphinQt2/Config/Mapping/WiimoteEmuExtension.h"
#include "DolphinQt2/Config/Mapping/WiimoteEmuGeneral.h" #include "DolphinQt2/Config/Mapping/WiimoteEmuGeneral.h"
#include "DolphinQt2/Config/Mapping/WiimoteEmuMotionControl.h" #include "DolphinQt2/Config/Mapping/WiimoteEmuMotionControl.h"
#include "DolphinQt2/QtUtils/WrapInScrollArea.h"
#include "DolphinQt2/Settings.h" #include "DolphinQt2/Settings.h"
#include "InputCommon/ControllerEmu/ControllerEmu.h" #include "InputCommon/ControllerEmu/ControllerEmu.h"
#include "InputCommon/ControllerInterface/ControllerInterface.h" #include "InputCommon/ControllerInterface/ControllerInterface.h"
@ -312,7 +313,7 @@ void MappingWindow::SetMappingType(MappingWindow::Type type)
void MappingWindow::AddWidget(const QString& name, QWidget* widget) void MappingWindow::AddWidget(const QString& name, QWidget* widget)
{ {
m_tab_widget->addTab(widget, name); m_tab_widget->addTab(GetWrappedWidget(widget, this, 150), name);
} }
int MappingWindow::GetPort() const int MappingWindow::GetPort() const

View File

@ -13,6 +13,7 @@
#include "DolphinQt2/Config/InfoWidget.h" #include "DolphinQt2/Config/InfoWidget.h"
#include "DolphinQt2/Config/PatchesWidget.h" #include "DolphinQt2/Config/PatchesWidget.h"
#include "DolphinQt2/Config/PropertiesDialog.h" #include "DolphinQt2/Config/PropertiesDialog.h"
#include "DolphinQt2/QtUtils/WrapInScrollArea.h"
#include "UICommon/GameFile.h" #include "UICommon/GameFile.h"
PropertiesDialog::PropertiesDialog(QWidget* parent, const UICommon::GameFile& game) PropertiesDialog::PropertiesDialog(QWidget* parent, const UICommon::GameFile& game)
@ -37,11 +38,11 @@ PropertiesDialog::PropertiesDialog(QWidget* parent, const UICommon::GameFile& ga
connect(ar, &ARCodeWidget::OpenGeneralSettings, this, &PropertiesDialog::OpenGeneralSettings); connect(ar, &ARCodeWidget::OpenGeneralSettings, this, &PropertiesDialog::OpenGeneralSettings);
tab_widget->addTab(game_config, tr("Game Config")); tab_widget->addTab(GetWrappedWidget(game_config, this), tr("Game Config"));
tab_widget->addTab(patches, tr("Patches")); tab_widget->addTab(GetWrappedWidget(patches, this), tr("Patches"));
tab_widget->addTab(ar, tr("AR Codes")); tab_widget->addTab(GetWrappedWidget(ar, this), tr("AR Codes"));
tab_widget->addTab(gecko, tr("Gecko Codes")); tab_widget->addTab(GetWrappedWidget(gecko, this), tr("Gecko Codes"));
tab_widget->addTab(info, tr("Info")); tab_widget->addTab(GetWrappedWidget(info, this), tr("Info"));
if (DiscIO::IsDisc(game.GetPlatform())) if (DiscIO::IsDisc(game.GetPlatform()))
{ {

View File

@ -120,6 +120,7 @@
<QtMoc Include="NetPlay\PadMappingDialog.h" /> <QtMoc Include="NetPlay\PadMappingDialog.h" />
<QtMoc Include="QtUtils\DoubleClickEventFilter.h" /> <QtMoc Include="QtUtils\DoubleClickEventFilter.h" />
<QtMoc Include="QtUtils\WindowActivationEventFilter.h" /> <QtMoc Include="QtUtils\WindowActivationEventFilter.h" />
<QtMoc Include="QtUtils\WrapInScrollArea.h" />
<QtMoc Include="QtUtils\AspectRatioWidget.h" /> <QtMoc Include="QtUtils\AspectRatioWidget.h" />
<QtMoc Include="RenderWidget.h" /> <QtMoc Include="RenderWidget.h" />
<QtMoc Include="Settings.h" /> <QtMoc Include="Settings.h" />
@ -278,6 +279,7 @@
<ClCompile Include="QtUtils\ImageConverter.cpp" /> <ClCompile Include="QtUtils\ImageConverter.cpp" />
<ClCompile Include="QtUtils\ListTabWidget.cpp" /> <ClCompile Include="QtUtils\ListTabWidget.cpp" />
<ClCompile Include="QtUtils\WindowActivationEventFilter.cpp" /> <ClCompile Include="QtUtils\WindowActivationEventFilter.cpp" />
<ClCompile Include="QtUtils\WrapInScrollArea.cpp" />
<ClCompile Include="QtUtils\AspectRatioWidget.cpp" /> <ClCompile Include="QtUtils\AspectRatioWidget.cpp" />
<ClCompile Include="RenderWidget.cpp" /> <ClCompile Include="RenderWidget.cpp" />
<ClCompile Include="Resources.cpp" /> <ClCompile Include="Resources.cpp" />
@ -320,6 +322,7 @@
<ClInclude Include="QtUtils\ElidedButton.h" /> <ClInclude Include="QtUtils\ElidedButton.h" />
<ClInclude Include="QtUtils\ImageConverter.h" /> <ClInclude Include="QtUtils\ImageConverter.h" />
<ClInclude Include="QtUtils\ListTabWidget.h" /> <ClInclude Include="QtUtils\ListTabWidget.h" />
<ClInclude Include="QtUtils\WrapInScrollArea.h" />
<ClInclude Include="Resources.h" /> <ClInclude Include="Resources.h" />
<ClInclude Include="Settings\GameCubePane.h" /> <ClInclude Include="Settings\GameCubePane.h" />
<ClInclude Include="Settings\PathPane.h" /> <ClInclude Include="Settings\PathPane.h" />

View File

@ -0,0 +1,48 @@
// Copyright 2018 Dolphin Emulator Project
// Licensed under GPLv2+
// Refer to the license.txt file included.
#include "DolphinQt2/QtUtils/WrapInScrollArea.h"
#include <QFrame>
#include <QLayout>
#include <QScrollArea>
#include <QVBoxLayout>
#include <QWidget>
QWidget* GetWrappedWidget(QWidget* wrapped_widget, QWidget* to_resize, int margin)
{
auto* scroll = new QScrollArea;
scroll->setWidget(wrapped_widget);
scroll->setWidgetResizable(true);
scroll->setFrameStyle(QFrame::NoFrame);
if (to_resize != nullptr)
{
// For some reason width() is bigger than it needs to be.
int recommended_width = wrapped_widget->width() * 0.9;
int recommended_height = wrapped_widget->height() + margin;
to_resize->resize(std::max(recommended_width, to_resize->width()),
std::max(recommended_height, to_resize->height()));
}
return scroll;
}
void WrapInScrollArea(QWidget* parent, QLayout* wrapped_layout, QWidget* to_resize)
{
if (to_resize == nullptr)
to_resize = parent;
auto* widget = new QWidget;
widget->setLayout(wrapped_layout);
auto* scroll_area = GetWrappedWidget(widget, to_resize);
auto* scroll_layout = new QVBoxLayout;
scroll_layout->addWidget(scroll_area);
scroll_layout->setMargin(0);
parent->setLayout(scroll_layout);
}

View File

@ -0,0 +1,13 @@
// Copyright 2018 Dolphin Emulator Project
// Licensed under GPLv2+
// Refer to the license.txt file included.
#pragma once
class QLayout;
class QWidget;
QWidget* GetWrappedWidget(QWidget* wrapped_widget, QWidget* to_resize = nullptr, int margin = 50);
// Wrap wrapped_layout in a QScrollArea and fill the parent widget with it
void WrapInScrollArea(QWidget* parent, QLayout* wrapped_layout, QWidget* to_resize = nullptr);