Qt: Unify monospace font usage

This commit is contained in:
Vicki Pfau 2020-12-16 18:15:54 -08:00
parent c4123a2386
commit 71379aac66
14 changed files with 27 additions and 23 deletions

View File

@ -113,6 +113,7 @@ Misc:
- Qt: Window title updates can be disabled (closes mgba.io/i/1912) - Qt: Window title updates can be disabled (closes mgba.io/i/1912)
- Qt: Redo OpenGL context thread handling (fixes mgba.io/i/1724) - Qt: Redo OpenGL context thread handling (fixes mgba.io/i/1724)
- Qt: Discard additional frame draws if waiting fails - Qt: Discard additional frame draws if waiting fails
- Qt: Unify monospace font usage
- SDL: Fall back to sw blit if OpenGL init fails - SDL: Fall back to sw blit if OpenGL init fails
- Util: Reset vector size on deinit - Util: Reset vector size on deinit
- VFS: Change semantics of VFile.sync on mapped files (fixes mgba.io/i/1730) - VFS: Change semantics of VFile.sync on mapped files (fixes mgba.io/i/1730)

View File

@ -5,7 +5,8 @@
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#include "AssetInfo.h" #include "AssetInfo.h"
#include <QFontDatabase> #include "GBAApp.h"
#include <QHBoxLayout> #include <QHBoxLayout>
using namespace QGBA; using namespace QGBA;
@ -19,7 +20,7 @@ void AssetInfo::addCustomProperty(const QString& id, const QString& visibleName)
QHBoxLayout* newLayout = new QHBoxLayout; QHBoxLayout* newLayout = new QHBoxLayout;
newLayout->addWidget(new QLabel(visibleName)); newLayout->addWidget(new QLabel(visibleName));
QLabel* value = new QLabel; QLabel* value = new QLabel;
value->setFont(QFontDatabase::systemFont(QFontDatabase::FixedFont)); value->setFont(GBAApp::monospaceFont());
value->setAlignment(Qt::AlignRight); value->setAlignment(Qt::AlignRight);
newLayout->addWidget(value); newLayout->addWidget(value);
m_customProperties[id] = value; m_customProperties[id] = value;

View File

@ -8,7 +8,6 @@
#include "CoreController.h" #include "CoreController.h"
#include "GBAApp.h" #include "GBAApp.h"
#include <QFontDatabase>
#include <QHBoxLayout> #include <QHBoxLayout>
#include <mgba/core/interface.h> #include <mgba/core/interface.h>
@ -32,7 +31,7 @@ AssetTile::AssetTile(QWidget* parent)
connect(m_ui.preview, &Swatch::indexPressed, this, &AssetTile::selectColor); connect(m_ui.preview, &Swatch::indexPressed, this, &AssetTile::selectColor);
const QFont font = QFontDatabase::systemFont(QFontDatabase::FixedFont); const QFont font = GBAApp::monospaceFont();
m_ui.tileId->setFont(font); m_ui.tileId->setFont(font);
m_ui.paletteId->setFont(font); m_ui.paletteId->setFont(font);

View File

