mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-24 23:11:14 +01:00
Merge pull request #13075 from robxnano/qt-color-scheme
Remove unneeded Win32 code for color scheme
This commit is contained in:
commit
f4e0a42cfc
@ -247,7 +247,6 @@ int main(int argc, char* argv[])
|
|||||||
DolphinAnalytics::Instance().ReportDolphinStart("qt");
|
DolphinAnalytics::Instance().ReportDolphinStart("qt");
|
||||||
|
|
||||||
Settings::Instance().InitDefaultPalette();
|
Settings::Instance().InitDefaultPalette();
|
||||||
Settings::Instance().UpdateSystemDark();
|
|
||||||
Settings::Instance().ApplyStyle();
|
Settings::Instance().ApplyStyle();
|
||||||
|
|
||||||
MainWindow win{std::move(boot), static_cast<const char*>(options.get("movie"))};
|
MainWindow win{std::move(boot), static_cast<const char*>(options.get("movie"))};
|
||||||
|
@ -250,7 +250,11 @@ MainWindow::MainWindow(std::unique_ptr<BootParameters> boot_parameters,
|
|||||||
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 5, 0)
|
#if QT_VERSION >= QT_VERSION_CHECK(6, 5, 0)
|
||||||
connect(QGuiApplication::styleHints(), &QStyleHints::colorSchemeChanged, this,
|
connect(QGuiApplication::styleHints(), &QStyleHints::colorSchemeChanged, this,
|
||||||
[](Qt::ColorScheme colorScheme) { Settings::Instance().ApplyStyle(); });
|
[this](Qt::ColorScheme colorScheme) {
|
||||||
|
Settings::Instance().ApplyStyle();
|
||||||
|
if (m_skylander_window)
|
||||||
|
m_skylander_window->RefreshList();
|
||||||
|
});
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
connect(m_cheats_manager, &CheatsManager::OpenGeneralSettings, this,
|
connect(m_cheats_manager, &CheatsManager::OpenGeneralSettings, this,
|
||||||
@ -1765,36 +1769,6 @@ QSize MainWindow::sizeHint() const
|
|||||||
return QSize(800, 600);
|
return QSize(800, 600);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
bool MainWindow::nativeEvent(const QByteArray& eventType, void* message, qintptr* result)
|
|
||||||
{
|
|
||||||
auto* msg = reinterpret_cast<MSG*>(message);
|
|
||||||
if (msg && msg->message == WM_SETTINGCHANGE && msg->lParam != NULL &&
|
|
||||||
std::wstring_view(L"ImmersiveColorSet")
|
|
||||||
.compare(reinterpret_cast<const wchar_t*>(msg->lParam)) == 0)
|
|
||||||
{
|
|
||||||
// Windows light/dark theme has changed. Update our flag and refresh the theme.
|
|
||||||
auto& settings = Settings::Instance();
|
|
||||||
const bool was_dark_before = settings.IsSystemDark();
|
|
||||||
settings.UpdateSystemDark();
|
|
||||||
if (settings.IsSystemDark() != was_dark_before)
|
|
||||||
{
|
|
||||||
settings.ApplyStyle();
|
|
||||||
|
|
||||||
// force the colors in the Skylander window to update
|
|
||||||
if (m_skylander_window)
|
|
||||||
m_skylander_window->RefreshList();
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: When switching from light to dark, the window decorations remain light. Qt seems very
|
|
||||||
// convinced that it needs to change these in response to this message, so even if we set them
|
|
||||||
// to dark here, Qt sets them back to light afterwards.
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void MainWindow::OnBootGameCubeIPL(DiscIO::Region region)
|
void MainWindow::OnBootGameCubeIPL(DiscIO::Region region)
|
||||||
{
|
{
|
||||||
StartGame(std::make_unique<BootParameters>(BootParameters::IPL{region}));
|
StartGame(std::make_unique<BootParameters>(BootParameters::IPL{region}));
|
||||||
|
@ -213,11 +213,6 @@ private:
|
|||||||
void dropEvent(QDropEvent* event) override;
|
void dropEvent(QDropEvent* event) override;
|
||||||
QSize sizeHint() const override;
|
QSize sizeHint() const override;
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
// This gets called for each event from the Windows message queue.
|
|
||||||
bool nativeEvent(const QByteArray& eventType, void* message, qintptr* result) override;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef HAVE_XRANDR
|
#ifdef HAVE_XRANDR
|
||||||
std::unique_ptr<X11Utils::XRRConfiguration> m_xrr_config;
|
std::unique_ptr<X11Utils::XRRConfiguration> m_xrr_config;
|
||||||
#endif
|
#endif
|
||||||
|
@ -16,17 +16,9 @@
|
|||||||
#include <QRadioButton>
|
#include <QRadioButton>
|
||||||
#include <QSize>
|
#include <QSize>
|
||||||
#include <QStyle>
|
#include <QStyle>
|
||||||
|
#include <QStyleHints>
|
||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
#include <fmt/format.h>
|
|
||||||
|
|
||||||
#include <winrt/Windows.UI.ViewManagement.h>
|
|
||||||
|
|
||||||
#include <QTabBar>
|
|
||||||
#include <QToolButton>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "AudioCommon/AudioCommon.h"
|
#include "AudioCommon/AudioCommon.h"
|
||||||
|
|
||||||
#include "Common/Config/Config.h"
|
#include "Common/Config/Config.h"
|
||||||
@ -52,7 +44,6 @@
|
|||||||
#include "VideoCommon/NetPlayChatUI.h"
|
#include "VideoCommon/NetPlayChatUI.h"
|
||||||
#include "VideoCommon/NetPlayGolfUI.h"
|
#include "VideoCommon/NetPlayGolfUI.h"
|
||||||
|
|
||||||
static bool s_system_dark = false;
|
|
||||||
static std::unique_ptr<QPalette> s_default_palette;
|
static std::unique_ptr<QPalette> s_default_palette;
|
||||||
|
|
||||||
Settings::Settings()
|
Settings::Settings()
|
||||||
@ -147,30 +138,13 @@ void Settings::InitDefaultPalette()
|
|||||||
s_default_palette = std::make_unique<QPalette>(qApp->palette());
|
s_default_palette = std::make_unique<QPalette>(qApp->palette());
|
||||||
}
|
}
|
||||||
|
|
||||||
void Settings::UpdateSystemDark()
|
|
||||||
{
|
|
||||||
#ifdef _WIN32
|
|
||||||
// Check if the system is set to dark mode so we can set the default theme and window
|
|
||||||
// decorations accordingly.
|
|
||||||
{
|
|
||||||
using namespace winrt::Windows::UI::ViewManagement;
|
|
||||||
const UISettings settings;
|
|
||||||
const auto& color = settings.GetColorValue(UIColorType::Foreground);
|
|
||||||
|
|
||||||
const bool is_system_dark = 5 * color.G + 2 * color.R + color.B > 8 * 128;
|
|
||||||
Settings::Instance().SetSystemDark(is_system_dark);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void Settings::SetSystemDark(bool dark)
|
|
||||||
{
|
|
||||||
s_system_dark = dark;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool Settings::IsSystemDark()
|
bool Settings::IsSystemDark()
|
||||||
{
|
{
|
||||||
return s_system_dark;
|
#if QT_VERSION >= QT_VERSION_CHECK(6, 5, 0)
|
||||||
|
return (qApp->styleHints()->colorScheme() == Qt::ColorScheme::Dark);
|
||||||
|
#else
|
||||||
|
return false;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Settings::IsThemeDark()
|
bool Settings::IsThemeDark()
|
||||||
|
@ -53,8 +53,6 @@ public:
|
|||||||
// UI
|
// UI
|
||||||
void TriggerThemeChanged();
|
void TriggerThemeChanged();
|
||||||
void InitDefaultPalette();
|
void InitDefaultPalette();
|
||||||
void UpdateSystemDark();
|
|
||||||
void SetSystemDark(bool dark);
|
|
||||||
bool IsSystemDark();
|
bool IsSystemDark();
|
||||||
bool IsThemeDark();
|
bool IsThemeDark();
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user