source: src/mvc/delegate.h @ e6ab8a2

qt5
Last change on this file since e6ab8a2 was e6ab8a2, checked in by Philipp Spitzer <philipp@…>, 11 years ago

Removed the ability to show "pictures" (maps) of rooms and maps of conferences.
The XML file does not contain picture/map/image information of conferences or rooms.
We left the room.picture definition in the database SQL because there is no "drop column"
in sqlite.

  • Property mode set to 100644
File size: 3.9 KB
Line 
1/*
2 * Copyright (C) 2010 Ixonos Plc.
3 * Copyright (C) 2011 Philipp Spitzer, gregor herrmann
4 *
5 * This file is part of ConfClerk.
6 *
7 * ConfClerk is free software: you can redistribute it and/or modify it
8 * under the terms of the GNU General Public License as published by the Free
9 * Software Foundation, either version 2 of the License, or (at your option)
10 * any later version.
11 *
12 * ConfClerk is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
14 * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
15 * more details.
16 *
17 * You should have received a copy of the GNU General Public License along with
18 * ConfClerk.  If not, see <http://www.gnu.org/licenses/>.
19 */
20#ifndef DELEGATE_H
21#define DELEGATE_H
22
23#include <QItemDelegate>
24#include <QTreeView>
25#include <QPointer>
26
27class Delegate : public QItemDelegate
28{
29    Q_OBJECT
30
31    public:
32
33        enum ControlId
34        {
35            ControlNone = 0,
36            FavouriteControlOn,
37            FavouriteControlOff,
38            AlarmControlOn,
39            AlarmControlOff,
40            WarningControl
41        };
42
43        class Control
44        {
45            public:
46                Control(ControlId aControlId, const QString &aImageName, const Control* prev_control);
47
48                inline QImage *image() const { return mImage; }
49                inline void setDrawPoint(const QPoint &aPoint) { mDrawPoint = aPoint; }
50                inline QRect drawRect(const QRect &aRect) const // helper for determining if Control was clicked
51                {
52                    return QRect(drawPoint(aRect), drawPoint(aRect)+QPoint(mImage->size().width(),mImage->size().height()));
53                }
54                void paint(QPainter* painter, const QRect rect);
55
56                bool enabled() const { return mEnabled; }
57                void setEnabled(bool v) { mEnabled = v; }
58            private:
59                inline QPoint drawPoint(const QRect &aRect = QRect()) const // for painter to draw Control
60                {
61                    if(aRect == QRect()) // null rectangle
62                        return mDrawPoint; // returns relative drawing point
63                    else
64                        return QPoint(aRect.x()+aRect.width(),aRect.y()) + mDrawPoint; // returns absolute drawing point
65                }
66
67                ControlId mId;
68                QImage *mImage;
69                QPoint mDrawPoint; // relative 'start-drawing' position (may hold negative values)
70                bool mEnabled;
71        };
72
73        Delegate(QTreeView *aParent); // the delegate 'owner' has to be specified in the constructor - it's used to obtain visualRect of selected item/index
74        ~Delegate();
75
76        void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const;
77        QSize sizeHint(const QStyleOptionViewItem &option, const QModelIndex &index) const;
78        //
79        Delegate::ControlId whichControlClicked(const QModelIndex &aIndex, const QPoint &aPoint) const;
80        bool isPointFromRect(const QPoint &aPoint, const QRect &aRect) const;
81
82    private:
83        bool hasParent( const QModelIndex &index ) const;
84        bool isLast( const QModelIndex &index ) const;
85        bool isExpanded( const QModelIndex &index ) const;
86        void defineControls();
87        // TODO: the better place for these methods would be 'eventmodel'
88        // they are used in 'paint' method and so it's better to obtain number of
89        // favourities/alarms once when the data has changed and not to call
90        // these methods which iterate over all Events in corresponding group
91        // every time it requires them
92        int numberOfFavourities(const QModelIndex &index) const;
93        int numberOfAlarms(const QModelIndex &index) const;
94
95    private:
96        QPointer<QTreeView> mViewPtr;
97        QMap<ControlId,Control*> mControls;
98};
99
100#endif /* DELEGATE_H */
101
Note: See TracBrowser for help on using the repository browser.