source: trunk/doc/src/examples/dropsite.qdoc@ 349

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

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

File size: 11.5 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 draganddrop/dropsite
44 \title Drop Site Example
45
46 The example shows how to distinguish the various MIME formats available
47 in a drag and drop operation.
48
49 \image dropsite-example.png Screenshot of the Drop Site example
50
51 The Drop Site example accepts drops from other applications, and displays
52 the MIME formats provided by the drag object.
53
54 There are two classes, \c DropArea and \c DropSiteWindow, and a \c main()
55 function in this example. A \c DropArea object is instantiated in
56 \c DropSiteWindow; a \c DropSiteWindow object is then invoked in the
57 \c main() function.
58
59 \section1 DropArea Class Definition
60
61 The \c DropArea class is a subclass of QLabel with a public slot,
62 \c clear(), and a \c changed() signal.
63
64 \snippet draganddrop/dropsite/droparea.h DropArea header part1
65
66 In addition, \c DropArea also contains a private instance of QLabel and
67 reimplementations of four \l{QWidget} event handlers:
68
69 \list 1
70 \o \l{QWidget::dragEnterEvent()}{dragEnterEvent()}
71 \o \l{QWidget::dragMoveEvent()}{dragMoveEvent()}
72 \o \l{QWidget::dragLeaveEvent()}{dragLeaveEvent()}
73 \o \l{QWidget::dropEvent()}{dropEvent()}
74 \endlist
75
76 These event handlers are further explained in the implementation of the
77 \c DropArea class.
78
79 \snippet draganddrop/dropsite/droparea.h DropArea header part2
80
81 \section1 DropArea Class Implementation
82
83 In the \c DropArea constructor, we set the \l{QWidget::setMinimumSize()}
84 {minimum size} to 200x200 pixels, the \l{QFrame::setFrameStyle()}
85 {frame style} to both QFrame::Sunken and QFrame::StyledPanel, and we align
86 its contents to the center.
87
88 \snippet draganddrop/dropsite/droparea.cpp DropArea constructor
89
90 Also, we enable drop events in \c DropArea by setting the
91 \l{QWidget::acceptDrops()}{acceptDrops} property to \c true. Then,
92 we enable the \l{QWidget::autoFillBackground()}{autoFillBackground}
93 property and invoke the \c clear() function.
94
95 The \l{QWidget::dragEnterEvent()}{dragEnterEvent()} event handler is
96 called when a drag is in progress and the mouse enters the \c DropArea
97 object. For the \c DropSite example, when the mouse enters \c DropArea,
98 we set its text to "<drop content>" and highlight its background.
99
100 \snippet draganddrop/dropsite/droparea.cpp dragEnterEvent() function
101
102 Then, we invoke \l{QDropEvent::acceptProposedAction()}
103 {acceptProposedAction()} on \a event, setting the drop action to the one
104 proposed. Lastly, we emit the \c changed() signal, with the data that was
105 dropped and its MIME type information as a parameter.
106
107 For \l{QWidget::dragMoveEvent()}{dragMoveEvent()}, we just accept the
108 proposed QDragMoveEvent object, \a event, with
109 \l{QDropEvent::acceptProposedAction()}{acceptProposedAction()}.
110
111 \snippet draganddrop/dropsite/droparea.cpp dragMoveEvent() function
112
113 The \c DropArea class's implementation of \l{QWidget::dropEvent()}
114 {dropEvent()} extracts the \a{event}'s mime data and displays it
115 accordingly.
116
117 \snippet draganddrop/dropsite/droparea.cpp dropEvent() function part1
118
119 The \c mimeData object can contain one of the following objects: an image,
120 HTML text, plain text, or a list of URLs.
121
122 \snippet draganddrop/dropsite/droparea.cpp dropEvent() function part2
123
124 \list
125 \o If \c mimeData contains an image, we display it in \c DropArea with
126 \l{QLabel::setPixmap()}{setPixmap()}.
127 \o If \c mimeData contains HTML, we display it with
128 \l{QLabel::setText()}{setText()} and set \c{DropArea}'s text format
129 as Qt::RichText.
130 \o If \c mimeData contains plain text, we display it with
131 \l{QLabel::setText()}{setText()} and set \c{DropArea}'s text format
132 as Qt::PlainText. In the event that \c mimeData contains URLs, we
133 iterate through the list of URLs to display them on individual
134 lines.
135 \o If \c mimeData contains other types of objects, we set
136 \c{DropArea}'s text, with \l{QLabel::setText()}{setText()} to
137 "Cannot display data" to inform the user.
138 \endlist
139
140 We then set \c{DropArea}'s \l{QWidget::backgroundRole()}{backgroundRole} to
141 QPalette::Dark and we accept \c{event}'s proposed action.
142
143 \snippet draganddrop/dropsite/droparea.cpp dropEvent() function part3
144
145 The \l{QWidget::dragLeaveEvent()}{dragLeaveEvent()} event handler is
146 called when a drag is in progress and the mouse leaves the widget.
147
148 \snippet draganddrop/dropsite/droparea.cpp dragLeaveEvent() function
149
150 For \c{DropArea}'s implementation, we clear invoke \c clear() and then
151 accept the proposed event.
152
153 The \c clear() function sets the text in \c DropArea to "<drop content>"
154 and sets the \l{QWidget::backgroundRole()}{backgroundRole} to
155 QPalette::Dark. Lastly, it emits the \c changed() signal.
156
157 \snippet draganddrop/dropsite/droparea.cpp clear() function
158
159 \section1 DropSiteWindow Class Definition
160
161 The \c DropSiteWindow class contains a constructor and a public slot,
162 \c updateFormatsTable().
163
164 \snippet draganddrop/dropsite/dropsitewindow.h DropSiteWindow header
165
166 The class also contains a private instance of \c DropArea, \c dropArea,
167 QLabel, \c abstractLabel, QTableWidget, \c formatsTable, QDialogButtonBox,
168 \c buttonBox, and two QPushButton objects, \c clearButton and
169 \c quitButton.
170
171 \section1 DropSiteWindow Class Implementation
172
173 In the constructor of \c DropSiteWindow, we instantiate \c abstractLabel
174 and set its \l{QLabel::setWordWrap()}{wordWrap} property to \c true. We
175 also call the \l{QLabel::adjustSize()}{adjustSize()} function to adjust
176 \c{abstractLabel}'s size according to its contents.
177
178 \snippet draganddrop/dropsite/dropsitewindow.cpp constructor part1
179
180 Then we instantiate \c dropArea and connect its \c changed() signal to
181 \c{DropSiteWindow}'s \c updateFormatsTable() slot.
182
183 \snippet draganddrop/dropsite/dropsitewindow.cpp constructor part2
184
185 We now set up the QTableWidget object, \c formatsTable. Its
186 horizontal header is set using a QStringList object, \c labels. The number
187 of columms are set to two and the table is not editable. Also, the
188 \c{formatTable}'s horizontal header is formatted to ensure that its second
189 column stretches to occupy additional space available.
190
191 \snippet draganddrop/dropsite/dropsitewindow.cpp constructor part3
192
193 Two QPushButton objects, \c clearButton and \c quitButton, are instantiated
194 and added to \c buttonBox - a QDialogButtonBox object. We use
195 QDialogButtonBox here to ensure that the push buttons are presented in a
196 layout that conforms to the platform's style.
197
198 \snippet draganddrop/dropsite/dropsitewindow.cpp constructor part4
199
200 The \l{QPushButton::clicked()}{clicked()} signals for \c quitButton and
201 \c clearButton are connected to \l{QWidget::close()}{close()} and
202 \c clear(), respectively.
203
204 For the layout, we use a QVBoxLayout, \c mainLayout, to arrange our widgets
205 vertically. We also set the window title to "Drop Site" and the minimum
206 size to 350x500 pixels.
207
208 \snippet draganddrop/dropsite/dropsitewindow.cpp constructor part5
209
210 We move on to the \c updateFormatsTable() function. This function updates
211 the \c formatsTable, displaying the MIME formats of the object dropped onto
212 the \c DropArea object. First, we set \l{QTableWidget}'s
213 \l{QTableWidget::setRowCount()}{rowCount} property to 0. Then, we validate
214 to ensure that the QMimeData object passed in is a valid object.
215
216 \snippet draganddrop/dropsite/dropsitewindow.cpp updateFormatsTable() part1
217
218 Once we are sure that \c mimeData is valid, we iterate through its
219 supported formats using the \l{The foreach Keyword}{foreach keyword}.
220 This keyword has the following format:
221
222 \snippet doc/src/snippets/code/doc_src_examples_dropsite.qdoc 0
223
224 In our example, \c format is the \a variable and the \a container is a
225 QStringList, obtained from \c mimeData->formats().
226
227 \note The \l{QMimeData::formats()}{formats()} function returns a
228 QStringList object, containing all the formats supported by the
229 \c mimeData.
230
231 \snippet draganddrop/dropsite/dropsitewindow.cpp updateFormatsTable() part2
232
233 Within each iteration, we create a QTableWidgetItem, \c formatItem and we
234 set its \l{QTableWidgetItem::setFlags()}{flags} to Qt::ItemIsEnabled, and
235 its \l{QTableWidgetItem::setTextAlignment()}{text alignment} to Qt::AlignTop
236 and Qt::AlignLeft.
237
238 A QString object, \c text, is customized to display data according to the
239 contents of \c format. We invoke {QString}'s \l{QString::simplified()}
240 {simplified()} function on \c text, to obtain a string that has no
241 additional space before, after or in between words.
242
243 \snippet draganddrop/dropsite/dropsitewindow.cpp updateFormatsTable() part3
244
245 If \c format contains a list of URLs, we iterate through them, using spaces
246 to separate them. On the other hand, if \c format contains an image, we
247 display the data by converting the text to hexadecimal.
248
249 \snippet draganddrop/dropsite/dropsitewindow.cpp updateFormatsTable() part4
250
251 Once \c text has been customized to contain the appropriate data, we insert
252 both \c format and \c text into \c formatsTable with
253 \l{QTableWidget::setItem()}{setItem()}. Lastly, we invoke
254 \l{QTableView::resizeColumnToContents()}{resizeColumnToContents()} on
255 \c{formatsTable}'s first column.
256
257 \section1 The main() Function
258
259 Within the \c main() function, we instantiate \c DropSiteWindow and invoke
260 its \l{QWidget::show()}{show()} function.
261
262 \snippet draganddrop/dropsite/main.cpp main() function
263*/
Note: See TracBrowser for help on using the repository browser.