summaryrefslogtreecommitdiffstats
path: root/doc/src/examples/delayedencoding.qdoc
blob: d94b589021d2bdd05b4c27eb3fbaeb3bd09e0b65 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/****************************************************************************
**
** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
** All rights reserved.
** Contact: Nokia Corporation (qt-info@nokia.com)
**
** This file is part of the documentation of the Qt Toolkit.
**
** $QT_BEGIN_LICENSE:FDL$
** GNU Free Documentation License
** Alternatively, this file may be used under the terms of the GNU Free
** Documentation License version 1.3 as published by the Free Software
** Foundation and appearing in the file included in the packaging of
** this file.
**
** Other Usage
** Alternatively, this file may be used in accordance with the terms
** and conditions contained in a signed written agreement between you
** and Nokia.
**
**
**
**
** $QT_END_LICENSE$
**
****************************************************************************/

/*!
    \example draganddrop/delayedencoding
    \title Delayed Encoding Example

    \brief The Delayed Encoding example shows how to delay preparing of data
    for drag and drop operations until a drop target is found.

    \image delayedecoding-example.png

    The \gui Export push button is pressed down to start the drag.
    The data for the drag and drop operation is not processed until
    the user of the application has found a valid drop target. This
    removes redundant processing if the operation is aborted. In our
    case, we have an SVG image that we wish to send as the \c {
    "image/png" } MIME type. It is the conversion from SVG to PNG we
    wish to delay - it can be quite expensive.

    The example is implemented in two classes: \c SourceWidget and \c
    MimeData. The \c SourceWidget class sets up the GUI and starts the
    drag operation on request. The \c MimeData class, which inherits
    QMimeData, sends a signal when a drop target is found. This signal
    is connected to a slot in \c SourceWidget, which does the
    conversion from SVG to PNG. 

    \section1 SourceWidget Class Definition

    The \c SourceWidget class starts drag and drop operations and also
    does the image conversion.
    
    \snippet examples/draganddrop/delayedencoding/sourcewidget.h 0
    
    The \gui Export push button is connected to the \c startDrag()
    slot. The \c createData() slot will be invoked when data for the
    drag and drop operation is to be created.

    \section1 SourceWidget Class Implementation

    Let's start our code tour with a look at the \c startDrag() slot.

    \snippet examples/draganddrop/delayedencoding/sourcewidget.cpp 0

    We emit \c dataRequested() from \c MimeData when the operation has
    found a valid drop target.

    We gallop along to \c createData():

    \snippet examples/draganddrop/delayedencoding/sourcewidget.cpp 1

    Fortunately, Qt provides QSvgRenderer, which can render the SVG
    image to any QPaintDevice. Also, QImage has no problems saving to
    the PNG format.

    Finally, we can give the data to \c MimeData.

    \section1 MimeData Class Definition

    The \c MimeData class inherits QMimeData and makes it possible to
    delay preparing of the data for a drag and drop operation.

    \snippet examples/draganddrop/delayedencoding/mimedata.h 0

    We will look closer at \c retrieveData() and \c formats() in the
    next section.

    \section1 MimeData Class Implementation

    \snippet examples/draganddrop/delayedencoding/mimedata.cpp 0

    In the \c formats() function, we return the format of the
    data we provide. This is the \c { image/png } MIME type.

    \snippet examples/draganddrop/delayedencoding/mimedata.cpp 1

    \c retrieveData() is reimplemented from QMimeData and is
    called when the data is requested by the drag and drop
    operation. Fortunately for us, this happens when the operation
    is finishing, i.e., when a drop target has been found.

    We emit the \c dataRequested() signal, which is picked up by
    \c SourceWidget. The \c SourceWidget (as already explained)
    sets the data on \c MimeData with \l{QMimeData::}{setData()}.

*/