aboutsummaryrefslogtreecommitdiffstats
path: root/doc/qtcreator/src/qtquick/qtquick-buttons.qdoc
blob: 54ad29ee8a7729847e5b3f7babe2d65c436e8e20 (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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
/****************************************************************************
**
** Copyright (C) 2020 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
**
** This file is part of the Qt Creator documentation.
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU Free Documentation License Usage
** 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. Please review the following information to ensure
** the GNU Free Documentation License version 1.3 requirements
** will be met: https://www.gnu.org/licenses/fdl-1.3.html.
**
****************************************************************************/

// **********************************************************************
// NOTE: the sections are not ordered by their logical order to avoid
// reshuffling the file each time the index order changes (i.e., often).
// Run the fixnavi.pl script to adjust the links to the index order.
// **********************************************************************

/*!
    \previouspage qtquick-form-editor.html
    \page quick-buttons.html
    \nextpage quick-scalable-image.html

    \title Creating Buttons

    To create a button type:

    \list 1

        \li Select \uicontrol File > \uicontrol {New File or Project} >
            \if defined(qtcreator)
            \uicontrol Qt > \uicontrol {QML File (Qt Quick 2)} >
            \else
            \uicontrol {Qt Quick Files} > \uicontrol {Qt Quick File} >
            \endif
            \uicontrol Choose to create a QML file called Button.qml (for
            example).

            \note Types are listed in the \uicontrol Library only if the
            filename begins with a capital letter.

        \li Click \uicontrol {Design} to edit the file in the
            \uicontrol {Form Editor}.

        \li In the \uicontrol Navigator, select \uicontrol Item and set the
            width (\uicontrol W) and height (\uicontrol H) of the button in the
            \uicontrol Properties view.

        \li Drag and drop a \uicontrol Rectangle from the \uicontrol Library to
            the item in the navigator. This creates a nested item where the
            item is the parent of the rectangle. Items are positioned relative
            to their parents.

        \li In the \uicontrol Properties view, modify the appearance of the
            rectangle:

        \list a

            \li In the \uicontrol Color field, select the button color.

            \li In the \uicontrol Radius field, use the slider to set the radius of
                the rectangle and produce rounded corners for the button.

            \li Select \uicontrol {Layout}, and then select the
                \inlineimage anchor-fill.png
                (\uicontrol {Fill to Parent}) button to anchor the rectangle to
                the item.


        \endlist

        \li Drag and drop a \uicontrol {Text} type to the item in the navigator.

        \li In the \uicontrol Properties view, edit the properties of the \uicontrol Text
            type.

        \list a

            \li In the \uicontrol Text field, type \b Button.

                You can select the text color in the \uicontrol {Text color} field and the
                font, size, and style in the
                \uicontrol Font section.

            \li In the \uicontrol Alignment field, select the center buttons to align
                the text to the center of the button.

            \li Select \uicontrol Layout > \uicontrol {Fill to Parent}
                to anchor the text to the whole button area.

        \endlist

        \li Press \key {Ctrl+S} to save the button.

            \image qmldesigner-button.png "Button component"

    \endlist

    To create a graphical button that scales beautifully without using vector
    graphics, use the \l [QML]{BorderImage}{Border Image} type. For more
    information, see \l{Creating Scalable Buttons and Borders}.

    */


/*!
    \previouspage quick-buttons.html
    \page quick-scalable-image.html
    \nextpage qtquick-navigator.html

    \title Creating Scalable Buttons and Borders

    You can use the \l [QML]{BorderImage}{Border Image} type to display an
    image, such as a PNG file, as a border and a background.

    Use two border images and suitable graphics to make it look like the
    button is pushed down when it is clicked. One of the border images
    is visible by default. You can specify that it is hidden and the other one
    becomes visible when the mouse is clicked.

    Add a \l [QML]{MouseArea}{Mouse Area} type that covers the whole area and
    emits the clicked signal (\c {item.clicked()}) when it detects a mouse
    click.

    You can add text to the button and set it up as a property. The text can
    then be initialized from the outside, making the button a reusable UI
    component. The font size is also available in case the default size is too
    big. You can scale down the button text and use smooth text rendering for
    some extra quality.

    \image qmldesigner-borderimage.png "Graphical button"

    To create a graphical button:

    \list 1

        \li Select \uicontrol File > \uicontrol {New File or Project} >
            \if defined(qtcreator)
            \uicontrol Qt > \uicontrol {QML File (Qt Quick 2)} >
            \else
            \uicontrol {Qt Quick Files} > \uicontrol {Qt Quick File} >
            \endif
            \uicontrol Choose to create a QML file called Button.qml (for
            example).

            \note Types are listed in the \uicontrol Library only if the
            filename begins with a capital letter.

        \li Click \uicontrol {Design} to edit the file in the
            \uicontrol {Form Editor}.

        \li In the \uicontrol Navigator, select \uicontrol Item and set the
            width (\uicontrol W) and height (\uicontrol H) of the button in the
            \uicontrol Properties view.

        \li Select \uicontrol Connections > \uicontrol {Properties} >
            \uicontrol Add to add properties for the item:

            \image qmldesigner-borderimage-properties.png "Properties"

            \list a

                \li Double-click in the columns in the view to specify a \c text
                     property with the type \c string and an empty value.

                \li Specify another property, \c fontSize, with the type \c int
                    and the value \c 10.

            \endlist

        \li Drag and drop two \uicontrol {Border Image} types from the
            \uicontrol Library to the item in the \uicontrol Navigator.

        \li Drag and drop a \uicontrol Text type to the item in the navigator.

        \li Drag and drop a \uicontrol {Mouse Area} to the item in the
            navigator.

        \li In the navigator, select a border image to specify settings for it
            in the \uicontrol Properties view:

        \list a

            \li Select \uicontrol Connections > \uicontrol {Bindings}
                > \uicontrol Add to hide the image when the mouse button is not
                pressed down. Specify the \c visible property with the
                \c !mouseArea source item and \c pressed source property.

                \image qmldesigner-borderimage-bindings.png "Border image bindings"

            \li In the \uicontrol Source field, select the image file for the button,
                for example button_up.png.

            \li  Click \uicontrol {Layout}, and then click the
                \inlineimage anchor-fill.png
                (\uicontrol {Fill to Parent}) button to anchor the border image to the
                \uicontrol Item.

        \endlist

        \li Select the other border image to specify similar settings for it:

        \list a

            \li In \uicontrol Bindings, specify the \c visible property
                with the \c mouseArea source item and \c pressed source
                property to show the image when the mouse button is pressed
                down.

            \li In the \uicontrol Source field, select the image file for the button
                when it is clicked, for example button_down.png.

            \li Select \uicontrol {Layout} > \uicontrol {Fill to Parent}
                button to anchor the border image to the \uicontrol Item.

        \endlist

        \li Select the text to specify font size and color, and text scaling
            and rendering:

        \list a

            \li In the \uicontrol Color field, use the color picker to select
                the font color, or enter a value in the field.

            \li In \uicontrol Bindings, create bindings to properties:

                \image qmldesigner-borderimage-bindings-text.png "Text bindings"

                \list

                    \li Set the source property of the \c text property as
                        \c text and the source item as \c parent.

                    \li Set the source property of the \c font.pixelSize as
                        \c fontSize and the source item as \c parent.

                    \li Set the source property of \c scale as
                        \c {if (!mouseArea} and the source item as
                        \c {pressed) { 1 } else { 0.95 }}.

                \endlist

            \li Click \uicontrol {Layout}, and then click the
                \inlineimage anchor-vertical-center.png
                (\uicontrol {Vertical Center}) and
                \inlineimage anchor-horizontal-center.png
                (\uicontrol {Horizontal Center}) buttons to inherit the
                vertical and horizontal centering from the parent.

        \endlist

        \li Select \uicontrol mouseArea in the navigator and then select
            \uicontrol Connections > \uicontrol Add to set \c item.clicked()
            as the value of the \c onClicked signal handler.

           \image qmldesigner-borderimage-connections.png "Item connections"

        \li In the \uicontrol {Text Editor}, specify the \c clicked signal for
            the Item:

            \qml
            Item {
                id: item
                property string text: ""
                property int fontSize: 10

                signal clicked
            }
            \endqml

    \endlist

    \note To test the button, add it to a Qt Quick Application or Qt
    Quick UI project and run the application.

*/