]> cloud.milkyroute.net Git - dolphin.git/commitdiff
Use PE_PanelItemViewItem for consistency
authorRafael Fernández López <ereslibre@kde.org>
Sat, 29 Mar 2008 16:01:06 +0000 (16:01 +0000)
committerRafael Fernández López <ereslibre@kde.org>
Sat, 29 Mar 2008 16:01:06 +0000 (16:01 +0000)
svn path=/trunk/KDE/kdebase/apps/; revision=791451

src/dolphincategorydrawer.cpp

index b96387646397ec4b6eefbb638806c5a20ac63e65..721b0dc68dc580b2b9558268132b7bc30ab196d0 100644 (file)
@@ -24,6 +24,8 @@
 #include <QPainter>
 #include <QFile>
 #include <QDir>
 #include <QPainter>
 #include <QFile>
 #include <QDir>
+#include <QApplication>
+#include <QStyleOption>
 
 #ifdef HAVE_NEPOMUK
 #include <nepomuk/kratingpainter.h>
 
 #ifdef HAVE_NEPOMUK
 #include <nepomuk/kratingpainter.h>
@@ -37,6 +39,8 @@
 #include "dolphinview.h"
 #include "dolphinmodel.h"
 
 #include "dolphinview.h"
 #include "dolphinmodel.h"
 
+#define HORIZONTAL_HINT 3
+
 DolphinCategoryDrawer::DolphinCategoryDrawer()
 {
 }
 DolphinCategoryDrawer::DolphinCategoryDrawer()
 {
 }
@@ -79,37 +83,19 @@ void DolphinCategoryDrawer::drawCategory(const QModelIndex &index, int sortRole,
     QStyleOptionButton opt;
 
     opt.rect = option.rect;
     QStyleOptionButton opt;
 
     opt.rect = option.rect;
+    opt.rect.setLeft(opt.rect.left() + HORIZONTAL_HINT);
+    opt.rect.setRight(opt.rect.right() - HORIZONTAL_HINT);
     opt.palette = option.palette;
     opt.direction = option.direction;
     opt.text = category;
 
     opt.palette = option.palette;
     opt.direction = option.direction;
     opt.text = category;
 
-    if (option.state & QStyle::State_Selected)
-    {
-        QColor selected = option.palette.color(QPalette::Highlight);
-
-        QLinearGradient gradient(option.rect.topLeft(),
-                                 option.rect.bottomRight());
-        gradient.setColorAt(option.direction == Qt::LeftToRight ? 0
-                                                                : 1, selected);
-        gradient.setColorAt(option.direction == Qt::LeftToRight ? 1
-                                                                : 0, Qt::transparent);
-
-        painter->fillRect(option.rect, gradient);
-    }
-    else if (option.state & QStyle::State_MouseOver)
-    {
-        QColor hover = option.palette.color(QPalette::Highlight);
-        hover.setAlpha(88);
-
-        QLinearGradient gradient(option.rect.topLeft(),
-                                 option.rect.bottomRight());
-        gradient.setColorAt(option.direction == Qt::LeftToRight ? 0
-                                                                : 1, hover);
-        gradient.setColorAt(option.direction == Qt::LeftToRight ? 1
-                                                                : 0, Qt::transparent);
-
-        painter->fillRect(option.rect, gradient);
-    }
+    QStyleOptionViewItemV4 viewOptions;
+    viewOptions.rect = option.rect;
+    viewOptions.palette = option.palette;
+    viewOptions.direction = option.direction;
+    viewOptions.state = option.state;
+    viewOptions.viewItemPosition = QStyleOptionViewItemV4::OnlyOne;
+    QApplication::style()->drawPrimitive(QStyle::PE_PanelItemViewItem, &viewOptions, painter, 0);
 
     QFont painterFont = painter->font();
     painterFont.setWeight(QFont::Bold);
 
     QFont painterFont = painter->font();
     painterFont.setWeight(QFont::Bold);