]> cloud.milkyroute.net Git - dolphin.git/blobdiff - src/kitemviews/kitemlistgroupheader.h
Merge branch 'Applications/14.12' into frameworks
[dolphin.git] / src / kitemviews / kitemlistgroupheader.h
index 135fd5e5f6ae2421bcd00e60528bdac5900db9c6..c89da50274aade92fef0e7f2405acd37cbb61781 100644 (file)
 #ifndef KITEMLISTGROUPHEADER_H
 #define KITEMLISTGROUPHEADER_H
 
-#include <libdolphin_export.h>
+#include "libdolphin_export.h"
 
+#include <kitemviews/kitemliststyleoption.h>
+
+#include <QByteArray>
 #include <QGraphicsWidget>
+#include <QVariant>
 
 class KItemListView;
 
+/**
+ * @brief Base class for group headers.
+ *
+ * Draws a default header background. Derived classes must reimplement
+ * the method paint() and draw the role within the given roleBounds() with
+ * the color roleColor().
+ */
 class LIBDOLPHINPRIVATE_EXPORT KItemListGroupHeader : public QGraphicsWidget
 {
     Q_OBJECT
@@ -34,11 +45,86 @@ public:
     KItemListGroupHeader(QGraphicsWidget* parent = 0);
     virtual ~KItemListGroupHeader();
 
-    void setIndex(int index);
-    int index() const;
+    void setRole(const QByteArray& role);
+    QByteArray role() const;
+
+    void setData(const QVariant& data);
+    QVariant data() const;
+
+    void setStyleOption(const KItemListStyleOption& option);
+    const KItemListStyleOption& styleOption() const;
+
+    /**
+     * Sets the scroll orientation that is used by the KItemListView.
+     * This allows the group header to use a modified look dependent
+     * on the orientation.
+     */
+    void setScrollOrientation(Qt::Orientation orientation);
+    Qt::Orientation scrollOrientation() const;
+
+    void setItemIndex(int index);
+    int itemIndex() const;
+
+    virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, QWidget* widget = 0) Q_DECL_OVERRIDE;
+
+protected:
+    virtual void paintRole(QPainter* painter, const QRectF& roleBounds, const QColor& color) = 0;
+    virtual void paintSeparator(QPainter* painter, const QColor& color) = 0;
+
+    /**
+     * Is called after the role has been changed and allows the derived class
+     * to react on this change.
+     */
+    virtual void roleChanged(const QByteArray& current, const QByteArray& previous);
+
+    /**
+     * Is called after the role has been changed and allows the derived class
+     * to react on this change.
+     */
+    virtual void dataChanged(const QVariant& current, const QVariant& previous);
+
+    /**
+     * Is called after the style option has been changed and allows the derived class
+     * to react on this change.
+     */
+    virtual void styleOptionChanged(const KItemListStyleOption& current, const KItemListStyleOption& previous);
+
+    /**
+     * Is called after the scroll orientation has been changed and allows the derived class
+     * to react on this change.
+     */
+    virtual void scrollOrientationChanged(Qt::Orientation current, Qt::Orientation previous);
+
+    /**
+     * Is called after the item index has been changed and allows the derived class to react on
+     * this change.
+     */
+    virtual void itemIndexChanged(int current, int previous);
+
+    virtual void resizeEvent(QGraphicsSceneResizeEvent* event) Q_DECL_OVERRIDE;
+
+    virtual QPalette::ColorRole normalTextColorRole() const;
+    virtual QPalette::ColorRole normalBaseColorRole() const;
+
+private:
+    void updateCache();
+
+    static QColor mixedColor(const QColor& c1, const QColor& c2, int c1Percent = 50);
+
+    QColor textColor() const;
+    QColor baseColor() const;
+
+private:
+    bool m_dirtyCache;
+    QByteArray m_role;
+    QVariant m_data;
+    KItemListStyleOption m_styleOption;
+    Qt::Orientation m_scrollOrientation;
+    int m_itemIndex;
 
-    virtual QSizeF sizeHint(Qt::SizeHint which = Qt::PreferredSize, const QSizeF& constraint = QSizeF()) const;
-    virtual void paint(QPainter* painter, const QStyleOptionGraphicsItem* option, QWidget* widget = 0);
+    QColor m_separatorColor;
+    QColor m_roleColor;
+    QRectF m_roleBounds;
 };
 #endif