Prefer QPA implementation in qsystemtrayicon_x11 if available
In order to have the possibility to provide a custom QSystemTrayIcon implementation in the platform theme instead of the X11 xembed based one, the qpa implementation needs to be called. This was not possible as qpa and x11 implementation were compile time mutual exclusive. This change moves the qpa implementation in the shared part and the methods in qsystemtrayicon_qpa just delegate to them. In addition the _x11 part tries to create a QPlatformSystemTrayIcon through the platform theme and if that succeeds the implementation prefers the qpa variant and delegates to the same methods. Change-Id: I6b33acac63524a77ebdce39af6eb74666f8c7561 Reviewed-by: Kevin Krammer <kevin.krammer@kdab.com> Reviewed-by: Friedemann Kleint <Friedemann.Kleint@digia.com> Reviewed-by: Paul Olav Tvete <paul.tvete@digia.com>
This commit is contained in:
parent
de1d5d2e39
commit
f1ee10f81a
@ -672,6 +672,74 @@ void QBalloonTip::timerEvent(QTimerEvent *e)
|
|||||||
QWidget::timerEvent(e);
|
QWidget::timerEvent(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
void QSystemTrayIconPrivate::install_sys_qpa()
|
||||||
|
{
|
||||||
|
qpa_sys->init();
|
||||||
|
QObject::connect(qpa_sys, SIGNAL(activated(QPlatformSystemTrayIcon::ActivationReason)),
|
||||||
|
q_func(), SLOT(_q_emitActivated(QPlatformSystemTrayIcon::ActivationReason)));
|
||||||
|
QObject::connect(qpa_sys, &QPlatformSystemTrayIcon::messageClicked,
|
||||||
|
q_func(), &QSystemTrayIcon::messageClicked);
|
||||||
|
updateMenu_sys();
|
||||||
|
updateIcon_sys();
|
||||||
|
updateToolTip_sys();
|
||||||
|
}
|
||||||
|
|
||||||
|
void QSystemTrayIconPrivate::remove_sys_qpa()
|
||||||
|
{
|
||||||
|
qpa_sys->cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
|
QRect QSystemTrayIconPrivate::geometry_sys_qpa() const
|
||||||
|
{
|
||||||
|
return qpa_sys->geometry();
|
||||||
|
}
|
||||||
|
|
||||||
|
void QSystemTrayIconPrivate::updateIcon_sys_qpa()
|
||||||
|
{
|
||||||
|
qpa_sys->updateIcon(icon);
|
||||||
|
}
|
||||||
|
|
||||||
|
void QSystemTrayIconPrivate::updateMenu_sys_qpa()
|
||||||
|
{
|
||||||
|
if (menu) {
|
||||||
|
if (!menu->platformMenu()) {
|
||||||
|
QPlatformMenu *platformMenu = qpa_sys->createMenu();
|
||||||
|
if (platformMenu)
|
||||||
|
menu->setPlatformMenu(platformMenu);
|
||||||
|
}
|
||||||
|
qpa_sys->updateMenu(menu->platformMenu());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void QSystemTrayIconPrivate::updateToolTip_sys_qpa()
|
||||||
|
{
|
||||||
|
qpa_sys->updateToolTip(toolTip);
|
||||||
|
}
|
||||||
|
|
||||||
|
void QSystemTrayIconPrivate::showMessage_sys_qpa(const QString &message,
|
||||||
|
const QString &title,
|
||||||
|
QSystemTrayIcon::MessageIcon icon,
|
||||||
|
int msecs)
|
||||||
|
{
|
||||||
|
QIcon notificationIcon;
|
||||||
|
switch (icon) {
|
||||||
|
case QSystemTrayIcon::Information:
|
||||||
|
notificationIcon = QApplication::style()->standardIcon(QStyle::SP_MessageBoxInformation);
|
||||||
|
break;
|
||||||
|
case QSystemTrayIcon::Warning:
|
||||||
|
notificationIcon = QApplication::style()->standardIcon(QStyle::SP_MessageBoxWarning);
|
||||||
|
break;
|
||||||
|
case QSystemTrayIcon::Critical:
|
||||||
|
notificationIcon = QApplication::style()->standardIcon(QStyle::SP_MessageBoxCritical);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
qpa_sys->showMessage(message, title, notificationIcon,
|
||||||
|
static_cast<QPlatformSystemTrayIcon::MessageIcon>(icon), msecs);
|
||||||
|
}
|
||||||
|
|
||||||
QT_END_NAMESPACE
|
QT_END_NAMESPACE
|
||||||
|
|
||||||
#endif // QT_NO_SYSTEMTRAYICON
|
#endif // QT_NO_SYSTEMTRAYICON
|
||||||
|
@ -98,6 +98,15 @@ public:
|
|||||||
QSystemTrayIconSys *sys;
|
QSystemTrayIconSys *sys;
|
||||||
QPlatformSystemTrayIcon *qpa_sys;
|
QPlatformSystemTrayIcon *qpa_sys;
|
||||||
bool visible;
|
bool visible;
|
||||||
|
|
||||||
|
private:
|
||||||
|
void install_sys_qpa();
|
||||||
|
void remove_sys_qpa();
|
||||||
|
void updateIcon_sys_qpa();
|
||||||
|
void updateToolTip_sys_qpa();
|
||||||
|
void updateMenu_sys_qpa();
|
||||||
|
QRect geometry_sys_qpa() const;
|
||||||
|
void showMessage_sys_qpa(const QString &msg, const QString &title, QSystemTrayIcon::MessageIcon icon, int secs);
|
||||||
};
|
};
|
||||||
|
|
||||||
class QBalloonTip : public QWidget
|
class QBalloonTip : public QWidget
|
||||||
|
@ -65,28 +65,20 @@ QSystemTrayIconPrivate::~QSystemTrayIconPrivate()
|
|||||||
|
|
||||||
void QSystemTrayIconPrivate::install_sys()
|
void QSystemTrayIconPrivate::install_sys()
|
||||||
{
|
{
|
||||||
if (qpa_sys) {
|
if (qpa_sys)
|
||||||
qpa_sys->init();
|
install_sys_qpa();
|
||||||
QObject::connect(qpa_sys, SIGNAL(activated(QPlatformSystemTrayIcon::ActivationReason)),
|
|
||||||
q_func(), SLOT(_q_emitActivated(QPlatformSystemTrayIcon::ActivationReason)));
|
|
||||||
QObject::connect(qpa_sys, SIGNAL(messageClicked()),
|
|
||||||
q_func(), SIGNAL(messageClicked()));
|
|
||||||
updateMenu_sys();
|
|
||||||
updateIcon_sys();
|
|
||||||
updateToolTip_sys();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void QSystemTrayIconPrivate::remove_sys()
|
void QSystemTrayIconPrivate::remove_sys()
|
||||||
{
|
{
|
||||||
if (qpa_sys)
|
if (qpa_sys)
|
||||||
qpa_sys->cleanup();
|
remove_sys_qpa();
|
||||||
}
|
}
|
||||||
|
|
||||||
QRect QSystemTrayIconPrivate::geometry_sys() const
|
QRect QSystemTrayIconPrivate::geometry_sys() const
|
||||||
{
|
{
|
||||||
if (qpa_sys)
|
if (qpa_sys)
|
||||||
return qpa_sys->geometry();
|
return geometry_sys_qpa();
|
||||||
else
|
else
|
||||||
return QRect();
|
return QRect();
|
||||||
}
|
}
|
||||||
@ -94,25 +86,19 @@ QRect QSystemTrayIconPrivate::geometry_sys() const
|
|||||||
void QSystemTrayIconPrivate::updateIcon_sys()
|
void QSystemTrayIconPrivate::updateIcon_sys()
|
||||||
{
|
{
|
||||||
if (qpa_sys)
|
if (qpa_sys)
|
||||||
qpa_sys->updateIcon(icon);
|
updateIcon_sys_qpa();
|
||||||
}
|
}
|
||||||
|
|
||||||
void QSystemTrayIconPrivate::updateMenu_sys()
|
void QSystemTrayIconPrivate::updateMenu_sys()
|
||||||
{
|
{
|
||||||
if (qpa_sys && menu) {
|
if (qpa_sys)
|
||||||
if (!menu->platformMenu()) {
|
updateMenu_sys_qpa();
|
||||||
QPlatformMenu *platformMenu = qpa_sys->createMenu();
|
|
||||||
if (platformMenu)
|
|
||||||
menu->setPlatformMenu(platformMenu);
|
|
||||||
}
|
|
||||||
qpa_sys->updateMenu(menu->platformMenu());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void QSystemTrayIconPrivate::updateToolTip_sys()
|
void QSystemTrayIconPrivate::updateToolTip_sys()
|
||||||
{
|
{
|
||||||
if (qpa_sys)
|
if (qpa_sys)
|
||||||
qpa_sys->updateToolTip(toolTip);
|
updateToolTip_sys_qpa();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool QSystemTrayIconPrivate::isSystemTrayAvailable_sys()
|
bool QSystemTrayIconPrivate::isSystemTrayAvailable_sys()
|
||||||
@ -138,25 +124,8 @@ void QSystemTrayIconPrivate::showMessage_sys(const QString &message,
|
|||||||
QSystemTrayIcon::MessageIcon icon,
|
QSystemTrayIcon::MessageIcon icon,
|
||||||
int msecs)
|
int msecs)
|
||||||
{
|
{
|
||||||
if (!qpa_sys)
|
if (qpa_sys)
|
||||||
return;
|
showMessage_sys_qpa(message, title, icon, msecs);
|
||||||
|
|
||||||
QIcon notificationIcon;
|
|
||||||
switch (icon) {
|
|
||||||
case QSystemTrayIcon::Information:
|
|
||||||
notificationIcon = QApplication::style()->standardIcon(QStyle::SP_MessageBoxInformation);
|
|
||||||
break;
|
|
||||||
case QSystemTrayIcon::Warning:
|
|
||||||
notificationIcon = QApplication::style()->standardIcon(QStyle::SP_MessageBoxWarning);
|
|
||||||
break;
|
|
||||||
case QSystemTrayIcon::Critical:
|
|
||||||
notificationIcon = QApplication::style()->standardIcon(QStyle::SP_MessageBoxCritical);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
qpa_sys->showMessage(message, title, notificationIcon,
|
|
||||||
static_cast<QPlatformSystemTrayIcon::MessageIcon>(icon), msecs);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QT_END_NAMESPACE
|
QT_END_NAMESPACE
|
||||||
|
@ -55,6 +55,9 @@
|
|||||||
#include <qscreen.h>
|
#include <qscreen.h>
|
||||||
#include <qbackingstore.h>
|
#include <qbackingstore.h>
|
||||||
#include <qpa/qplatformnativeinterface.h>
|
#include <qpa/qplatformnativeinterface.h>
|
||||||
|
#include <qpa/qplatformsystemtrayicon.h>
|
||||||
|
#include <qpa/qplatformtheme.h>
|
||||||
|
#include <private/qguiapplication_p.h>
|
||||||
#include <qdebug.h>
|
#include <qdebug.h>
|
||||||
|
|
||||||
#ifndef QT_NO_SYSTEMTRAYICON
|
#ifndef QT_NO_SYSTEMTRAYICON
|
||||||
@ -209,16 +212,22 @@ void QSystemTrayIconSys::paintEvent(QPaintEvent *)
|
|||||||
|
|
||||||
QSystemTrayIconPrivate::QSystemTrayIconPrivate()
|
QSystemTrayIconPrivate::QSystemTrayIconPrivate()
|
||||||
: sys(0),
|
: sys(0),
|
||||||
|
qpa_sys(QGuiApplicationPrivate::platformTheme()->createPlatformSystemTrayIcon()),
|
||||||
visible(false)
|
visible(false)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
QSystemTrayIconPrivate::~QSystemTrayIconPrivate()
|
QSystemTrayIconPrivate::~QSystemTrayIconPrivate()
|
||||||
{
|
{
|
||||||
|
delete qpa_sys;
|
||||||
}
|
}
|
||||||
|
|
||||||
void QSystemTrayIconPrivate::install_sys()
|
void QSystemTrayIconPrivate::install_sys()
|
||||||
{
|
{
|
||||||
|
if (qpa_sys) {
|
||||||
|
install_sys_qpa();
|
||||||
|
return;
|
||||||
|
}
|
||||||
Q_Q(QSystemTrayIcon);
|
Q_Q(QSystemTrayIcon);
|
||||||
if (!sys && locateSystemTray()) {
|
if (!sys && locateSystemTray()) {
|
||||||
sys = new QSystemTrayIconSys(q);
|
sys = new QSystemTrayIconSys(q);
|
||||||
@ -229,6 +238,8 @@ void QSystemTrayIconPrivate::install_sys()
|
|||||||
|
|
||||||
QRect QSystemTrayIconPrivate::geometry_sys() const
|
QRect QSystemTrayIconPrivate::geometry_sys() const
|
||||||
{
|
{
|
||||||
|
if (qpa_sys)
|
||||||
|
return geometry_sys_qpa();
|
||||||
if (!sys)
|
if (!sys)
|
||||||
return QRect();
|
return QRect();
|
||||||
return sys->globalGeometry();
|
return sys->globalGeometry();
|
||||||
@ -236,6 +247,10 @@ QRect QSystemTrayIconPrivate::geometry_sys() const
|
|||||||
|
|
||||||
void QSystemTrayIconPrivate::remove_sys()
|
void QSystemTrayIconPrivate::remove_sys()
|
||||||
{
|
{
|
||||||
|
if (qpa_sys) {
|
||||||
|
remove_sys_qpa();
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (!sys)
|
if (!sys)
|
||||||
return;
|
return;
|
||||||
QBalloonTip::hideBalloon();
|
QBalloonTip::hideBalloon();
|
||||||
@ -246,17 +261,26 @@ void QSystemTrayIconPrivate::remove_sys()
|
|||||||
|
|
||||||
void QSystemTrayIconPrivate::updateIcon_sys()
|
void QSystemTrayIconPrivate::updateIcon_sys()
|
||||||
{
|
{
|
||||||
|
if (qpa_sys) {
|
||||||
|
updateIcon_sys_qpa();
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (sys)
|
if (sys)
|
||||||
sys->updateIcon();
|
sys->updateIcon();
|
||||||
}
|
}
|
||||||
|
|
||||||
void QSystemTrayIconPrivate::updateMenu_sys()
|
void QSystemTrayIconPrivate::updateMenu_sys()
|
||||||
{
|
{
|
||||||
|
if (qpa_sys)
|
||||||
|
updateMenu_sys_qpa();
|
||||||
}
|
}
|
||||||
|
|
||||||
void QSystemTrayIconPrivate::updateToolTip_sys()
|
void QSystemTrayIconPrivate::updateToolTip_sys()
|
||||||
{
|
{
|
||||||
|
if (qpa_sys) {
|
||||||
|
updateToolTip_sys_qpa();
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (!sys)
|
if (!sys)
|
||||||
return;
|
return;
|
||||||
#ifndef QT_NO_TOOLTIP
|
#ifndef QT_NO_TOOLTIP
|
||||||
@ -266,6 +290,11 @@ void QSystemTrayIconPrivate::updateToolTip_sys()
|
|||||||
|
|
||||||
bool QSystemTrayIconPrivate::isSystemTrayAvailable_sys()
|
bool QSystemTrayIconPrivate::isSystemTrayAvailable_sys()
|
||||||
{
|
{
|
||||||
|
QScopedPointer<QPlatformSystemTrayIcon> sys(QGuiApplicationPrivate::platformTheme()->createPlatformSystemTrayIcon());
|
||||||
|
if (sys)
|
||||||
|
return sys->isSystemTrayAvailable();
|
||||||
|
|
||||||
|
// no QPlatformSystemTrayIcon so fall back to default xcb platform behavior
|
||||||
const QString platform = QGuiApplication::platformName();
|
const QString platform = QGuiApplication::platformName();
|
||||||
if (platform.compare(QStringLiteral("xcb"), Qt::CaseInsensitive) == 0)
|
if (platform.compare(QStringLiteral("xcb"), Qt::CaseInsensitive) == 0)
|
||||||
return locateSystemTray();
|
return locateSystemTray();
|
||||||
@ -274,12 +303,21 @@ bool QSystemTrayIconPrivate::isSystemTrayAvailable_sys()
|
|||||||
|
|
||||||
bool QSystemTrayIconPrivate::supportsMessages_sys()
|
bool QSystemTrayIconPrivate::supportsMessages_sys()
|
||||||
{
|
{
|
||||||
|
QScopedPointer<QPlatformSystemTrayIcon> sys(QGuiApplicationPrivate::platformTheme()->createPlatformSystemTrayIcon());
|
||||||
|
if (sys)
|
||||||
|
return sys->supportsMessages();
|
||||||
|
|
||||||
|
// no QPlatformSystemTrayIcon so fall back to default xcb platform behavior
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void QSystemTrayIconPrivate::showMessage_sys(const QString &message, const QString &title,
|
void QSystemTrayIconPrivate::showMessage_sys(const QString &message, const QString &title,
|
||||||
QSystemTrayIcon::MessageIcon icon, int msecs)
|
QSystemTrayIcon::MessageIcon icon, int msecs)
|
||||||
{
|
{
|
||||||
|
if (qpa_sys) {
|
||||||
|
showMessage_sys_qpa(message, title, icon, msecs);
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (!sys)
|
if (!sys)
|
||||||
return;
|
return;
|
||||||
const QPoint g = sys->globalGeometry().topLeft();
|
const QPoint g = sys->globalGeometry().topLeft();
|
||||||
|
Loading…
Reference in New Issue
Block a user