1
/***************************************************************************
2
* Copyright (C) 2011 by Peter Penz <peter.penz19@gmail.com> *
4
* This program is free software; you can redistribute it and/or modify *
5
* it under the terms of the GNU General Public License as published by *
6
* the Free Software Foundation; either version 2 of the License, or *
7
* (at your option) any later version. *
9
* This program is distributed in the hope that it will be useful, *
10
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
12
* GNU General Public License for more details. *
14
* You should have received a copy of the GNU General Public License *
15
* along with this program; if not, write to the *
16
* Free Software Foundation, Inc., *
17
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
18
***************************************************************************/
20
#ifndef KITEMLISTGROUPHEADER_H
21
#define KITEMLISTGROUPHEADER_H
23
#include <libdolphin_export.h>
25
#include <kitemviews/kitemliststyleoption.h>
28
#include <QGraphicsWidget>
34
* @brief Base class for group headers.
36
* Draws a default header background. Derived classes must reimplement
37
* the method paint() and draw the role within the given roleBounds() with
38
* the color roleColor().
40
class LIBDOLPHINPRIVATE_EXPORT KItemListGroupHeader : public QGraphicsWidget
45
KItemListGroupHeader(QGraphicsWidget* parent = 0);
46
virtual ~KItemListGroupHeader();
48
void setRole(const QByteArray& role);
49
QByteArray role() const;
51
void setData(const QVariant& data);
52
QVariant data() const;
54
void setStyleOption(const KItemListStyleOption& option);
55
const KItemListStyleOption& styleOption() const;
58
* Sets the scroll orientation that is used by the KItemListView.
59
* This allows the group header to use a modified look dependent
62
void setScrollOrientation(Qt::Orientation orientation);
63
Qt::Orientation scrollOrientation() const;
65
void setItemIndex(int index);
66
int itemIndex() const;
68
virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, QWidget* widget = 0);
71
/** @return Bounding rectangle where the role should be drawn into. */
72
QRectF roleBounds() const;
74
/** @return Primary color that should be used for drawing the role. */
75
QColor roleColor() const;
78
* Is called after the role has been changed and allows the derived class
79
* to react on this change.
81
virtual void roleChanged(const QByteArray& current, const QByteArray& previous);
84
* Is called after the role has been changed and allows the derived class
85
* to react on this change.
87
virtual void dataChanged(const QVariant& current, const QVariant& previous);
90
* Is called after the style option has been changed and allows the derived class
91
* to react on this change.
93
virtual void styleOptionChanged(const KItemListStyleOption& current, const KItemListStyleOption& previous);
96
* Is called after the scroll orientation has been changed and allows the derived class
97
* to react on this change.
99
virtual void scrollOrientationChanged(Qt::Orientation current, Qt::Orientation previous);
102
* Is called after the item index has been changed and allows the derived class to react on
105
virtual void itemIndexChanged(int current, int previous);
108
virtual void resizeEvent(QGraphicsSceneResizeEvent* event);
113
static QColor mixedColor(const QColor& c1, const QColor& c2, int c1Percent = 50);
119
KItemListStyleOption m_styleOption;
120
Qt::Orientation m_scrollOrientation;