backport revision 929233
Fix handle possibly moving to the other side if the cursor exist for a short time. Remove the handle if the cursor goes away before we even appear, previously the handle was kept invisible until the cursor next entered. svn path=/branches/KDE/4.2/kdelibs/; revision=929237
This commit is contained in:
parent
c4e98d21ed
commit
2321a47eae
@ -102,7 +102,7 @@ AppletHandle::AppletHandle(Containment *parent, Applet *applet, const QPointF &h
|
||||
m_leaveTimer->setSingleShot(true);
|
||||
m_leaveTimer->setInterval(500);
|
||||
|
||||
connect(m_hoverTimer, SIGNAL(timeout()), this, SLOT(fadeIn()));
|
||||
connect(m_hoverTimer, SIGNAL(timeout()), this, SLOT(hoverTimeout()));
|
||||
connect(m_leaveTimer, SIGNAL(timeout()), this, SLOT(leaveTimeout()));
|
||||
connect(m_applet, SIGNAL(destroyed(QObject*)), this, SLOT(appletDestroyed()));
|
||||
|
||||
@ -145,7 +145,7 @@ void AppletHandle::detachApplet ()
|
||||
return;
|
||||
}
|
||||
|
||||
disconnect(m_hoverTimer, SIGNAL(timeout()), this, SLOT(fadeIn()));
|
||||
disconnect(m_hoverTimer, SIGNAL(timeout()), this, SLOT(hoverTimeout()));
|
||||
disconnect(m_leaveTimer, SIGNAL(timeout()), this, SLOT(leaveTimeout()));
|
||||
m_applet->disconnect(this);
|
||||
|
||||
@ -771,29 +771,29 @@ void AppletHandle::hoverEnterEvent(QGraphicsSceneHoverEvent *event)
|
||||
//kDebug() << "hover enter";
|
||||
|
||||
//if a disappear was scheduled stop the timer
|
||||
m_leaveTimer->stop();
|
||||
|
||||
if (m_leaveTimer->isActive()) {
|
||||
m_leaveTimer->stop();
|
||||
}
|
||||
// if we're already fading out, fade back in
|
||||
if (m_animId != 0 && m_anim == FadeOut) {
|
||||
startFading(FadeIn, m_entryPos);
|
||||
} else {
|
||||
//schedule appear
|
||||
m_hoverTimer->start();
|
||||
else if (m_animId != 0 && m_anim == FadeOut) {
|
||||
startFading(FadeIn, m_entryPos, true);
|
||||
}
|
||||
}
|
||||
|
||||
void AppletHandle::hoverMoveEvent(QGraphicsSceneHoverEvent *event)
|
||||
{
|
||||
Q_UNUSED(event);
|
||||
m_leaveTimer->stop();
|
||||
hoverEnterEvent(event);
|
||||
}
|
||||
|
||||
void AppletHandle::hoverLeaveEvent(QGraphicsSceneHoverEvent *event)
|
||||
{
|
||||
Q_UNUSED(event);
|
||||
m_hoverTimer->stop();
|
||||
|
||||
if (m_pressedButton != NoButton) {
|
||||
// if we haven't even showed up yet, remove the handle
|
||||
if (m_hoverTimer->isActive()) {
|
||||
m_hoverTimer->stop();
|
||||
QTimer::singleShot(0, this, SLOT(emitDisappear()));
|
||||
} else if (m_pressedButton != NoButton) {
|
||||
m_pendingFade = true;
|
||||
} else {
|
||||
//wait a moment to hide the handle in order to recheck the mouse position
|
||||
@ -829,7 +829,7 @@ void AppletHandle::fadeAnimation(qreal progress)
|
||||
update();
|
||||
}
|
||||
|
||||
void AppletHandle::fadeIn()
|
||||
void AppletHandle::hoverTimeout()
|
||||
{
|
||||
startFading(FadeIn, m_entryPos);
|
||||
}
|
||||
@ -856,20 +856,16 @@ void AppletHandle::setHoverPos(const QPointF &hoverPos)
|
||||
m_entryPos = hoverPos;
|
||||
}
|
||||
|
||||
void AppletHandle::startFading(FadeType anim, const QPointF &hoverPos)
|
||||
void AppletHandle::startFading(FadeType anim, const QPointF &hoverPos, bool preserveSide)
|
||||
{
|
||||
if (m_animId != 0) {
|
||||
Animator::self()->stopCustomAnimation(m_animId);
|
||||
}
|
||||
|
||||
m_hoverTimer->stop();
|
||||
m_leaveTimer->stop();
|
||||
|
||||
m_entryPos = hoverPos;
|
||||
qreal time = 100;
|
||||
|
||||
if (!m_applet || (anim == FadeOut && m_hoverTimer->isActive())) {
|
||||
// fading out before we've started fading in
|
||||
if (!m_applet) {
|
||||
m_anim = FadeOut;
|
||||
fadeAnimation(1.0);
|
||||
return;
|
||||
@ -879,7 +875,9 @@ void AppletHandle::startFading(FadeType anim, const QPointF &hoverPos)
|
||||
//kDebug() << m_entryPos.x() << m_applet->pos().x();
|
||||
prepareGeometryChange();
|
||||
bool wasOnRight = m_buttonsOnRight;
|
||||
m_buttonsOnRight = m_entryPos.x() > (m_applet->size().width() / 2);
|
||||
if (!preserveSide) {
|
||||
m_buttonsOnRight = m_entryPos.x() > (m_applet->size().width() / 2);
|
||||
}
|
||||
calculateSize();
|
||||
QPolygonF region = mapToParent(m_rect).intersected(parentWidget()->boundingRect());
|
||||
//kDebug() << region << m_rect << mapToParent(m_rect) << parentWidget()->boundingRect();
|
||||
|
@ -63,7 +63,7 @@ class AppletHandle : public QObject, public QGraphicsItem
|
||||
QRectF boundingRect() const;
|
||||
QPainterPath shape() const;
|
||||
void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = 0);
|
||||
void startFading(FadeType anim, const QPointF &hoverPos);
|
||||
void startFading(FadeType anim, const QPointF &hoverPos, bool preserveSide = false);
|
||||
void setHoverPos(const QPointF &hoverPos);
|
||||
|
||||
protected:
|
||||
@ -83,7 +83,7 @@ class AppletHandle : public QObject, public QGraphicsItem
|
||||
void fadeAnimation(qreal progress);
|
||||
void appletDestroyed();
|
||||
void appletResized();
|
||||
void fadeIn();
|
||||
void hoverTimeout();
|
||||
void leaveTimeout();
|
||||
void emitDisappear();
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user