]> cloud.milkyroute.net Git - dolphin.git/commitdiff
use KGraphicsUtils::blendColor() instead of custom mixColors() method
authorPeter Penz <peter.penz19@gmail.com>
Mon, 28 May 2007 05:38:13 +0000 (05:38 +0000)
committerPeter Penz <peter.penz19@gmail.com>
Mon, 28 May 2007 05:38:13 +0000 (05:38 +0000)
svn path=/trunk/KDE/kdebase/apps/; revision=668924

src/statusbarmessagelabel.cpp
src/statusbarmessagelabel.h

index f5c632693801afdfa452dc356886780325417d45..32d57e09b283aab5fa4215af3b15081b4ca5b667 100644 (file)
@@ -21,6 +21,7 @@
 #include "statusbarmessagelabel.h"
 
 #include <kglobalsettings.h>
+#include <kgraphicsutils.h>
 #include <kiconloader.h>
 #include <kicon.h>
 #include <klocale.h>
@@ -137,8 +138,12 @@ void StatusBarMessageLabel::paintEvent(QPaintEvent* /* event */)
     QColor backgroundColor(palette().brush(QPalette::Background).color());
     QColor foregroundColor(KGlobalSettings::textColor());
     if (m_illumination > 0) {
-        backgroundColor = mixColors(backgroundColor, QColor(255, 255, 128), m_illumination);
-        foregroundColor = mixColors(foregroundColor, QColor(0, 0, 0), m_illumination);
+        QColor mixColor(255, 255, 128);
+        mixColor.setAlpha(m_illumination);
+        backgroundColor = KGraphicsUtils::blendColor(backgroundColor, mixColor);
+
+        mixColor.setRgb(0, 0, 0, m_illumination);
+        foregroundColor = KGraphicsUtils::blendColor(foregroundColor, mixColor);
     }
     painter.setBrush(backgroundColor);
     painter.setPen(backgroundColor);
@@ -175,8 +180,11 @@ void StatusBarMessageLabel::timerDone()
     switch (m_state) {
     case Illuminate: {
         // increase the illumination
-        if (m_illumination < 100) {
-            m_illumination += 20;
+        if (m_illumination < 255) {
+            m_illumination += 32;
+            if (m_illumination > 255) {
+                m_illumination = 255;
+            }
             update();
         } else {
             m_state = Illuminated;
@@ -258,17 +266,6 @@ int StatusBarMessageLabel::availableTextWidth() const
     return width() - m_pixmap.width() - (borderGap() * 4) - buttonWidth;
 }
 
-QColor StatusBarMessageLabel::mixColors(const QColor& c1,
-                                        const QColor& c2,
-                                        int percent) const
-{
-    const int recip = 100 - percent;
-    const int red   = (c1.red()   * recip + c2.red()   * percent) / 100;
-    const int green = (c1.green() * recip + c2.green() * percent) / 100;
-    const int blue  = (c1.blue()  * recip + c2.blue()  * percent) / 100;
-    return QColor(red, green, blue);
-}
-
 void StatusBarMessageLabel::updateCloseButtonPosition()
 {
     const int x = width() - m_closeButton->width() - borderGap();
index dcefdedfb373c39904f7136e1980f6381f3681d9..25610d4b6b42b62eb4e77dabd58175f6f7644e61 100644 (file)
@@ -155,10 +155,6 @@ private:
     QPixmap m_pixmap;
     QPushButton* m_closeButton;
 
-    QColor mixColors(const QColor& c1,
-                     const QColor& c2,
-                     int percent) const;
-
     int borderGap() const
     {
         return 2;