mirror of https://github.com/mgba-emu/mgba.git
Qt: Refactor GB names and lists into namespace
This commit is contained in:
parent
f5a1ceb025
commit
ddc913c13a
|
@ -16,7 +16,7 @@ if(BUILD_SDL)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(POLICY CMP0071)
|
if(POLICY CMP0071)
|
||||||
cmake_policy(SET CMP0071 OLD)
|
cmake_policy(SET CMP0071 NEW)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(CMAKE_AUTOMOC ON)
|
set(CMAKE_AUTOMOC ON)
|
||||||
|
@ -154,6 +154,7 @@ set(GBA_SRC
|
||||||
GBAOverride.cpp)
|
GBAOverride.cpp)
|
||||||
|
|
||||||
set(GB_SRC
|
set(GB_SRC
|
||||||
|
GameBoy.cpp
|
||||||
GBOverride.cpp
|
GBOverride.cpp
|
||||||
PrinterView.cpp)
|
PrinterView.cpp)
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,94 @@
|
||||||
|
/* Copyright (c) 2013-2020 Jeffrey Pfau
|
||||||
|
*
|
||||||
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
#include "GameBoy.h"
|
||||||
|
|
||||||
|
#include <QCoreApplication>
|
||||||
|
#include <QMap>
|
||||||
|
|
||||||
|
using namespace QGBA;
|
||||||
|
|
||||||
|
static const QList<GBModel> s_gbModelList{
|
||||||
|
GB_MODEL_DMG,
|
||||||
|
GB_MODEL_SGB,
|
||||||
|
GB_MODEL_CGB,
|
||||||
|
GB_MODEL_AGB,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const QList<GBMemoryBankControllerType> s_mbcList{
|
||||||
|
GB_MBC_NONE,
|
||||||
|
GB_MBC1,
|
||||||
|
GB_MBC2,
|
||||||
|
GB_MBC3,
|
||||||
|
GB_MBC3_RTC,
|
||||||
|
GB_MBC5,
|
||||||
|
GB_MBC5_RUMBLE,
|
||||||
|
GB_MBC6,
|
||||||
|
GB_MBC7,
|
||||||
|
GB_MMM01,
|
||||||
|
GB_POCKETCAM,
|
||||||
|
GB_TAMA5,
|
||||||
|
GB_HuC1,
|
||||||
|
GB_HuC3,
|
||||||
|
GB_UNL_WISDOM_TREE,
|
||||||
|
GB_UNL_BBD,
|
||||||
|
GB_UNL_HITEK,
|
||||||
|
GB_UNL_PKJD,
|
||||||
|
};
|
||||||
|
|
||||||
|
static QMap<GBModel, QString> s_gbModelNames;
|
||||||
|
static QMap<GBMemoryBankControllerType, QString> s_mbcNames;
|
||||||
|
|
||||||
|
static QString tr(const char* str) {
|
||||||
|
return QCoreApplication::translate("Game Boy", str);
|
||||||
|
}
|
||||||
|
|
||||||
|
QList<GBModel> GameBoy::modelList() {
|
||||||
|
return s_gbModelList;
|
||||||
|
}
|
||||||
|
|
||||||
|
QString GameBoy::modelName(GBModel model) {
|
||||||
|
if (s_gbModelNames.isEmpty()) {
|
||||||
|
s_gbModelNames[GB_MODEL_AUTODETECT] = tr("Autodetect");
|
||||||
|
s_gbModelNames[GB_MODEL_DMG] = tr("Game Boy (DMG)");
|
||||||
|
s_gbModelNames[GB_MODEL_MGB] = tr("Game Boy Pocket (MGB)");
|
||||||
|
s_gbModelNames[GB_MODEL_SGB] = tr("Super Game Boy (SGB)");
|
||||||
|
s_gbModelNames[GB_MODEL_SGB2] = tr("Super Game Boy 2 (SGB)");
|
||||||
|
s_gbModelNames[GB_MODEL_CGB] = tr("Game Boy Color (CGB)");
|
||||||
|
s_gbModelNames[GB_MODEL_AGB] = tr("Game Boy Advance (AGB)");
|
||||||
|
}
|
||||||
|
|
||||||
|
return s_gbModelNames[model];
|
||||||
|
}
|
||||||
|
|
||||||
|
QList<GBMemoryBankControllerType> GameBoy::mbcList() {
|
||||||
|
return s_mbcList;
|
||||||
|
}
|
||||||
|
|
||||||
|
QString GameBoy::mbcName(GBMemoryBankControllerType mbc) {
|
||||||
|
if (s_mbcNames.isEmpty()) {
|
||||||
|
s_mbcNames[GB_MBC_AUTODETECT] = tr("Autodetect");
|
||||||
|
s_mbcNames[GB_MBC_NONE] = tr("ROM Only");
|
||||||
|
s_mbcNames[GB_MBC1] = tr("MBC1");
|
||||||
|
s_mbcNames[GB_MBC2] = tr("MBC2");
|
||||||
|
s_mbcNames[GB_MBC3] = tr("MBC3");
|
||||||
|
s_mbcNames[GB_MBC3_RTC] = tr("MBC3 + RTC");
|
||||||
|
s_mbcNames[GB_MBC5] = tr("MBC5");
|
||||||
|
s_mbcNames[GB_MBC5_RUMBLE] = tr("MBC5 + Rumble");
|
||||||
|
s_mbcNames[GB_MBC6] = tr("MBC6");
|
||||||
|
s_mbcNames[GB_MBC7] = tr("MBC7 (Tilt)");
|
||||||
|
s_mbcNames[GB_MMM01] = tr("MMM01");
|
||||||
|
s_mbcNames[GB_HuC1] = tr("HuC-1");
|
||||||
|
s_mbcNames[GB_HuC3] = tr("HuC-3");
|
||||||
|
s_mbcNames[GB_POCKETCAM] = tr("Pocket Cam");
|
||||||
|
s_mbcNames[GB_TAMA5] = tr("TAMA5");
|
||||||
|
s_mbcNames[GB_UNL_WISDOM_TREE] = tr("Wisdom Tree");
|
||||||
|
s_mbcNames[GB_UNL_PKJD] = tr("Pokémon Jade/Diamond");
|
||||||
|
s_mbcNames[GB_UNL_BBD] = tr("BBD");
|
||||||
|
s_mbcNames[GB_UNL_HITEK] = tr("Hitek");
|
||||||
|
}
|
||||||
|
|
||||||
|
return s_mbcNames[mbc];
|
||||||
|
}
|
|
@ -0,0 +1,25 @@
|
||||||
|
/* Copyright (c) 2013-2020 Jeffrey Pfau
|
||||||
|
*
|
||||||
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <QList>
|
||||||
|
#include <QString>
|
||||||
|
|
||||||
|
#ifdef M_CORE_GB
|
||||||
|
#include <mgba/gb/interface.h>
|
||||||
|
|
||||||
|
namespace QGBA {
|
||||||
|
|
||||||
|
namespace GameBoy {
|
||||||
|
QList<GBModel> modelList();
|
||||||
|
QString modelName(GBModel);
|
||||||
|
|
||||||
|
QList<GBMemoryBankControllerType> mbcList();
|
||||||
|
QString mbcName(GBMemoryBankControllerType);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
#endif
|
|
@ -6,6 +6,7 @@
|
||||||
#include "OverrideView.h"
|
#include "OverrideView.h"
|
||||||
|
|
||||||
#include <QPushButton>
|
#include <QPushButton>
|
||||||
|
#include <QStandardItemModel>
|
||||||
|
|
||||||
#include "ConfigController.h"
|
#include "ConfigController.h"
|
||||||
#include "CoreController.h"
|
#include "CoreController.h"
|
||||||
|
@ -16,53 +17,17 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef M_CORE_GB
|
#ifdef M_CORE_GB
|
||||||
|
#include "GameBoy.h"
|
||||||
#include "GBOverride.h"
|
#include "GBOverride.h"
|
||||||
#include <mgba/internal/gb/gb.h>
|
#include <mgba/internal/gb/gb.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
using namespace QGBA;
|
using namespace QGBA;
|
||||||
|
|
||||||
#ifdef M_CORE_GB
|
|
||||||
QList<enum GBModel> OverrideView::s_gbModelList;
|
|
||||||
QList<enum GBMemoryBankControllerType> OverrideView::s_mbcList;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
OverrideView::OverrideView(ConfigController* config, QWidget* parent)
|
OverrideView::OverrideView(ConfigController* config, QWidget* parent)
|
||||||
: QDialog(parent, Qt::WindowTitleHint | Qt::WindowSystemMenuHint | Qt::WindowCloseButtonHint)
|
: QDialog(parent, Qt::WindowTitleHint | Qt::WindowSystemMenuHint | Qt::WindowCloseButtonHint)
|
||||||
, m_config(config)
|
, m_config(config)
|
||||||
{
|
{
|
||||||
#ifdef M_CORE_GB
|
|
||||||
if (s_mbcList.isEmpty()) {
|
|
||||||
// NB: Keep in sync with OverrideView.ui
|
|
||||||
s_mbcList.append(GB_MBC_AUTODETECT);
|
|
||||||
s_mbcList.append(GB_MBC_NONE);
|
|
||||||
s_mbcList.append(GB_MBC1);
|
|
||||||
s_mbcList.append(GB_MBC2);
|
|
||||||
s_mbcList.append(GB_MBC3);
|
|
||||||
s_mbcList.append(GB_MBC3_RTC);
|
|
||||||
s_mbcList.append(GB_MBC5);
|
|
||||||
s_mbcList.append(GB_MBC5_RUMBLE);
|
|
||||||
s_mbcList.append(GB_MBC6);
|
|
||||||
s_mbcList.append(GB_MBC7);
|
|
||||||
s_mbcList.append(GB_MMM01);
|
|
||||||
s_mbcList.append(GB_POCKETCAM);
|
|
||||||
s_mbcList.append(GB_TAMA5);
|
|
||||||
s_mbcList.append(GB_HuC1);
|
|
||||||
s_mbcList.append(GB_HuC3);
|
|
||||||
s_mbcList.append(GB_UNL_WISDOM_TREE);
|
|
||||||
s_mbcList.append(GB_UNL_BBD);
|
|
||||||
s_mbcList.append(GB_UNL_HITEK);
|
|
||||||
s_mbcList.append(GB_UNL_PKJD);
|
|
||||||
}
|
|
||||||
if (s_gbModelList.isEmpty()) {
|
|
||||||
// NB: Keep in sync with OverrideView.ui
|
|
||||||
s_gbModelList.append(GB_MODEL_AUTODETECT);
|
|
||||||
s_gbModelList.append(GB_MODEL_DMG);
|
|
||||||
s_gbModelList.append(GB_MODEL_SGB);
|
|
||||||
s_gbModelList.append(GB_MODEL_CGB);
|
|
||||||
s_gbModelList.append(GB_MODEL_AGB);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
m_ui.setupUi(this);
|
m_ui.setupUi(this);
|
||||||
|
|
||||||
connect(m_ui.hwAutodetect, &QAbstractButton::toggled, [this] (bool enabled) {
|
connect(m_ui.hwAutodetect, &QAbstractButton::toggled, [this] (bool enabled) {
|
||||||
|
@ -74,6 +39,33 @@ OverrideView::OverrideView(ConfigController* config, QWidget* parent)
|
||||||
});
|
});
|
||||||
|
|
||||||
#ifdef M_CORE_GB
|
#ifdef M_CORE_GB
|
||||||
|
m_ui.gbModel->setItemData(0, GB_MODEL_AUTODETECT);
|
||||||
|
m_ui.mbc->setItemData(0, GB_MBC_AUTODETECT);
|
||||||
|
|
||||||
|
for (auto model : GameBoy::modelList()) {
|
||||||
|
m_ui.gbModel->addItem(GameBoy::modelName(model), model);
|
||||||
|
}
|
||||||
|
|
||||||
|
QStandardItemModel* model = static_cast<QStandardItemModel*>(m_ui.mbc->model());
|
||||||
|
int bitsSeen = 0;
|
||||||
|
for (auto mbc : GameBoy::mbcList()) {
|
||||||
|
int mbcValue = static_cast<int>(mbc);
|
||||||
|
if ((mbcValue & ~bitsSeen) & 0x001) {
|
||||||
|
m_ui.mbc->addItem(tr("Official MBCs"), -2);
|
||||||
|
model->item(m_ui.mbc->count() - 1)->setFlags(Qt::NoItemFlags);
|
||||||
|
}
|
||||||
|
if ((mbcValue & ~bitsSeen) & 0x010) {
|
||||||
|
m_ui.mbc->addItem(tr("Licensed MBCs"), -3);
|
||||||
|
model->item(m_ui.mbc->count() - 1)->setFlags(Qt::NoItemFlags);
|
||||||
|
}
|
||||||
|
if ((mbcValue & ~bitsSeen) & 0x200) {
|
||||||
|
m_ui.mbc->addItem(tr("Unlicensed MBCs"), -4);
|
||||||
|
model->item(m_ui.mbc->count() - 1)->setFlags(Qt::NoItemFlags);
|
||||||
|
}
|
||||||
|
bitsSeen |= mbcValue;
|
||||||
|
m_ui.mbc->addItem(GameBoy::mbcName(mbc), mbc);
|
||||||
|
}
|
||||||
|
|
||||||
m_colorPickers[0] = ColorPicker(m_ui.color0, QColor(0xF8, 0xF8, 0xF8));
|
m_colorPickers[0] = ColorPicker(m_ui.color0, QColor(0xF8, 0xF8, 0xF8));
|
||||||
m_colorPickers[1] = ColorPicker(m_ui.color1, QColor(0xA8, 0xA8, 0xA8));
|
m_colorPickers[1] = ColorPicker(m_ui.color1, QColor(0xA8, 0xA8, 0xA8));
|
||||||
m_colorPickers[2] = ColorPicker(m_ui.color2, QColor(0x50, 0x50, 0x50));
|
m_colorPickers[2] = ColorPicker(m_ui.color2, QColor(0x50, 0x50, 0x50));
|
||||||
|
@ -190,8 +182,8 @@ void OverrideView::updateOverrides() {
|
||||||
#ifdef M_CORE_GB
|
#ifdef M_CORE_GB
|
||||||
if (m_ui.tabWidget->currentWidget() == m_ui.tabGB) {
|
if (m_ui.tabWidget->currentWidget() == m_ui.tabGB) {
|
||||||
std::unique_ptr<GBOverride> gb(new GBOverride);
|
std::unique_ptr<GBOverride> gb(new GBOverride);
|
||||||
gb->override.mbc = s_mbcList[m_ui.mbc->currentIndex()];
|
gb->override.mbc = static_cast<GBMemoryBankControllerType>(m_ui.mbc->currentData().toInt());
|
||||||
gb->override.model = s_gbModelList[m_ui.gbModel->currentIndex()];
|
gb->override.model = static_cast<GBModel>(m_ui.gbModel->currentData().toInt());
|
||||||
bool hasColor = false;
|
bool hasColor = false;
|
||||||
for (int i = 0; i < 12; ++i) {
|
for (int i = 0; i < 12; ++i) {
|
||||||
gb->override.gbColors[i] = m_gbColors[i];
|
gb->override.gbColors[i] = m_gbColors[i];
|
||||||
|
@ -240,13 +232,13 @@ void OverrideView::gameStarted() {
|
||||||
case PLATFORM_GB: {
|
case PLATFORM_GB: {
|
||||||
m_ui.tabWidget->setCurrentWidget(m_ui.tabGB);
|
m_ui.tabWidget->setCurrentWidget(m_ui.tabGB);
|
||||||
GB* gb = static_cast<GB*>(thread->core->board);
|
GB* gb = static_cast<GB*>(thread->core->board);
|
||||||
int mbc = s_mbcList.indexOf(gb->memory.mbcType);
|
int index = m_ui.mbc->findData(gb->memory.mbcType);
|
||||||
if (mbc >= 0) {
|
if (index >= 0) {
|
||||||
m_ui.mbc->setCurrentIndex(mbc);
|
m_ui.mbc->setCurrentIndex(index);
|
||||||
} else {
|
} else {
|
||||||
m_ui.mbc->setCurrentIndex(0);
|
m_ui.mbc->setCurrentIndex(0);
|
||||||
}
|
}
|
||||||
int model = s_gbModelList.indexOf(gb->model);
|
int model = m_ui.gbModel->findData(gb->model);
|
||||||
if (model >= 0) {
|
if (model >= 0) {
|
||||||
m_ui.gbModel->setCurrentIndex(model);
|
m_ui.gbModel->setCurrentIndex(model);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -55,9 +55,6 @@ private:
|
||||||
#ifdef M_CORE_GB
|
#ifdef M_CORE_GB
|
||||||
uint32_t m_gbColors[12]{};
|
uint32_t m_gbColors[12]{};
|
||||||
ColorPicker m_colorPickers[12];
|
ColorPicker m_colorPickers[12];
|
||||||
|
|
||||||
static QList<enum GBModel> s_gbModelList;
|
|
||||||
static QList<enum GBMemoryBankControllerType> s_mbcList;
|
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -248,26 +248,6 @@
|
||||||
<string>Autodetect</string>
|
<string>Autodetect</string>
|
||||||
</property>
|
</property>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Game Boy (DMG)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Super Game Boy (SGB)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Game Boy Color (CGB)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Game Boy Advance (AGB)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="0">
|
<item row="1" column="0">
|
||||||
|
@ -284,96 +264,6 @@
|
||||||
<string>Autodetect</string>
|
<string>Autodetect</string>
|
||||||
</property>
|
</property>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>None</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>MBC1</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>MBC2</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>MBC3</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>MBC3 + RTC</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>MBC5</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>MBC5 + Rumble</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>MBC6</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>MBC7</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>MMM01</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Pocket Cam</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>TAMA5</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>HuC-1</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>HuC-3</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Wisdom Tree (Unlicensed)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>BBD (Unlicensed)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Hitek (Unlicensed)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Pokémon Jade/Diamond (Unlicensed)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="2" column="0">
|
<item row="2" column="0">
|
||||||
|
|
|
@ -15,16 +15,16 @@
|
||||||
#include "ShaderSelector.h"
|
#include "ShaderSelector.h"
|
||||||
#include "ShortcutView.h"
|
#include "ShortcutView.h"
|
||||||
|
|
||||||
|
#ifdef M_CORE_GB
|
||||||
|
#include "GameBoy.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <mgba/core/serialize.h>
|
#include <mgba/core/serialize.h>
|
||||||
#include <mgba/core/version.h>
|
#include <mgba/core/version.h>
|
||||||
#include <mgba/internal/gba/gba.h>
|
#include <mgba/internal/gba/gba.h>
|
||||||
|
|
||||||
using namespace QGBA;
|
using namespace QGBA;
|
||||||
|
|
||||||
#ifdef M_CORE_GB
|
|
||||||
QList<enum GBModel> SettingsView::s_gbModelList;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
SettingsView::SettingsView(ConfigController* controller, InputController* inputController, ShortcutController* shortcutController, LogController* logController, QWidget* parent)
|
SettingsView::SettingsView(ConfigController* controller, InputController* inputController, ShortcutController* shortcutController, LogController* logController, QWidget* parent)
|
||||||
: QDialog(parent, Qt::WindowTitleHint | Qt::WindowSystemMenuHint | Qt::WindowCloseButtonHint)
|
: QDialog(parent, Qt::WindowTitleHint | Qt::WindowSystemMenuHint | Qt::WindowCloseButtonHint)
|
||||||
, m_controller(controller)
|
, m_controller(controller)
|
||||||
|
@ -33,13 +33,14 @@ SettingsView::SettingsView(ConfigController* controller, InputController* inputC
|
||||||
m_ui.setupUi(this);
|
m_ui.setupUi(this);
|
||||||
|
|
||||||
#ifdef M_CORE_GB
|
#ifdef M_CORE_GB
|
||||||
if (s_gbModelList.isEmpty()) {
|
m_ui.gbModel->setItemData(0, GB_MODEL_AUTODETECT);
|
||||||
// NB: Keep in sync with SettingsView.ui
|
m_ui.sgbModel->setItemData(0, GB_MODEL_AUTODETECT);
|
||||||
s_gbModelList.append(GB_MODEL_AUTODETECT);
|
m_ui.cgbModel->setItemData(0, GB_MODEL_AUTODETECT);
|
||||||
s_gbModelList.append(GB_MODEL_DMG);
|
|
||||||
s_gbModelList.append(GB_MODEL_SGB);
|
for (auto model : GameBoy::modelList()) {
|
||||||
s_gbModelList.append(GB_MODEL_CGB);
|
m_ui.gbModel->addItem(GameBoy::modelName(model), model);
|
||||||
s_gbModelList.append(GB_MODEL_AGB);
|
m_ui.sgbModel->addItem(GameBoy::modelName(model), model);
|
||||||
|
m_ui.cgbModel->addItem(GameBoy::modelName(model), model);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -511,14 +512,20 @@ void SettingsView::updateConfig() {
|
||||||
m_logModel.logger()->logToStdout(m_ui.logToStdout->isChecked());
|
m_logModel.logger()->logToStdout(m_ui.logToStdout->isChecked());
|
||||||
|
|
||||||
#ifdef M_CORE_GB
|
#ifdef M_CORE_GB
|
||||||
GBModel modelGB = s_gbModelList[m_ui.gbModel->currentIndex()];
|
QVariant modelGB = m_ui.gbModel->currentData();
|
||||||
m_controller->setOption("gb.model", GBModelToName(modelGB));
|
if (modelGB.isValid()) {
|
||||||
|
m_controller->setOption("gb.model", GBModelToName(static_cast<GBModel>(modelGB.toInt())));
|
||||||
|
}
|
||||||
|
|
||||||
GBModel modelSGB = s_gbModelList[m_ui.sgbModel->currentIndex()];
|
QVariant modelSGB = m_ui.sgbModel->currentData();
|
||||||
m_controller->setOption("sgb.model", GBModelToName(modelSGB));
|
if (modelSGB.isValid()) {
|
||||||
|
m_controller->setOption("sgb.model", GBModelToName(static_cast<GBModel>(modelSGB.toInt())));
|
||||||
|
}
|
||||||
|
|
||||||
GBModel modelCGB = s_gbModelList[m_ui.cgbModel->currentIndex()];
|
QVariant modelCGB = m_ui.cgbModel->currentData();
|
||||||
m_controller->setOption("cgb.model", GBModelToName(modelCGB));
|
if (modelCGB.isValid()) {
|
||||||
|
m_controller->setOption("cgb.model", GBModelToName(static_cast<GBModel>(modelCGB.toInt())));
|
||||||
|
}
|
||||||
|
|
||||||
for (int colorId = 0; colorId < 12; ++colorId) {
|
for (int colorId = 0; colorId < 12; ++colorId) {
|
||||||
if (!(m_gbColors[colorId] & 0xFF000000)) {
|
if (!(m_gbColors[colorId] & 0xFF000000)) {
|
||||||
|
@ -641,21 +648,21 @@ void SettingsView::reloadConfig() {
|
||||||
QString modelGB = m_controller->getOption("gb.model");
|
QString modelGB = m_controller->getOption("gb.model");
|
||||||
if (!modelGB.isNull()) {
|
if (!modelGB.isNull()) {
|
||||||
GBModel model = GBNameToModel(modelGB.toUtf8().constData());
|
GBModel model = GBNameToModel(modelGB.toUtf8().constData());
|
||||||
int index = s_gbModelList.indexOf(model);
|
int index = m_ui.gbModel->findData(model);
|
||||||
m_ui.gbModel->setCurrentIndex(index >= 0 ? index : 0);
|
m_ui.gbModel->setCurrentIndex(index >= 0 ? index : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
QString modelSGB = m_controller->getOption("sgb.model");
|
QString modelSGB = m_controller->getOption("sgb.model");
|
||||||
if (!modelSGB.isNull()) {
|
if (!modelSGB.isNull()) {
|
||||||
GBModel model = GBNameToModel(modelSGB.toUtf8().constData());
|
GBModel model = GBNameToModel(modelSGB.toUtf8().constData());
|
||||||
int index = s_gbModelList.indexOf(model);
|
int index = m_ui.sgbModel->findData(model);
|
||||||
m_ui.sgbModel->setCurrentIndex(index >= 0 ? index : 0);
|
m_ui.sgbModel->setCurrentIndex(index >= 0 ? index : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
QString modelCGB = m_controller->getOption("cgb.model");
|
QString modelCGB = m_controller->getOption("cgb.model");
|
||||||
if (!modelCGB.isNull()) {
|
if (!modelCGB.isNull()) {
|
||||||
GBModel model = GBNameToModel(modelCGB.toUtf8().constData());
|
GBModel model = GBNameToModel(modelCGB.toUtf8().constData());
|
||||||
int index = s_gbModelList.indexOf(model);
|
int index = m_ui.cgbModel->findData(model);
|
||||||
m_ui.cgbModel->setCurrentIndex(index >= 0 ? index : 0);
|
m_ui.cgbModel->setCurrentIndex(index >= 0 ? index : 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -61,7 +61,6 @@ private:
|
||||||
#ifdef M_CORE_GB
|
#ifdef M_CORE_GB
|
||||||
uint32_t m_gbColors[12]{};
|
uint32_t m_gbColors[12]{};
|
||||||
ColorPicker m_colorPickers[12];
|
ColorPicker m_colorPickers[12];
|
||||||
static QList<enum GBModel> s_gbModelList;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void saveSetting(const char* key, const QAbstractButton*);
|
void saveSetting(const char* key, const QAbstractButton*);
|
||||||
|
|
|
@ -1476,26 +1476,6 @@
|
||||||
<string>Autodetect</string>
|
<string>Autodetect</string>
|
||||||
</property>
|
</property>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Game Boy (DMG)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Super Game Boy (SGB)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Game Boy Color (CGB)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Game Boy Advance (AGB)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="0">
|
<item row="1" column="0">
|
||||||
|
@ -1512,26 +1492,6 @@
|
||||||
<string>Autodetect</string>
|
<string>Autodetect</string>
|
||||||
</property>
|
</property>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Game Boy (DMG)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Super Game Boy (SGB)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Game Boy Color (CGB)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Game Boy Advance (AGB)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="2" column="0">
|
<item row="2" column="0">
|
||||||
|
@ -1548,26 +1508,6 @@
|
||||||
<string>Autodetect</string>
|
<string>Autodetect</string>
|
||||||
</property>
|
</property>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Game Boy (DMG)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Super Game Boy (SGB)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Game Boy Color (CGB)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Game Boy Advance (AGB)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="3" column="0" colspan="2">
|
<item row="3" column="0" colspan="2">
|
||||||
|
|
Loading…
Reference in New Issue