* unify the code that positions the message overlay
* always use contentsRect(), never geometry or boundingRect; this prevents how it sometimes overlaps the borders of applets * always make sure that the zOrder is set, not just in the non-popup case svn path=/trunk/KDE/kdelibs/; revision=1015154
This commit is contained in:
parent
54f76aa0ea
commit
7890d0c816
54
applet.cpp
54
applet.cpp
@ -507,39 +507,58 @@ void AppletPrivate::createMessageOverlay(bool usePopup)
|
|||||||
PopupApplet *popup = qobject_cast<Plasma::PopupApplet*>(q);
|
PopupApplet *popup = qobject_cast<Plasma::PopupApplet*>(q);
|
||||||
|
|
||||||
if (!messageOverlay) {
|
if (!messageOverlay) {
|
||||||
if (usePopup && popup && popup->widget()) {
|
if (usePopup && popup) {
|
||||||
|
if (popup->widget()) {
|
||||||
messageOverlayProxy = new QGraphicsProxyWidget(q);
|
messageOverlayProxy = new QGraphicsProxyWidget(q);
|
||||||
messageOverlayProxy->setWidget(popup->widget());
|
messageOverlayProxy->setWidget(popup->widget());
|
||||||
messageOverlay = new AppletOverlayWidget(messageOverlayProxy);
|
messageOverlay = new AppletOverlayWidget(messageOverlayProxy);
|
||||||
} else if (usePopup && popup && popup->graphicsWidget() &&
|
} else if (popup->graphicsWidget() &&
|
||||||
popup->graphicsWidget() != extender) {
|
popup->graphicsWidget() != extender) {
|
||||||
messageOverlay = new AppletOverlayWidget(popup->graphicsWidget());
|
messageOverlay = new AppletOverlayWidget(popup->graphicsWidget());
|
||||||
} else {
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!messageOverlay) {
|
||||||
messageOverlay = new AppletOverlayWidget(q);
|
messageOverlay = new AppletOverlayWidget(q);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (usePopup && popup && popup->widget()) {
|
positionMessageOverlay();
|
||||||
|
}
|
||||||
|
|
||||||
|
void AppletPrivate::positionMessageOverlay()
|
||||||
|
{
|
||||||
|
if (!messageOverlay) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
PopupApplet *popup = qobject_cast<Plasma::PopupApplet*>(q);
|
||||||
|
const bool usePopup = popup && messageOverlay->parentItem() == q;
|
||||||
|
QGraphicsItem *topItem = q;
|
||||||
|
|
||||||
|
if (usePopup && popup->widget()) {
|
||||||
// popupapplet with widget()
|
// popupapplet with widget()
|
||||||
|
topItem = popup->d->proxy;
|
||||||
messageOverlay->setGeometry(popup->widget()->contentsRect());
|
messageOverlay->setGeometry(popup->widget()->contentsRect());
|
||||||
} else if (usePopup && popup && popup->graphicsWidget() &&
|
} else if (usePopup && popup->graphicsWidget() && popup->graphicsWidget() != extender) {
|
||||||
popup->graphicsWidget() != extender) {
|
|
||||||
// popupapplet with graphicsWidget()
|
// popupapplet with graphicsWidget()
|
||||||
messageOverlay->setGeometry(popup->graphicsWidget()->boundingRect());
|
topItem = popup->graphicsWidget();
|
||||||
|
QGraphicsWidget *w = dynamic_cast<QGraphicsWidget *>(topItem);
|
||||||
|
messageOverlay->setGeometry(w ? w->contentsRect() : topItem->boundingRect());
|
||||||
} else {
|
} else {
|
||||||
// normal applet
|
// normal applet
|
||||||
messageOverlay->setGeometry(q->contentsRect());
|
messageOverlay->setGeometry(q->contentsRect());
|
||||||
|
}
|
||||||
|
|
||||||
// raise the overlay above all the other children!
|
// raise the overlay above all the other children!
|
||||||
int zValue = 100;
|
int zValue = 100;
|
||||||
foreach (QGraphicsItem *child, q->QGraphicsItem::children()) {
|
foreach (QGraphicsItem *child, topItem->children()) {
|
||||||
if (child->zValue() > zValue) {
|
if (child->zValue() > zValue) {
|
||||||
zValue = child->zValue() + 1;
|
zValue = child->zValue() + 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
messageOverlay->setZValue(zValue);
|
messageOverlay->setZValue(zValue);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void AppletPrivate::destroyMessageOverlay()
|
void AppletPrivate::destroyMessageOverlay()
|
||||||
{
|
{
|
||||||
@ -1101,22 +1120,7 @@ void Applet::flushPendingConstraintsEvents()
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (c & Plasma::SizeConstraint) {
|
if (c & Plasma::SizeConstraint) {
|
||||||
if (d->messageOverlay) {
|
d->positionMessageOverlay();
|
||||||
d->messageOverlay->setGeometry(QRectF(QPointF(0, 0), geometry().size()));
|
|
||||||
/*
|
|
||||||
QGraphicsItem *button = 0;
|
|
||||||
QList<QGraphicsItem*> children = d->messageOverlay->QGraphicsItem::children();
|
|
||||||
|
|
||||||
if (!children.isEmpty()) {
|
|
||||||
button = children.first();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (button) {
|
|
||||||
QSizeF s = button->boundingRect().size();
|
|
||||||
button->setPos(d->messageOverlay->boundingRect().width() / 2 - s.width() / 2,
|
|
||||||
d->messageOverlay->boundingRect().height() / 2 - s.height() / 2);
|
|
||||||
}*/
|
|
||||||
}
|
|
||||||
|
|
||||||
if (d->started && layout()) {
|
if (d->started && layout()) {
|
||||||
layout()->updateGeometry();
|
layout()->updateGeometry();
|
||||||
|
@ -160,6 +160,7 @@ private:
|
|||||||
Q_PRIVATE_SLOT(d, void updateDialogPosition())
|
Q_PRIVATE_SLOT(d, void updateDialogPosition())
|
||||||
|
|
||||||
friend class Applet;
|
friend class Applet;
|
||||||
|
friend class AppletPrivate;
|
||||||
friend class PopupAppletPrivate;
|
friend class PopupAppletPrivate;
|
||||||
PopupAppletPrivate * const d;
|
PopupAppletPrivate * const d;
|
||||||
};
|
};
|
||||||
|
@ -88,6 +88,7 @@ public:
|
|||||||
void setFocus();
|
void setFocus();
|
||||||
void cleanUpAndDelete();
|
void cleanUpAndDelete();
|
||||||
void createMessageOverlay(bool usePopup = true);
|
void createMessageOverlay(bool usePopup = true);
|
||||||
|
void positionMessageOverlay();
|
||||||
void destroyMessageOverlay();
|
void destroyMessageOverlay();
|
||||||
void addGlobalShortcutsPage(KConfigDialog *dialog);
|
void addGlobalShortcutsPage(KConfigDialog *dialog);
|
||||||
void clearShortcutEditorPtr();
|
void clearShortcutEditorPtr();
|
||||||
|
Loading…
Reference in New Issue
Block a user