source: trunk/doc/src/examples/dbscreen.qdoc@ 282

Last change on this file since 282 was 2, checked in by Dmitry A. Kuminov, 16 years ago

Initially imported qt-all-opensource-src-4.5.1 from Trolltech.

File size: 8.3 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4** Contact: Qt Software Information (qt-info@nokia.com)
5**
6** This file is part of the documentation of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial Usage
10** Licensees holding valid Qt Commercial licenses may use this file in
11** accordance with the Qt Commercial License Agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Nokia.
14**
15** GNU Lesser General Public License Usage
16** Alternatively, this file may be used under the terms of the GNU Lesser
17** General Public License version 2.1 as published by the Free Software
18** Foundation and appearing in the file LICENSE.LGPL included in the
19** packaging of this file. Please review the following information to
20** ensure the GNU Lesser General Public License version 2.1 requirements
21** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22**
23** In addition, as a special exception, Nokia gives you certain
24** additional rights. These rights are described in the Nokia Qt LGPL
25** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26** package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you are unsure which license is appropriate for your use, please
37** contact the sales department at qt-sales@nokia.com.
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42/*!
43 \example qws/dbscreen
44 \title Double Buffered Graphics Driver Example
45
46 The Double Buffered Graphics Driver example shows how to write your own
47 double buffered graphics driver and add it to Qt for Embedded Linux.
48
49 Similar to the \l{Accelerated Graphics Driver Example}, there are three steps
50 to writing and implementing this graphics driver:
51
52 \list 1
53 \o \l {Step 1: Creating a Custom Graphics Driver}
54 {Creating a Custom Graphics Driver}
55
56 \o \l {Step 2: Implementing the Back Buffer}
57 {Implementing the Back Buffer}
58
59 \o \l {Step 3: Creating the Driver Plugin}
60 {Creating the Driver Plugin}
61
62 \endlist
63
64 After compiling the example code, install the graphics driver plugin with
65 the command \c {make install}. To start an application using the graphics
66 driver, you can either set the environment variable \l QWS_DISPLAY and
67 then run the application, or you can just run the application using the
68 \c -display switch.
69
70 Note that this is a minimal example and this driver will not work well
71 with widgets painting themself directly to the screen (e.g. widgets with
72 the Qt::WA_PaintOnScreen window attribute set). Also, the example requires
73 the Linux framebuffer to be set up correctly and with the correct device
74 permissions. For further information, refer to
75 \l{Testing the Linux Framebuffer}.
76
77 \section1 Step 1: Creating a Custom Graphics Driver
78
79 Usually, a custom graphics driver is created by subclassing the QScreen
80 class, the base class for implementing screen or graphics drivers in
81 Qt for Embedded Linux. In this example, however, we subclass the QLinuxFbScreen
82 class instead, to ensure that our driver uses the Linux framebuffer.
83
84 For our graphics driver, the \c DBScreen class, we reimplement five
85 functions belonging to QScreen:
86
87 \list
88 \o \l{QScreen::initDevice()}{initDevice()},
89 \o \l{QScreen::shutdownDevice()}{shutdownDevice()},
90 \o \l{QScreen::blit()}{blit()},
91 \o \l{QScreen::solidFill()}{solidFill()}, and
92 \o \l{QScreen::exposeRegion()}{exposeRegion()}.
93 \endlist
94
95 \snippet examples/qws/dbscreen/dbscreen.h 0
96
97 In addition to the abovementioned functions, there is a private instance
98 of QPainter and QImage - \c painter, used for drawing operations on
99 the back buffer, and \c image, the back buffer itself.
100
101 \section1 Step 2: Implementing the Back Buffer
102
103 The graphics driver must carry out three main functions:
104
105 \list 1
106 \o Allocate the back buffer on startup and deallocate it on shutdown.
107 \o Draw to the back buffer instead of directly to the screen
108 (which is what QLinuxFbScreen does).
109 \o Copy the back buffer to the screen whenever a screen update is
110 done.
111 \endlist
112
113 \section2 Device initializing and shutdown
114
115 We first reimplement \c initDevice() and \c shutdownDevice().
116
117 The \c initDevice() function initializes the framebuffer. We reimplement
118 this function to enable accelerated drivers to set up the graphic card.
119 For this example, we first call the super class' implementation to set up
120 the Linux framebuffer. If this call returns \c false, we return \c false.
121 Otherwise, we initialize the screen cursor with
122 QScreenCursor::initSoftwareCursor() as well as instantiate \c image and
123 \c painter. Then, we return \c true.
124
125 \snippet examples/qws/dbscreen/dbscreen.cpp 0
126
127 The \c shutdownDevice() function's default implementation only hides the
128 mouse cursor. Hence, we reimplement it to carry out the necessary cleanup
129 before the Qt for Embedded Linux server exits.
130
131 \snippet examples/qws/dbscreen/dbscreen.cpp 1
132
133 Again, we call the super class implementation to shutdown the Linux
134 framebuffer prior to deleting \c image and \c painter.
135
136 \section2 Drawing to the back buffer
137
138 We move on to the drawing functions - \c solidFill() and \c blit(). In
139 QLinuxFbScreen, these functions draw directly to the Linux framebuffer;
140 but in our driver we reimplement them to draw to the back buffer instead.
141
142 \snippet examples/qws/dbscreen/dbscreen.cpp 2
143
144 The \c solidFill() function is called from \c exposeRegion() to fill the
145 given \c region of the screen with the specified \c color. In this
146 example, we use \c painter to fill rectangles in \c image, the back
147 buffer, according to the given region.
148
149 \snippet examples/qws/dbscreen/dbscreen.cpp 3
150
151 The \c blit() function is also called from \c exposeRegion() to copy the
152 given QRegion object, \c region, in the given QImage object, \c image, to
153 the QPoint object specified by \c topLeft. Once again we use \c painter
154 to draw in the back buffer, \c image.
155
156 \section2 Displaying the buffer on the screen
157
158 The \c exposeRegion() function is called by the Qt for Embedded Linux server
159 whenever a screen update is required. The given \c region is the screen
160 region that needs to be updated and \c changing is is the index into
161 QWSServer::clientWindows() of the window that caused the update.
162
163 \snippet examples/qws/dbscreen/dbscreen.cpp 4
164
165 In our implementation, we first call the super class implementation to
166 ensure that \c solidFill() and \c blit() will be called correctly. This
167 causes the changed areas to be updated in the back buffer. We then call
168 the super class' implementation of \c blit() to copy the updated region
169 from the back buffer into the Linux framebuffer.
170
171 \section1 Step 3: Creating the Driver Plugin
172
173 Qt provides a high level API for writing Qt extentions. One of the plugin
174 base classes provided is QScreenDriverPlugin, which we use in this example
175 to create our screen driver plugin.
176
177 \snippet examples/qws/dbscreen/dbscreendriverplugin.cpp 0
178
179 There are only two functions to reimplement:
180
181 \list
182 \o \l{QScreenDriverPlugin::create()}{create()} - creates a driver
183 matching the given key
184 \o \l{QScreenDriverPlugin::create()}{keys()} - returns a list of
185 valid keys representing the drivers supported by the plugin
186 \endlist
187
188 \snippet examples/qws/dbscreen/dbscreendriverplugin.cpp 1
189 \codeline
190 \snippet examples/qws/dbscreen/dbscreendriverplugin.cpp 2
191
192 Our plugin will only support one driver, \c dbscreen.
193
194 Lastly, we export the plugin.
195
196 \snippet examples/qws/dbscreen/dbscreendriverplugin.cpp 3
197
198 For detailed information about the Qt plugin system see
199 \l{How to Create Qt Plugins.}
200*/
Note: See TracBrowser for help on using the repository browser.