@ -5,6 +5,7 @@
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#include "CheatsModel.h" #include "CheatsModel.h"
#include "GBAApp.h"
#include "LogController.h" #include "LogController.h"
#include "VFileDevice.h" #include "VFileDevice.h"
@ -19,8 +20,7 @@ CheatsModel::CheatsModel(mCheatDevice* device, QObject* parent)
: QAbstractItemModel(parent) : QAbstractItemModel(parent)
, m_device(device) , m_device(device)
{ {
m_font.setFamily("Source Code Pro"); m_font = GBAApp::monospaceFont();
m_font.setStyleHint(QFont::Monospace);
} }
QVariant CheatsModel::data(const QModelIndex& index, int role) const { QVariant CheatsModel::data(const QModelIndex& index, int role) const {

View File

@ -16,6 +16,7 @@
#include <QFileInfo> #include <QFileInfo>
#include <QFileOpenEvent> #include <QFileOpenEvent>
#include <QFontDatabase>
#include <QIcon> #include <QIcon>
#include <mgba-util/socket.h> #include <mgba-util/socket.h>
@ -35,11 +36,14 @@ static GBAApp* g_app = nullptr;
mLOG_DEFINE_CATEGORY(QT, "Qt", "platform.qt"); mLOG_DEFINE_CATEGORY(QT, "Qt", "platform.qt");
QFont GBAApp::s_monospace;
GBAApp::GBAApp(int& argc, char* argv[], ConfigController* config) GBAApp::GBAApp(int& argc, char* argv[], ConfigController* config)
: QApplication(argc, argv) : QApplication(argc, argv)
, m_configController(config) , m_configController(config)
{ {
g_app = this; g_app = this;
s_monospace = QFontDatabase::systemFont(QFontDatabase::FixedFont);
#ifdef BUILD_SDL #ifdef BUILD_SDL
SDL_Init(SDL_INIT_NOPARACHUTE); SDL_Init(SDL_INIT_NOPARACHUTE);

View File

@ -7,6 +7,7 @@
#include <QApplication> #include <QApplication>
#include <QFileDialog> #include <QFileDialog>
#include <QFont>
#include <QList> #include <QList>
#include <QMap> #include <QMap>
#include <QMultiMap> #include <QMultiMap>
@ -56,6 +57,8 @@ public:
static QString dataDir(); static QString dataDir();
static QFont monospaceFont() { return s_monospace; }
QList<Window*> windows() { return m_windows; } QList<Window*> windows() { return m_windows; }
Window* newWindow(); Window* newWindow();
@ -111,6 +114,8 @@ private:
QThreadPool m_workerThreads; QThreadPool m_workerThreads;
qint64 m_nextJob = 1; qint64 m_nextJob = 1;
static QFont s_monospace;
NoIntroDB* m_db = nullptr; NoIntroDB* m_db = nullptr;
}; };

View File

@ -6,9 +6,9 @@
#include "IOViewer.h" #include "IOViewer.h"
#include "CoreController.h" #include "CoreController.h"
#include "GBAApp.h"
#include <QComboBox> #include <QComboBox>
#include <QFontDatabase>
#include <QGridLayout> #include <QGridLayout>
#include <QSpinBox> #include <QSpinBox>
@ -1037,7 +1037,7 @@ IOViewer::IOViewer(std::shared_ptr<CoreController> controller, QWidget* parent)
m_ui.regSelect->addItem("0x0400" + QString("%1: %2").arg(i << 1, 4, 16, QChar('0')).toUpper().arg(reg), i << 1); m_ui.regSelect->addItem("0x0400" + QString("%1: %2").arg(i << 1, 4, 16, QChar('0')).toUpper().arg(reg), i << 1);
} }
const QFont font = QFontDatabase::systemFont(QFontDatabase::FixedFont); const QFont font = GBAApp::monospaceFont();
m_ui.regValue->setFont(font); m_ui.regValue->setFont(font);
connect(m_ui.buttonBox, &QDialogButtonBox::clicked, this, &IOViewer::buttonPressed); connect(m_ui.buttonBox, &QDialogButtonBox::clicked, this, &IOViewer::buttonPressed);

View File

@ -25,7 +25,6 @@
#include <QAction> #include <QAction>
#include <QButtonGroup> #include <QButtonGroup>
#include <QClipboard> #include <QClipboard>
#include <QFontDatabase>
#include <QMouseEvent> #include <QMouseEvent>
#include <QRadioButton> #include <QRadioButton>
#include <QTimer> #include <QTimer>

View File

