┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src/kitemviews/kitemlistgroupheader.cpp
diff options
context:
space:
mode:
authorPeter Penz <[email protected]>2012-02-06 23:26:20 +0100
committerPeter Penz <[email protected]>2012-02-06 23:31:49 +0100
commit5369ee6819a26d9d3f106521c525c03f81a943ce (patch)
treeb6a31372f7fa6cd58aac1c7faeca6d5d96d50e32 /src/kitemviews/kitemlistgroupheader.cpp
parent7af39fb960352e0504153c627db0615d80758ebe (diff)
Group header improvements
- Use a simpler background and colors as suggested by Martin Zilz. This is just an early draft, I need to post some comparison screenshots to Martin for review. - Fixes of some layout issues that have been revealed because of adjusting the group header heights. - More clever animation/no-animation detection when doing listview-property changes in parallel.
Diffstat (limited to 'src/kitemviews/kitemlistgroupheader.cpp')
-rw-r--r--src/kitemviews/kitemlistgroupheader.cpp109
1 files changed, 25 insertions, 84 deletions
diff --git a/src/kitemviews/kitemlistgroupheader.cpp b/src/kitemviews/kitemlistgroupheader.cpp
index a63ad8d09..8eff39901 100644
--- a/src/kitemviews/kitemlistgroupheader.cpp
+++ b/src/kitemviews/kitemlistgroupheader.cpp
@@ -36,15 +36,13 @@ KItemListGroupHeader::KItemListGroupHeader(QGraphicsWidget* parent) :
m_data(),
m_styleOption(),
m_scrollOrientation(Qt::Vertical),
- m_leftBorderCache(0),
- m_rightBorderCache(0),
- m_outlineColor()
+ m_roleColor(),
+ m_roleBounds()
{
}
KItemListGroupHeader::~KItemListGroupHeader()
{
- deleteCache();
}
void KItemListGroupHeader::setRole(const QByteArray& role)
@@ -97,8 +95,6 @@ void KItemListGroupHeader::setScrollOrientation(Qt::Orientation orientation)
m_scrollOrientation = orientation;
if (orientation == Qt::Vertical) {
m_dirtyCache = true;
- } else {
- deleteCache();
}
scrollOrientationChanged(orientation, previous);
}
@@ -114,24 +110,25 @@ void KItemListGroupHeader::paint(QPainter* painter, const QStyleOptionGraphicsIt
Q_UNUSED(option);
Q_UNUSED(widget);
- if (m_scrollOrientation == Qt::Horizontal) {
- Q_ASSERT(!m_leftBorderCache);
- Q_ASSERT(!m_rightBorderCache);
- return;
- }
-
if (m_dirtyCache) {
updateCache();
}
- const int leftBorderX = m_leftBorderCache->width() + 1;
- const int rightBorderX = size().width() - m_rightBorderCache->width() - 2;
+ if (m_scrollOrientation != Qt::Horizontal) {
+ painter->setPen(m_roleColor);
+ const qreal y = m_roleBounds.y() - m_styleOption.margin;
+ painter->drawLine(0, y, size().width() - 1, y);
+ }
+}
- painter->setPen(m_outlineColor);
- painter->drawLine(leftBorderX, 1, rightBorderX, 1);
+QRectF KItemListGroupHeader::roleBounds() const
+{
+ return m_roleBounds;
+}
- painter->drawPixmap(1, 1, *m_leftBorderCache);
- painter->drawPixmap(rightBorderX, 1, *m_rightBorderCache);
+QColor KItemListGroupHeader::roleColor() const
+{
+ return m_roleColor;
}
void KItemListGroupHeader::roleChanged(const QByteArray& current, const QByteArray& previous)
@@ -170,82 +167,26 @@ void KItemListGroupHeader::updateCache()
{
Q_ASSERT(m_dirtyCache);
- deleteCache();
-
- const int length = qMax(int(size().height() - 1), 1);
- m_leftBorderCache = new QPixmap(length, length);
- m_leftBorderCache->fill(Qt::transparent);
-
- m_rightBorderCache = new QPixmap(length, length);
- m_rightBorderCache->fill(Qt::transparent);
-
// Calculate the outline color. No alphablending is used for
// performance reasons.
const QColor c1 = m_styleOption.palette.text().color();
const QColor c2 = m_styleOption.palette.background().color();
const int p1 = 35;
const int p2 = 100 - p1;
- m_outlineColor = QColor((c1.red() * p1 + c2.red() * p2) / 100,
- (c1.green() * p1 + c2.green() * p2) / 100,
- (c1.blue() * p1 + c2.blue() * p2) / 100);
-
- // The drawing code is based on the code of DolphinCategoryDrawer from Dolphin 1.7
- // Copyright (C) 2007 Rafael Fernández López <[email protected]>
- {
- // Cache the left border as pixmap
- QPainter painter(m_leftBorderCache);
- painter.setPen(m_outlineColor);
+ m_roleColor = QColor((c1.red() * p1 + c2.red() * p2) / 100,
+ (c1.green() * p1 + c2.green() * p2) / 100,
+ (c1.blue() * p1 + c2.blue() * p2) / 100);
- // 1. Draw top horizontal line
- painter.drawLine(3, 0, length, 0);
+ const int margin = m_styleOption.margin;
+ const QFontMetrics fontMetrics(m_styleOption.font);
+ const qreal roleHeight = fontMetrics.height();
- // 2. Draw vertical line with gradient
- const QPoint start(0, 3);
- QLinearGradient gradient(start, QPoint(0, length));
- gradient.setColorAt(0, m_outlineColor);
- gradient.setColorAt(1, Qt::transparent);
- painter.fillRect(QRect(start, QSize(1, length - start.y())), gradient);
-
- // 3. Draw arc
- painter.setRenderHint(QPainter::Antialiasing);
- QRectF arc(QPointF(0, 0), QSizeF(4, 4));
- arc.translate(0.5, 0.5);
- painter.drawArc(arc, 1440, 1440);
- }
-
- {
- // Cache the right border as pixmap
- QPainter painter(m_rightBorderCache);
- painter.setPen(m_outlineColor);
-
- // 1. Draw top horizontal line
- painter.drawLine(0, 0, length - 3, 0);
-
- // 2. Draw vertical line with gradient
- const int right = length - 1;
- const QPoint start(right, 3);
- QLinearGradient gradient(start, QPoint(right, length));
- gradient.setColorAt(0, m_outlineColor);
- gradient.setColorAt(1, Qt::transparent);
- painter.fillRect(QRect(start, QSize(1, length - start.y())), gradient);
-
- // 3. Draw arc
- painter.setRenderHint(QPainter::Antialiasing);
- QRectF arc(QPointF(length - 5, 0), QSizeF(4, 4));
- arc.translate(0.5, 0.5);
- painter.drawArc(arc, 0, 1440);
- }
+ m_roleBounds = QRectF(margin,
+ size().height() - roleHeight - margin,
+ size().width() - 2 * margin,
+ roleHeight);
m_dirtyCache = false;
}
-void KItemListGroupHeader::deleteCache()
-{
- delete m_leftBorderCache;
- m_leftBorderCache = 0;
-
- delete m_rightBorderCache;
- m_rightBorderCache = 0;
-}
-
#include "kitemlistgroupheader.moc"