Add PLUGIN_CLASS_NAME to qtbase plugins
[profile/ivi/qtbase.git] / src / plugins / platforms / eglfs / qeglfscursor.h
1 /****************************************************************************
2 **
3 ** Copyright (C) 2012 Digia Plc and/or its subsidiary(-ies).
4 ** Contact: http://www.qt-project.org/legal
5 **
6 ** This file is part of the plugins of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:LGPL$
9 ** Commercial License Usage
10 ** Licensees holding valid commercial Qt licenses may use this file in
11 ** accordance with the commercial license agreement provided with the
12 ** Software or, alternatively, in accordance with the terms contained in
13 ** a written agreement between you and Digia.  For licensing terms and
14 ** conditions see http://qt.digia.com/licensing.  For further information
15 ** use the contact form at http://qt.digia.com/contact-us.
16 **
17 ** GNU Lesser General Public License Usage
18 ** Alternatively, this file may be used under the terms of the GNU Lesser
19 ** General Public License version 2.1 as published by the Free Software
20 ** Foundation and appearing in the file LICENSE.LGPL included in the
21 ** packaging of this file.  Please review the following information to
22 ** ensure the GNU Lesser General Public License version 2.1 requirements
23 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
24 **
25 ** In addition, as a special exception, Digia gives you certain additional
26 ** rights.  These rights are described in the Digia Qt LGPL Exception
27 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
28 **
29 ** GNU General Public License Usage
30 ** Alternatively, this file may be used under the terms of the GNU
31 ** General Public License version 3.0 as published by the Free Software
32 ** Foundation and appearing in the file LICENSE.GPL included in the
33 ** packaging of this file.  Please review the following information to
34 ** ensure the GNU General Public License version 3.0 requirements will be
35 ** met: http://www.gnu.org/copyleft/gpl.html.
36 **
37 **
38 ** $QT_END_LICENSE$
39 **
40 ****************************************************************************/
41
42 #ifndef QEGLFSCURSOR_H
43 #define QEGLFSCURSOR_H
44
45 #include <qpa/qplatformcursor.h>
46 #include "qeglfsscreen.h"
47 #include <GLES2/gl2.h>
48
49 QT_BEGIN_NAMESPACE
50
51 class QOpenGLShaderProgram;
52 class QEglFSScreen;
53
54 class QEglFSCursor : public QPlatformCursor
55 {
56 public:
57     QEglFSCursor(QEglFSScreen *screen);
58     ~QEglFSCursor();
59
60 #ifndef QT_NO_CURSOR
61     void changeCursor(QCursor *cursor, QWindow *widget) Q_DECL_OVERRIDE;
62 #endif
63     void pointerEvent(const QMouseEvent &event) Q_DECL_OVERRIDE;
64
65     QPoint pos() const Q_DECL_OVERRIDE;
66     void setPos(const QPoint &pos) Q_DECL_OVERRIDE;
67
68     QRect cursorRect() const;
69
70     virtual void paintOnScreen();
71
72 protected:
73 #ifndef QT_NO_CURSOR
74     bool setCurrentCursor(QCursor *cursor);
75 #endif
76     void draw(const QRectF &rect);
77     void update(const QRegion &region);
78
79     QEglFSScreen *m_screen;
80
81     // current cursor information
82     struct Cursor {
83         Cursor() : texture(0), shape(Qt::BlankCursor), customCursorTexture(0) { }
84         uint texture; // a texture from 'image' or the atlas
85         Qt::CursorShape shape;
86         QRectF textureRect; // normalized rect inside texture
87         QSize size; // size of the cursor
88         QPoint hotSpot;
89         QImage customCursorImage;
90         QPoint pos; // current cursor position
91         uint customCursorTexture;
92     } m_cursor;
93
94 private:
95     void createShaderPrograms();
96     static void createCursorTexture(uint *texture, const QImage &image);
97     void initCursorAtlas();
98
99     // cursor atlas information
100     struct CursorAtlas {
101         CursorAtlas() : cursorsPerRow(0), texture(0), cursorWidth(0), cursorHeight(0) { }
102         int cursorsPerRow;
103         uint texture;
104         int width, height; // width and height of the the atlas
105         int cursorWidth, cursorHeight; // width and height of cursors inside the atlas
106         QList<QPoint> hotSpots;
107         QImage image; // valid until it's uploaded
108     } m_cursorAtlas;
109
110     GLuint m_program;
111     int m_vertexCoordEntry;
112     int m_textureCoordEntry;
113     int m_textureEntry;
114 };
115
116 QT_END_NAMESPACE
117
118 #endif // QEGLFSCURSOR_H
119