Change how new fusion styles are selected

This commit is contained in:
AdenKoperczak 2024-10-21 11:23:34 -04:00
parent 5c57ae0edc
commit 57d65cf086
4 changed files with 71 additions and 10 deletions

View file

@ -70,7 +70,13 @@
<file>res/palettes/wct/SW.pal</file>
<file>res/palettes/wct/VIL.pal</file>
<file>res/palettes/wct/ZDR.pal</file>
<file>res/qt6ct_colors/airy.conf</file>
<file>res/qt6ct_colors/darker.conf</file>
<file>res/qt6ct_colors/dusk.conf</file>
<file>res/qt6ct_colors/ia_ora.conf</file>
<file>res/qt6ct_colors/sand.conf</file>
<file>res/qt6ct_colors/simple.conf</file>
<file>res/qt6ct_colors/waves.conf</file>
<file>res/textures/lines/default-1x7.png</file>
<file>res/textures/lines/test-pattern.png</file>
<file>res/textures/images/cursor-17.png</file>

View file

@ -166,10 +166,24 @@ static void ConfigureTheme(const std::vector<std::string>& args)
QGuiApplication::styleHints()->setColorScheme(qtColorScheme);
if (uiStyle == scwx::qt::types::UiStyle::FusionQt6Ct)
std::optional<std::string> paletteFile =
scwx::qt::types::GetQtPaletteFile(uiStyle);
if (paletteFile)
{
QPalette palette = Qt6CT::loadColorScheme(":res/qt6ct_colors/darker.conf",
QApplication::style()->standardPalette());;
QPalette defaultPalette = QApplication::style()->standardPalette();
QPalette palette =
Qt6CT::loadColorScheme(QString::fromStdString(*paletteFile),
defaultPalette);
if (defaultPalette == palette)
{
logger_->warn("Failed to load palette file '{}'", *paletteFile);
}
else
{
logger_->info("Loaded palette file '{}'", *paletteFile);
}
QApplication::setPalette(palette);
}
}

View file

@ -15,7 +15,12 @@ static const std::unordered_map<UiStyle, std::string> qtStyleName_ {
{UiStyle::Fusion, "Fusion"},
{UiStyle::FusionLight, "Fusion"},
{UiStyle::FusionDark, "Fusion"},
{UiStyle::FusionQt6Ct, "Fusion"},
{UiStyle::FusionAiry, "Fusion"},
{UiStyle::FusionDarker, "Fusion"},
{UiStyle::FusionDusk, "Fusion"},
{UiStyle::FusionIaOra, "Fusion"},
{UiStyle::FusionSand, "Fusion"},
{UiStyle::FusionWaves, "Fusion"},
{UiStyle::Unknown, "?"}};
static const std::unordered_map<UiStyle, std::string> uiStyleName_ {
@ -23,7 +28,12 @@ static const std::unordered_map<UiStyle, std::string> uiStyleName_ {
{UiStyle::Fusion, "Fusion"},
{UiStyle::FusionLight, "Fusion Light"},
{UiStyle::FusionDark, "Fusion Dark"},
{UiStyle::FusionQt6Ct, "Fusion with qt6ct Palette"},
{UiStyle::FusionAiry, "Fusion Airy"},
{UiStyle::FusionDarker, "Fusion Darker"},
{UiStyle::FusionDusk, "Fusion Dusk"},
{UiStyle::FusionIaOra, "Fusion IA Ora"},
{UiStyle::FusionSand, "Fusion Sand"},
{UiStyle::FusionWaves, "Fusion Waves"},
{UiStyle::Unknown, "?"}};
static const std::unordered_map<UiStyle, Qt::ColorScheme> qtColorSchemeMap_ {
@ -31,9 +41,22 @@ static const std::unordered_map<UiStyle, Qt::ColorScheme> qtColorSchemeMap_ {
{UiStyle::Fusion, Qt::ColorScheme::Unknown},
{UiStyle::FusionLight, Qt::ColorScheme::Light},
{UiStyle::FusionDark, Qt::ColorScheme::Dark},
{UiStyle::FusionQt6Ct, Qt::ColorScheme::Unknown},
{UiStyle::FusionAiry, Qt::ColorScheme::Unknown},
{UiStyle::FusionDarker, Qt::ColorScheme::Unknown},
{UiStyle::FusionDusk, Qt::ColorScheme::Unknown},
{UiStyle::FusionIaOra, Qt::ColorScheme::Unknown},
{UiStyle::FusionSand, Qt::ColorScheme::Unknown},
{UiStyle::FusionWaves, Qt::ColorScheme::Unknown},
{UiStyle::Unknown, Qt::ColorScheme::Unknown}};
static const std::unordered_map<UiStyle, std::string> paletteFile_ {
{UiStyle::FusionAiry, ":res/qt6ct_colors/airy.conf"},
{UiStyle::FusionDarker, ":res/qt6ct_colors/darker.conf"},
{UiStyle::FusionDusk, ":res/qt6ct_colors/dusk.conf"},
{UiStyle::FusionIaOra, ":res/qt6ct_colors/ia_ora.conf"},
{UiStyle::FusionSand, ":res/qt6ct_colors/sand.conf"},
{UiStyle::FusionWaves, ":res/qt6ct_colors/waves.conf"}};
SCWX_GET_ENUM(UiStyle, GetUiStyle, uiStyleName_)
Qt::ColorScheme GetQtColorScheme(UiStyle uiStyle)
@ -46,6 +69,16 @@ std::string GetQtStyleName(UiStyle uiStyle)
return qtStyleName_.at(uiStyle);
}
std::optional<std::string> GetQtPaletteFile(UiStyle uiStyle)
{
if (paletteFile_.contains(uiStyle))
{
return paletteFile_.at(uiStyle);
}
return std::nullopt;
}
std::string GetUiStyleName(UiStyle uiStyle)
{
return uiStyleName_.at(uiStyle);

View file

@ -2,6 +2,7 @@
#include <scwx/util/iterator.hpp>
#include <optional>
#include <string>
#include <Qt>
@ -26,15 +27,22 @@ enum class UiStyle
Fusion,
FusionLight,
FusionDark,
FusionQt6Ct,
FusionAiry,
FusionDarker,
FusionDusk,
FusionIaOra,
FusionSand,
FusionWaves,
Unknown
};
typedef scwx::util::Iterator<UiStyle, UiStyle::Default, UiStyle::FusionQt6Ct>
typedef scwx::util::Iterator<UiStyle, UiStyle::Default, UiStyle::FusionWaves>
UiStyleIterator;
Qt::ColorScheme GetQtColorScheme(UiStyle uiStyle);
std::string GetQtStyleName(UiStyle uiStyle);
std::optional<std::string> GetQtPaletteFile(UiStyle uiStyle);
UiStyle GetUiStyle(const std::string& name);
std::string GetUiStyleName(UiStyle uiStyle);