aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKen Moore <ken@ixsystems.com>2018-03-05 15:26:59 -0500
committerKen Moore <ken@ixsystems.com>2018-03-05 15:26:59 -0500
commit380c826f4dd98f00f7d0cde45fe48e652cdaa483 (patch)
treec986911b28d3b0a807572f97f9647699ef6fad14
parentChanged fz_rotate to fz_pre_rotate, which fixes rendering issues in some PDFs... (diff)
downloadlumina-380c826f4dd98f00f7d0cde45fe48e652cdaa483.tar.gz
lumina-380c826f4dd98f00f7d0cde45fe48e652cdaa483.tar.bz2
lumina-380c826f4dd98f00f7d0cde45fe48e652cdaa483.zip
Make the cursor theme change a but more dynamic. Can't seem to force a reload of the Qt cursor cache (for now), but this seems to fix it in Fluxbox right away.
-rw-r--r--src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengine-qtplugin.pro3
-rw-r--r--src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengineplatformtheme.cpp88
-rw-r--r--src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengineplatformtheme.h4
3 files changed, 91 insertions, 4 deletions
diff --git a/src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengine-qtplugin.pro b/src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengine-qtplugin.pro
index 3dca4fd1..227a196e 100644
--- a/src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengine-qtplugin.pro
+++ b/src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengine-qtplugin.pro
@@ -21,6 +21,9 @@ SOURCES += \
OTHER_FILES += lthemeengine.json
+LIBS += -lXcursor
+QT += x11extras
+
INCLUDEPATH += ../
HEADERS += \
diff --git a/src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengineplatformtheme.cpp b/src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengineplatformtheme.cpp
index e581b016..302ec2fc 100644
--- a/src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengineplatformtheme.cpp
+++ b/src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengineplatformtheme.cpp
@@ -7,14 +7,18 @@
#include <QTimer>
#include <QIcon>
#include <QRegExp>
+
#ifdef QT_WIDGETS_LIB
#include <QStyle>
#include <QStyleFactory>
#include <QApplication>
#include <QWidget>
#endif
+
#include <QFile>
#include <QFileSystemWatcher>
+#include <QDir>
+#include <QTextStream>
#include <stdlib.h>
@@ -28,7 +32,11 @@
#include <private/qdbustrayicon_p.h>
#endif
-
+#include <QX11Info>
+#include <QCursor>
+//Need access to the private QCursor header so we can refresh the mouse cursor cache
+//#include <private/qcursor_p.h> //Does not work - looks like we need to use X11 stuff instead
+#include <X11/Xcursor/Xcursor.h>
Q_LOGGING_CATEGORY(llthemeengine, "lthemeengine")
@@ -37,10 +45,11 @@ Q_LOGGING_CATEGORY(llthemeengine, "lthemeengine")
lthemeenginePlatformTheme::lthemeenginePlatformTheme(){
if(QGuiApplication::desktopSettingsAware()){
readSettings();
- QMetaObject::invokeMethod(this, "applySettings", Qt::QueuedConnection);
#ifdef QT_WIDGETS_LIB
QMetaObject::invokeMethod(this, "createFSWatcher", Qt::QueuedConnection);
#endif
+ QMetaObject::invokeMethod(this, "applySettings", Qt::QueuedConnection);
+
QGuiApplication::setFont(m_generalFont);
}
//qCDebug(llthemeengine) << "using lthemeengine plugin";
@@ -168,16 +177,26 @@ void lthemeenginePlatformTheme::applySettings(){
}
#endif
if(!m_update){ m_update = true; }
+
+ //Mouse Cursor syncronization
+ QString mthemefile = QDir::homePath()+"/.icons/default/index.theme";
+ if(!watcher->files().contains(mthemefile) && QFile::exists(mthemefile)){
+ watcher->addPath(mthemefile); //X11 mouse cursor theme file
+ //qDebug() << "Add Mouse Cursor File to Watcher";
+ syncMouseCursorTheme(mthemefile);
+ }
}
#ifdef QT_WIDGETS_LIB
void lthemeenginePlatformTheme::createFSWatcher(){
- QFileSystemWatcher *watcher = new QFileSystemWatcher(this);
- watcher->addPath(lthemeengine::configPath());
+ watcher = new QFileSystemWatcher(this);
+ watcher->addPath(lthemeengine::configPath()); //theme engine settings directory
+ watcher->addPath(QDir::homePath()+"/.icons/default/index.theme"); //X11 mouse cursor theme file
QTimer *timer = new QTimer(this);
timer->setSingleShot(true);
timer->setInterval(500);
connect(watcher, SIGNAL(directoryChanged(QString)), timer, SLOT(start()));
+ connect(watcher, SIGNAL(fileChanged(QString)), this, SLOT(fileChanged(QString)) );
connect(timer, SIGNAL(timeout()), SLOT(updateSettings()));
}
@@ -188,6 +207,13 @@ void lthemeenginePlatformTheme::updateSettings(){
}
#endif
+void lthemeenginePlatformTheme::fileChanged(QString path){
+ if(path.endsWith("default/index.theme")){
+ //qDebug() << "Mouse Cursor File Changed";
+ syncMouseCursorTheme(path);
+ }
+}
+
void lthemeenginePlatformTheme::readSettings(){
if(m_customPalette){
delete m_customPalette;
@@ -294,3 +320,57 @@ QPalette lthemeenginePlatformTheme::loadColorScheme(QString filePath){
else{ customPalette = *QPlatformTheme::palette(SystemPalette); } //load fallback palette
return customPalette;
}
+
+void lthemeenginePlatformTheme::syncMouseCursorTheme(QString indexfile){
+ //Read the index file and pull out the theme name
+ QFile file(indexfile);
+ QString newtheme;
+ if(file.open(QIODevice::ReadOnly)){
+ QTextStream stream(&file);
+ QString tmp;
+ while(!stream.atEnd()){
+ tmp = stream.readLine().simplified();
+ if(tmp.startsWith("Inherits=")){ newtheme = tmp.section("=",1,-1).simplified(); break; }
+ }
+ file.close();
+ }
+ if(newtheme.isEmpty()){ return; } //nothing to do
+ QString curtheme = QString(XcursorGetTheme(QX11Info::display()) ); //currently-used theme
+ //qDebug() << "Sync Mouse Cursur Theme:" << curtheme << newtheme;
+ if(curtheme!=newtheme){
+ qDebug() << " - Setting new cursor theme:" << newtheme;
+ XcursorSetTheme(QX11Info::display(), newtheme.toLocal8Bit().data()); //save the new theme name
+ }else{
+ return;
+ }
+ qDebug() << "Qt Stats:";
+ qDebug() << " TopLevelWindows:" << QGuiApplication::topLevelWindows().length();
+ qDebug() << " AllWindows:" << QGuiApplication::allWindows().length();
+ qDebug() << " AllWidgets:" << QApplication::allWidgets().length();
+
+ //XcursorSetThemeCore( QX11Info::display(), XcursorGetThemeCore(QX11Info::display()) ); //reset the theme core
+ //Load the cursors from the new theme
+ int defsize = XcursorGetDefaultSize(QX11Info::display());
+ qDebug() << "Default cursor size:" << defsize;
+ XcursorImages *imgs = XcursorLibraryLoadImages("left_ptr", NULL, defsize);
+ qDebug() << "imgs:" << imgs << imgs->nimage;
+ XcursorCursors *curs = XcursorImagesLoadCursors(QX11Info::display(), imgs);
+ if(curs==0){ return; } //not found
+ qDebug() << "Got Cursors:" << curs->ncursor;
+ //Now re-set the cursors for the current top-level X windows
+ QWindowList wins = QGuiApplication::allWindows(); //QGuiApplication::topLevelWindows();
+ qDebug() << "Got Windows:" << wins.length();
+ for(int i=0; i<curs->ncursor; i++){
+ for(int w=0; w<wins.length(); w++){
+ XDefineCursor(curs->dpy, wins[w]->winId(), curs->cursors[i]);
+ }
+ }
+ XcursorCursorsDestroy(curs); //finished with this temporary structure
+
+ /*QWidgetList wlist = QApplication::allWidgets();
+ qDebug() << "Widget List:" << wlist.length();
+ for(int i=0; i<wlist.length(); i++){
+ QCursor cur(wlist[i]->cursor().shape());
+ wlist[i]->cursor().swap( cur );
+ }*/
+}
diff --git a/src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengineplatformtheme.h b/src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengineplatformtheme.h
index f521d457..359236b7 100644
--- a/src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengineplatformtheme.h
+++ b/src-qt5/core/lumina-theme-engine/src/lthemeengine-qtplugin/lthemeengineplatformtheme.h
@@ -6,6 +6,7 @@
#include <QFont>
#include <QPalette>
#include <QLoggingCategory>
+#include <QFileSystemWatcher>
#if (QT_VERSION < QT_VERSION_CHECK(5, 5, 0))
#ifndef QT_NO_SYSTEMTRAYICON
@@ -58,6 +59,7 @@ private slots:
void createFSWatcher();
void updateSettings();
#endif
+ void fileChanged(QString);
private:
void readSettings();
@@ -77,6 +79,7 @@ private:
bool m_usePalette = true;
int m_toolButtonStyle = Qt::ToolButtonFollowStyle;
int m_wheelScrollLines = 3;
+ QFileSystemWatcher *watcher;
#if (QT_VERSION >= QT_VERSION_CHECK(5, 6, 0)) && !defined(QT_NO_DBUS)
mutable bool m_dbusGlobalMenuAvailable = false;
mutable bool m_checkDBusGlobalMenu = true;
@@ -86,6 +89,7 @@ private:
mutable bool m_checkDBusTray = true;
#endif
+ void syncMouseCursorTheme(QString indexfile);
};
Q_DECLARE_LOGGING_CATEGORY(llthemeengine)
bgstack15