[prev in list] [next in list] [prev in thread] [next in thread] 

List:       kde-commits
Subject:    KDE/kdebase/workspace/libs/plasma/widgets
From:       Aaron J. Seigo <aseigo () kde ! org>
Date:       2007-06-17 17:49:50
Message-ID: 1182102590.565668.23262.nullmailer () svn ! kde ! org
[Download RAW message or body]

SVN commit 676786 by aseigo:

* use EaseIn for the icon button show
* show the button(s) in .2s rather than the very slow feeling .5s
* don't leak the timeline
* don't connect to the timeline signal more than once
* comment in code that is ifdef'd out anyways
* don't set the svg element for fg and bg unless it exists
* remove some dead code


 M  +26 -43    icon.cpp  


--- trunk/KDE/kdebase/workspace/libs/plasma/widgets/icon.cpp #676785:676786
@@ -23,7 +23,7 @@
 #include <QGraphicsSceneMouseEvent>
 #include <QGraphicsView>
 
-// #define PROVE_IT_CAN_BE_DONE
+//#define PROVE_IT_CAN_BE_DONE
 
 #ifdef PROVE_IT_CAN_BE_DONE
 #include <private/qwindowsurface_p.h>
@@ -78,7 +78,6 @@
                 svgElements |= SvgForegroundPressed;
             }
             stepMenu = 0;
-            timeline = new QTimeLine;
             button1Pressed = false;
             button1Hovered = false;
         }
@@ -104,7 +103,7 @@
         QSizeF size;
         QSizeF iconSize;
         QIcon icon;
-        QTimeLine *timeline;
+        QTimeLine timeline;
         ButtonState state;
         Svg svg;
         int svgElements;
@@ -123,7 +122,10 @@
     setEnabled(true);
     setFlags(ItemIsMovable);
     setPos(QPointF(0.0,0.0));
-    d->timeline->setDuration(500);
+    connect(&d->timeline, SIGNAL(frameChanged(int)), this, SLOT(animateBubbles(int)));
+    d->timeline.setCurveShape(QTimeLine::EaseInCurve);
+    d->timeline.setDuration(200);
+    d->timeline.setFrameRange(0, 5);
 }
 
 Icon::~Icon()
@@ -142,24 +144,23 @@
     Q_UNUSED(widget)
 
 #ifdef PROVE_IT_CAN_BE_DONE
-//     if (d->state == Private::HoverState && scene()) {
-//         QList<QGraphicsView*> views = scene()->views();
-//         if (views.count() > 0) {
-//             QPixmap* pix = static_cast<QPixmap*>(views[0]->windowSurface()->paintDevice());
-//             QImage image(boundingRect().size().toSize(), QImage::Format_ARGB32_Premultiplied);
-//             {
-//                 QPainter p(&image);
-//                 p.drawPixmap(image.rect(), *pix, sceneBoundingRect());
-//             }
-//             expblur<16,7>(image, 8);
-//             painter->save();
-//             painter->drawImage(0, 0, image);
-//             painter->restore();
-//         }
-//     }
+     if (d->state == Private::HoverState && scene()) {
+         QList<QGraphicsView*> views = scene()->views();
+         if (views.count() > 0) {
+             QPixmap* pix = static_cast<QPixmap*>(views[0]->windowSurface()->paintDevice());
+             QImage image(boundingRect().size().toSize(), QImage::Format_ARGB32_Premultiplied);
+             {
+                 QPainter p(&image);
+                 p.drawPixmap(image.rect(), *pix, sceneBoundingRect());
+             }
+             expblur<16,7>(image, 8);
+             painter->save();
+             painter->drawImage(0, 0, image);
+             painter->restore();
+         }
+     }
 #endif
 
-    
     QString element;
     if (d->svgElements & Private::SvgBackground) {
         element = "background";
@@ -167,7 +168,6 @@
 
     switch (d->state) {
         case Private::NoState:
-            element = "background";
             break;
         case Private::HoverState:
             if (d->svgElements & Private::SvgBackgroundHover) {
@@ -219,7 +219,6 @@
 
     switch (d->state) {
         case Private::NoState:
-            element = "foreground";
             break;
         case Private::HoverState:
             if (d->svgElements & Private::SvgForegroundHover) {
@@ -244,19 +243,16 @@
     // Draw top-left button
     QColor colorButton1;
     if (d->button1Hovered) {
-//         colorButton1 = QColor(0, 49, 110); //Oxygen color
         element = "button1-hover";
     } else if (d->button1Pressed) {
-//         colorButton1 = QColor(29, 10, 85); //Oxygen color
         element = "button1-pressed";
     } else {
-//         colorButton1 = QColor(0, 67, 138); //Oxygen color
         element = "button1";
     }
 
     KIcon exec("exec");
     painter->setRenderHint(QPainter::Antialiasing);
-    painter->setOpacity(d->stepMenu*0.04);
+    painter->setOpacity(d->stepMenu*0.2);
 //     painter->setBrush(colorButton1);
     painter->setPen(Qt::NoPen);
 
@@ -388,33 +384,20 @@
         d->button1Hovered = false;
     }
 
-    if (d->timeline->state() == QTimeLine::Running) {
-        d->timeline->setPaused(true);
-    }
-    d->timeline->setFrameRange(0, 25);
-    d->timeline->setDirection(QTimeLine::Forward);
-    connect(d->timeline, SIGNAL(frameChanged(int)), this, SLOT(animateBubbles(int)));
-
+    d->timeline.setDirection(QTimeLine::Forward);
     d->state = Private::HoverState;
     QGraphicsItem::hoverEnterEvent(event);
-    d->timeline->start();
+    d->timeline.start();
 }
 
 void Icon::hoverLeaveEvent(QGraphicsSceneHoverEvent *event)
 {
-    if (d->timeline->state() == QTimeLine::Running) {
-        d->timeline->setPaused(true);
-    }
+    d->timeline.setDirection(QTimeLine::Backward);
 
-    d->timeline->setFrameRange(0, 25);
-    d->timeline->setDirection(QTimeLine::Backward);
-
-    connect(d->timeline, SIGNAL(frameChanged(int)), this, SLOT(animateBubbles(int)));
-
     d->state = Private::HoverState;
     QGraphicsItem::hoverEnterEvent(event);
 
-    d->timeline->start();
+    d->timeline.start();
     d->state = Private::NoState;
     QGraphicsItem::hoverLeaveEvent(event);
 }
[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic