Issue #200: Icons under dark theme on Arch/KDE is broken

This commit is contained in:
Jakub Melka 2024-10-19 19:53:36 +02:00
parent 4359109157
commit b0e5c3001b
4 changed files with 33 additions and 10 deletions

View File

@ -18,6 +18,7 @@
#include "pdfeditormainwindow.h" #include "pdfeditormainwindow.h"
#include "pdfconstants.h" #include "pdfconstants.h"
#include "pdfsecurityhandler.h" #include "pdfsecurityhandler.h"
#include "pdfwidgetutils.h"
#include <QApplication> #include <QApplication>
#include <QCommandLineParser> #include <QCommandLineParser>
@ -39,10 +40,14 @@ int main(int argc, char *argv[])
QApplication::setApplicationDisplayName(QApplication::translate("Application", "PDF4QT Editor")); QApplication::setApplicationDisplayName(QApplication::translate("Application", "PDF4QT Editor"));
QCommandLineOption noDrm("no-drm", "Disable DRM settings of documents."); QCommandLineOption noDrm("no-drm", "Disable DRM settings of documents.");
QCommandLineOption lightGui("theme-light", "Use a light theme for the GUI.");
QCommandLineOption darkGui("theme-dark", "Use a dark theme for the GUI.");
QCommandLineParser parser; QCommandLineParser parser;
parser.setApplicationDescription(QCoreApplication::applicationName()); parser.setApplicationDescription(QCoreApplication::applicationName());
parser.addOption(noDrm); parser.addOption(noDrm);
parser.addOption(lightGui);
parser.addOption(darkGui);
parser.addHelpOption(); parser.addHelpOption();
parser.addVersionOption(); parser.addVersionOption();
parser.addPositionalArgument("file", "The PDF file to open."); parser.addPositionalArgument("file", "The PDF file to open.");
@ -53,6 +58,16 @@ int main(int argc, char *argv[])
pdf::PDFSecurityHandler::setNoDRMMode(); pdf::PDFSecurityHandler::setNoDRMMode();
} }
if (parser.isSet(lightGui))
{
pdf::PDFWidgetUtils::setDarkTheme(false);
}
if (parser.isSet(darkGui))
{
pdf::PDFWidgetUtils::setDarkTheme(true);
}
QIcon appIcon(":/app-icon.svg"); QIcon appIcon(":/app-icon.svg");
QApplication::setWindowIcon(appIcon); QApplication::setWindowIcon(appIcon);

View File

@ -46,8 +46,6 @@ int qt_default_dpi_y() { return 96; }
namespace pdf namespace pdf
{ {
std::optional<bool> s_isDarkThemeOverride;
static constexpr bool isScalingNeeded() static constexpr bool isScalingNeeded()
{ {
return QT_VERSION_MAJOR < 6; return QT_VERSION_MAJOR < 6;
@ -176,18 +174,13 @@ void PDFWidgetUtils::style(QWidget* widget)
} }
} }
void PDFWidgetUtils::overrideDarkTheme(bool isDarkTheme) void PDFWidgetUtils::setDarkTheme(bool isDarkTheme)
{ {
s_isDarkThemeOverride = isDarkTheme; QApplication::styleHints()->setColorScheme(isDarkTheme ? Qt::ColorScheme::Dark : Qt::ColorScheme::Light);
} }
bool PDFWidgetUtils::isDarkTheme() bool PDFWidgetUtils::isDarkTheme()
{ {
if (s_isDarkThemeOverride.has_value())
{
return s_isDarkThemeOverride.value();
}
Qt::ColorScheme colorScheme = QApplication::styleHints()->colorScheme(); Qt::ColorScheme colorScheme = QApplication::styleHints()->colorScheme();
return colorScheme == Qt::ColorScheme::Dark; return colorScheme == Qt::ColorScheme::Dark;
} }

View File

@ -61,7 +61,7 @@ public:
static void style(QWidget* widget); static void style(QWidget* widget);
/// Overrides automatically detected dark theme / light theme settings /// Overrides automatically detected dark theme / light theme settings
static void overrideDarkTheme(bool isDarkTheme); static void setDarkTheme(bool isDarkTheme);
/// Returns true if the dark theme is currently set for the application. /// Returns true if the dark theme is currently set for the application.
static bool isDarkTheme(); static bool isDarkTheme();

View File

@ -18,6 +18,7 @@
#include "pdfviewermainwindow.h" #include "pdfviewermainwindow.h"
#include "pdfconstants.h" #include "pdfconstants.h"
#include "pdfsecurityhandler.h" #include "pdfsecurityhandler.h"
#include "pdfwidgetutils.h"
#include <QApplication> #include <QApplication>
#include <QCommandLineParser> #include <QCommandLineParser>
@ -33,10 +34,14 @@ int main(int argc, char *argv[])
QApplication::setApplicationDisplayName(QApplication::translate("Application", "PDF4QT Viewer")); QApplication::setApplicationDisplayName(QApplication::translate("Application", "PDF4QT Viewer"));
QCommandLineOption noDrm("no-drm", "Disable DRM settings of documents."); QCommandLineOption noDrm("no-drm", "Disable DRM settings of documents.");
QCommandLineOption lightGui("theme-light", "Use a light theme for the GUI.");
QCommandLineOption darkGui("theme-dark", "Use a dark theme for the GUI.");
QCommandLineParser parser; QCommandLineParser parser;
parser.setApplicationDescription(QCoreApplication::applicationName()); parser.setApplicationDescription(QCoreApplication::applicationName());
parser.addOption(noDrm); parser.addOption(noDrm);
parser.addOption(lightGui);
parser.addOption(darkGui);
parser.addHelpOption(); parser.addHelpOption();
parser.addVersionOption(); parser.addVersionOption();
parser.addPositionalArgument("file", "The PDF file to open."); parser.addPositionalArgument("file", "The PDF file to open.");
@ -47,6 +52,16 @@ int main(int argc, char *argv[])
pdf::PDFSecurityHandler::setNoDRMMode(); pdf::PDFSecurityHandler::setNoDRMMode();
} }
if (parser.isSet(lightGui))
{
pdf::PDFWidgetUtils::setDarkTheme(false);
}
if (parser.isSet(darkGui))
{
pdf::PDFWidgetUtils::setDarkTheme(true);
}
QIcon appIcon(":/app-icon.svg"); QIcon appIcon(":/app-icon.svg");
QApplication::setWindowIcon(appIcon); QApplication::setWindowIcon(appIcon);