@ -27,8 +27,7 @@ using namespace QGBA;
MemoryModel::MemoryModel(QWidget* parent) MemoryModel::MemoryModel(QWidget* parent)
: QAbstractScrollArea(parent) : QAbstractScrollArea(parent)
{ {
m_font.setFamily("Source Code Pro"); m_font = GBAApp::monospaceFont();
m_font.setStyleHint(QFont::Monospace);
#ifdef Q_OS_MAC #ifdef Q_OS_MAC
m_font.setPointSize(12); m_font.setPointSize(12);
#else #else

View File

@ -5,9 +5,9 @@
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#include "MessagePainter.h" #include "MessagePainter.h"
#include <QPainter> #include "GBAApp.h"
#include <QDebug> #include <QPainter>
#include <mgba/gba/interface.h> #include <mgba/gba/interface.h>
@ -16,8 +16,7 @@ using namespace QGBA;
MessagePainter::MessagePainter(QObject* parent) MessagePainter::MessagePainter(QObject* parent)
: QObject(parent) : QObject(parent)
{ {
m_messageFont.setFamily("Source Code Pro"); m_messageFont = GBAApp::monospaceFont();
m_messageFont.setStyleHint(QFont::Monospace);
m_messageFont.setPixelSize(13); m_messageFont.setPixelSize(13);
connect(&m_messageTimer, &QTimer::timeout, this, &MessagePainter::clearMessage); connect(&m_messageTimer, &QTimer::timeout, this, &MessagePainter::clearMessage);
m_messageTimer.setSingleShot(true); m_messageTimer.setSingleShot(true);

View File

@ -10,7 +10,6 @@
#include <QAction> #include <QAction>
#include <QClipboard> #include <QClipboard>
#include <QFontDatabase>
#include <QListWidgetItem> #include <QListWidgetItem>
#include <QTimer> #include <QTimer>
@ -34,7 +33,7 @@ ObjView::ObjView(std::shared_ptr<CoreController> controller, QWidget* parent)
m_ui.setupUi(this); m_ui.setupUi(this);
m_ui.tile->setController(controller); m_ui.tile->setController(controller);
const QFont font = QFontDatabase::systemFont(QFontDatabase::FixedFont); const QFont font = GBAApp::monospaceFont();
m_ui.x->setFont(font); m_ui.x->setFont(font);
m_ui.y->setFont(font); m_ui.y->setFont(font);

View File

@ -11,7 +11,6 @@
#include "VFileDevice.h" #include "VFileDevice.h"
#include <QFileDialog> #include <QFileDialog>
#include <QFontDatabase>
#include <mgba/core/core.h> #include <mgba/core/core.h>
#ifdef M_CORE_GBA #ifdef M_CORE_GBA
@ -48,7 +47,7 @@ PaletteView::PaletteView(std::shared_ptr<CoreController> controller, QWidget* pa
m_ui.selected->setDimensions(QSize(1, 1)); m_ui.selected->setDimensions(QSize(1, 1));
updatePalette(); updatePalette();
const QFont font = QFontDatabase::systemFont(QFontDatabase::FixedFont); const QFont font = GBAApp::monospaceFont();
m_ui.hexcode->setFont(font); m_ui.hexcode->setFont(font);
m_ui.value->setFont(font); m_ui.value->setFont(font);

View File

@ -6,6 +6,7 @@
#include "RegisterView.h" #include "RegisterView.h"
#include "CoreController.h" #include "CoreController.h"
#include "GBAApp.h"
#ifdef M_CORE_GBA #ifdef M_CORE_GBA
#include <mgba/internal/arm/arm.h> #include <mgba/internal/arm/arm.h>
@ -14,7 +15,6 @@
#include <mgba/internal/sm83/sm83.h> #include <mgba/internal/sm83/sm83.h>
#endif #endif
#include <QFontDatabase>
#include <QFormLayout> #include <QFormLayout>
#include <QLabel> #include <QLabel>
@ -74,7 +74,7 @@ RegisterView::RegisterView(std::shared_ptr<CoreController> controller, QWidget*
void RegisterView::addRegisters(const QStringList& names) { void RegisterView::addRegisters(const QStringList& names) {
QFormLayout* form = static_cast<QFormLayout*>(layout()); QFormLayout* form = static_cast<QFormLayout*>(layout());
const QFont font = QFontDatabase::systemFont(QFontDatabase::FixedFont); const QFont font = GBAApp::monospaceFont();
for (const auto& reg : names) { for (const auto& reg : names) {
QLabel* value = new QLabel; QLabel* value = new QLabel;
value->setTextInteractionFlags(Qt::TextSelectableByMouse); value->setTextInteractionFlags(Qt::TextSelectableByMouse);

View File

@ -10,7 +10,6 @@
#include <QAction> #include <QAction>
#include <QClipboard> #include <QClipboard>
#include <QFontDatabase>
#include <QTimer> #include <QTimer>
#ifdef M_CORE_GB #ifdef M_CORE_GB