┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src/kitemviews/kitemlistviewlayouter.cpp
diff options
context:
space:
mode:
authorPeter Penz <[email protected]>2012-02-11 18:02:38 +0100
committerPeter Penz <[email protected]>2012-02-11 18:04:53 +0100
commit056d12d60f93a052e19f6e2cff9b826e500eef16 (patch)
tree45c79d8620617645e1e34cd996adf8cc02f268b1 /src/kitemviews/kitemlistviewlayouter.cpp
parente29e1cda15973969164d7b7fa805544189a5e172 (diff)
Group header layout fixes
- Don't use a margin for the first group header - Provide margins between the groups - Use a more subtle coloring - Prevent animation glitches when resizing a window
Diffstat (limited to 'src/kitemviews/kitemlistviewlayouter.cpp')
-rw-r--r--src/kitemviews/kitemlistviewlayouter.cpp40
1 files changed, 31 insertions, 9 deletions
diff --git a/src/kitemviews/kitemlistviewlayouter.cpp b/src/kitemviews/kitemlistviewlayouter.cpp
index 2d02b6725..a9b59051d 100644
--- a/src/kitemviews/kitemlistviewlayouter.cpp
+++ b/src/kitemviews/kitemlistviewlayouter.cpp
@@ -48,6 +48,7 @@ KItemListViewLayouter::KItemListViewLayouter(QObject* parent) :
m_columnCount(0),
m_groupItemIndexes(),
m_groupHeaderHeight(0),
+ m_groupHeaderMargin(0),
m_itemRects()
{
}
@@ -134,6 +135,19 @@ qreal KItemListViewLayouter::groupHeaderHeight() const
return m_groupHeaderHeight;
}
+void KItemListViewLayouter::setGroupHeaderMargin(qreal margin)
+{
+ if (m_groupHeaderMargin != margin) {
+ m_groupHeaderMargin = margin;
+ m_dirty = true;
+ }
+}
+
+qreal KItemListViewLayouter::groupHeaderMargin() const
+{
+ return m_groupHeaderMargin;
+}
+
void KItemListViewLayouter::setScrollOffset(qreal offset)
{
if (m_scrollOffset != offset) {
@@ -310,7 +324,7 @@ void KItemListViewLayouter::doLayout()
// In the horizontal scrolling case all groups are aligned
// at the top, which decreases the available height. For the
// flipped data this means that the width must be decreased.
- size.rwidth() -= m_groupHeaderHeight;
+ size.rwidth() -= m_groupHeaderMargin + m_groupHeaderHeight;
}
}
@@ -322,7 +336,7 @@ void KItemListViewLayouter::doLayout()
const int itemCount = m_model->count();
if (itemCount > m_columnCount && m_columnWidth >= 32) {
// Apply the unused width equally to each column
- const qreal unusedWidth = size.width() - m_columnCount * m_columnWidth;
+ const qreal unusedWidth = widthForColumns - m_columnCount * m_columnWidth;
if (unusedWidth > 0) {
const qreal columnInc = unusedWidth / (m_columnCount + 1);
m_columnWidth += columnInc;
@@ -349,16 +363,22 @@ void KItemListViewLayouter::doLayout()
if (horizontalScrolling) {
// All group headers will always be aligned on the top and not
// flipped like the other properties
- x += m_groupHeaderHeight;
+ x += m_groupHeaderMargin + m_groupHeaderHeight;
}
- if (m_groupItemIndexes.contains(index)) {
- if (!horizontalScrolling) {
- // The item is the first item of a group.
- // Increase the y-position to provide space
- // for the group header.
- y += m_groupHeaderHeight;
+ if (m_groupItemIndexes.contains(index) && !horizontalScrolling) {
+ // The item is the first item of a group.
+ // Increase the y-position to provide space
+ // for the group header.
+ if (index == 0) {
+ // The first group header should be aligned on top
+ y -= itemMargin.height();
+ } else {
+ // Only add a margin if there has been added another
+ // group already before
+ y += m_groupHeaderMargin;
}
+ y += m_groupHeaderHeight;
}
}
@@ -430,6 +450,8 @@ void KItemListViewLayouter::doLayout()
--index;
}
+ m_maximumScrollOffset += itemMargin.height();
+
m_maximumItemOffset = m_columnCount * m_columnWidth;
} else {
m_maximumScrollOffset = 0;