aboutsummaryrefslogtreecommitdiffstats
path: root/doc/qtcreator/src/android/androiddev.qdoc
blob: e2095df83c368561947154fcb36eb625f893cda2 (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
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
/****************************************************************************
**
** Copyright (C) 2019 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.
**
****************************************************************************/

    /*!

    \contentspage index.html
    \page creator-developing-android.html
    \previouspage creator-connecting-mobile.html
    \if defined(qtdesignstudio)
    \nextpage creator-developing-generic-linux.html
    \else
    \nextpage creator-developing-baremetal.html
    \endif

    \title Connecting Android Devices

    You can connect Android devices to the development PC to build, run, debug,
    and analyze applications from \QC. Devices with Android
    version 4.1 (API level 16) or later are supported.

    If you have a tool chain for building applications for Android devices
    installed on the development PC, you can add it to \QC. You can then add a
    \l{glossary-buildandrun-kit}{kit}
    with the tool chain, and the Qt version for Android for the device's architecture,
    to build applications for and run them on Android devices. Starting from Qt 5.14.0,
    Qt for Android package contains all the architectures (ABIs) installed as one.
    You can also allow \QC to automatically create kits for installed Qt version
    and tool chains.

    The Android Debug Bridge (adb) command line tool is integrated to \QC to
    enable you to deploy applications to connected Android devices, to run
    them, and to read their logs. It includes a client and server that run on
    the development host and a daemon that runs on the emulator or device.

    \section1 Requirements

    To use \QC to develop Qt applications for Android, you need the following:

    \list
        \li \l{https://www.oracle.com/java/technologies/javase-jdk8-downloads.html}
            {Java SE Development Kit (JDK)} version 6 up to 8.
            You can also use \l{http://openjdk.java.net/}{OpenJDK} on Linux.

            \note Android SDK Tools have issues with JDK versions later than 8.

        \li \l{http://www.gradle.org}{Gradle} for building application packages
            (APK) and app bundles (AAB) for Android devices. Gradle is delivered
            with Qt 5.9, and later, because Gradle scripts are not delivered
            with  Android SDK tools since version 26.0.0.

            \note Using Ant to build APKs is no longer supported.

        \li \l{http://developer.android.com/sdk/index.html}{Android SDK Tools}

            The following Android SDK packages and tools are required for
            development:

            \list
                \li Platform tools
                \li Build tools
                \li At least one SDK platform
                \li The \l{http://developer.android.com/tools/sdk/ndk/index.html}
                    {Android NDK} from Google that provides the tool chain for
                    building applications for Android devices. For a detailed
                    list of Qt versions and their recommended NDK versions,
                    see \l{https://doc-snapshots.qt.io/qt5-5.14/android-getting-started.html}
                    {The Android NDK}.
            \endlist

            \li On Windows, you also need the Android Debug Bridge (ADB) driver
                on the Windows platform to enable USB debugging. The default USB
                driver on Windows does not allow debugging. For more information
                about installing ADB, see \l {ADB windows driver}
                {ADB driver installation}.
    \endlist

    \section1 Setting Up the Development Environment

    To build Android applications with Qt, install Qt for Android 5.2, or later.

    \note You can build a 64-bit version of Qt for Android yourself. However,
    for such a Qt version, the minimum required Android version on devices
    is 5.0 (API level 21).

    For more information, see \l{Qt for Android}.

    Download and install the latest Android SDK, and then install
    or update the NDKs, tools and packages needed for development.

    Starting from \QC 4.12, \QC offers to automatically set up your Android
    environment and install all the necessary packages and Tools, then
    creating debuggers, tool chains, and kits. For more information,
    see \l {Specifying Android Device Settings}.

    Alternatively, use the Android SDK command line tools to install
    the required packages. In that case, it is recommended to create an
    empty folder and extract the downloaded archive into this folder.

    \note The recommended Android SDK Tools version is 25.3.0, or later. The version
    25.2.5, or earlier, can be used but it is not advised because it cannot be
    fully integrated with \QC.

    \list
        \li Android SDK Tools version 25.3.0, or later

            This allows using the
            \l{https://developer.android.com/studio/command-line/sdkmanager.html}
            {sdkmanager} command line tool for SDK package management and the
            \l{https://developer.android.com/studio/command-line/avdmanager.html}
            {avdmanager} tool for Android Virtual Device (AVD) management.

            The sdkmanager will install downloaded packages next to the \c tools
            folder that contains all command line tools. You must specify the path
            to the folder where you extracted the files as Android SDK location
            inside the Android settings.

            To install those packages, use the following command:

            \badcode
            ./sdkmanager "platform-tools" "platforms;android-29" "build-tools;29.0.2" "ndk-bundle"
            \endcode

            For Qt 5.12.0 to 5.12.5 and Qt 5.13.0 to 5.13.1, the following
            should be installed instead:

            \badcode
            ./sdkmanager "platform-tools" "platforms;android-29" "build-tools;28.0.2" "ndk;19.2.5345600"
            \endcode

            \target ADB windows driver
            Under Windows, Google's USB drivers can be installed by running:

            \badcode
            sdkmanager.bat "extras;google;usb_driver"
            \endcode

            For more information about altenative methods of obtaining the USB
            driver, see \l{http://developer.android.com/sdk/win-usb.html}.
            After the package installation is complete, install the driver from
            \c{<ANDROID_SDK_ROOT>/extras/google/usb_driver}. Try running a few basic
            \l{http://developer.android.com/tools/help/adb.html}{adb} commands now
            and check whether your Android device responds to them.

        \li Android SDK Tools version 25.2.5, or earlier

            If your Qt version is earlier than v5.9, use this SDK tools version.
            The SDK tool used to install and update the other SDK tools and packages
            depends on the Android SDK Tools version that you have installed:

            Use the
            \l{https://developer.android.com/studio/tools/help/android.html}
            {android} tool that comes with the SDK Tools package. For example,
            on  Ubuntu the following command starts the SDK update:

            \code
            ./android update sdk
            \endcode

    \endlist

    \section2 Specifying Android Device Settings

    To configure connections to Android devices and general Android settings:

    \list 1

        \li Select \uicontrol Tools > \uicontrol Options > \uicontrol Devices >
            \uicontrol Android.

            \image qtcreator-options-android-main.png "Android options"

        \li In the \uicontrol {JDK location} field, set the path to the JDK.

            By default, \QC tries to find any valid JDK/OpenJDK installation.
            However, if none is found, you must set it manually. Click the
            \inlineimage icons/download-icon.png
            (\uicontrol Download) button to open the JDK download web page in the
            default browser. \QC checks the JDK installation and reports errors.

        \li In the \uicontrol {Android Settings} group, set the path to the
            Android SDK Tools.

            Select \inlineimage reload_gray.png
            button to automatically download and extract the Android SDK Tools
            to the selected path. This will do the following:

            \list 1
                \li Download and extract the Android SDK Tools.
                \li Install or update the essential packages such as NDKs,
                    build tools, platform tools.
            \endlist

            The SDK Tools download URL, the essential packages list, and the
            appropriate NDK for each Qt version are defined in a JSON
            configuration file. The file is located under the user's \QC
            resource folder:

            \badcode
            # Linux and macOS
            ~/.config/QtProject/qtcreator/android/sdk_definitions.json

            # Windows
            C:\Users\Username\AppData\Local\QtProject\qtcreator\android\sdk_definitions.json
            \endcode

            For example, the SDK configuration file defines the NDK version 19.2.5345600
            to be used for Qt 5.12.0 to 5.12.5 and Qt 5.13.0 to 5.13.1 versions:

            \badcode
            "specific_qt_versions": [
                {
                    "versions": ["5.12.[0-5]", "5.13.[0-1]"],
                    "sdk_essential_packages": ["build-tools;28.0.2", "ndk;19.2.5345600"],
                    "ndk_path": "ndk/19.2.5345600"
                }
            ]
            \endcode

            The latest version of the configuration file that is up-to-date
            with the Android SDK and NDK changes is found
            \l{https://code.qt.io/cgit/qt-creator/qt-creator.git/plain/share/qtcreator/android/sdk_definitions.json}{here}.

            The installed NDK versions are listed below the SDK path.
            The items with a lock icon are versions installed from the SDK Manager,
            and can only be modified from the SDK Manager tab. For more information,
            see \l{Managing Android SDK Packages}. Custom NDK paths can be manually
            added to the global list of NDKs via the \uicontrol Add button.
            This creates custom tool chains and debuggers associated to
            that NDK, which can be used to create custom kits defined by the user.

            To manually download the SDK Tools, select \inlineimage icons/download-icon.png
            to open the SDK or NDK download web page in the default browser.

            The SDK Manager checks the Android NDK and SDK installations,
            reports errors, and offers to install the necessary packages.

            \image qtcreator-options-android-sdk-tools.png "Android NDK and SDK checks"

        \li In the \uicontrol {Android OpenSSL} group, set the path to the
            prebuilt OpenSSL libraries.

            For Qt applications that require OpenSSL support, \QC allows to
            quickly add the \l{https://marketplace.qt.io/products/android-openssl-support}
            {Android OpenSSL support} to your project. For more details, see
            \l{Adding External Libraries}.

            Select \inlineimage icons/download-icon.png
            to download the OpenSSL repository to the selected path. If the
            automatic download fails, the download web page opens for manual download.

        \li Select the \uicontrol {Automatically create kits for Android tool chains}
            check box to allow \QC to create the kits for you. \QC displays a
            warning if it cannot find a suitable Qt version.

        \li Select \uicontrol File > \uicontrol {New File or Project} >
            \uicontrol {Application (Qt Quick)} >
            \uicontrol {Qt Quick Application - Empty} > \uicontrol Choose, and
            follow the instructions of the wizard to create a project. For more
            information, see
            \if defined(qtcreator)
            \l{Creating Qt Quick Projects}.
            \else
            \l{Creating UI Prototype Projects}.
            \endif

        \li To specify settings for deploying applications to Android, select
            \uicontrol Projects > \uicontrol Run for the \uicontrol Android kit, and then select
            \uicontrol Details to view the \uicontrol {Deploy configurations}. For more
            information about the options you have, see
            \l{Deploying Applications to Android Devices}.

        \li Enable debugging on your Android device.

            Debugging is enabled in different ways on different Android devices.
            Look for \uicontrol {USB Debugging} under \uicontrol {Developer Options}. On
            some devices \uicontrol {Developer Options} is hidden and becomes visible
            only when you tap the \uicontrol {Build number} field in \uicontrol Settings >
            \uicontrol About several times. For more details, check
            \l{https://developer.android.com/studio/debug/dev-options}{Configure on-device developer options}.

        \li Connect the Android device to the development PC with a USB cable.
            You might be asked to select a device in the
            \l{Selecting Android Devices}{Select Android Devices} dialog.
    \endlist

    \section2 Managing Android SDK Packages

    Since Android SDK Tools version 25.3.0, only a command-line tool,
    \l{https://developer.android.com/studio/command-line/sdkmanager.html}
    {sdkmanager}, is provided by Android for SDK package management. To make SDK
    management easier, \QC provides an SDK Manager for installing, updating, and
    removing SDK packages. You can still use sdkmanager for advanced SDK
    management.

    After you set the path to the Anroid SDK in \uicontrol Tools >
    \uicontrol Options > \uicontrol Devices > \uicontrol Android, the
    SDK Manager checks that all the necessary SDK packages have been installed.
    If packages are missing or updates are needed, the SDK Manager offers to
    add or remove those packages. Before taking action, it prompts
    you to accept the changes it is about to make. In addition, it prompts you to
    accept Google licenses, as necessary.

    To view the installed Android SDK packages, select \uicontrol Tools >
    \uicontrol Options > \uicontrol Devices > \uicontrol Android >
    \uicontrol {SDK Manager}.

    \image qtcreator-android-sdk-manager.png "Android SDK Manager"

    To filter the packages, select \uicontrol Available, \uicontrol Installed,
    or \uicontrol All in \uicontrol {Show Packages}.

    To update the installed Android SDK packages, select
    \uicontrol {Update Installed}. Select the packages to update, and then
    select \uicontrol Apply.

    To specify advanced sdkmanager settings, select
    \uicontrol {Advanced Options} and enter arguments in the
    \uicontrol {SDK Manager arguments} field. The available arguments are listed
    and described in \uicontrol {Available arguments}.

    To manage packages installed from Android SDK Tools version 25.2.5, or
    earlier, you can use the native Android SDK Manager. The \QC SDK Manager and
    the native SDK Manager are mutually exclusive, because they are used for
    different Android SDK Tools versions. If you have the native SDK Manager
    installed, you can open it by selecting \uicontrol {Native SDK Manager}.

    \section1 Managing Android Virtual Devices (AVD)

    A list of AVDs is shown under \uicontrol Tools > \uicontrol Options >
    \uicontrol Devices > \uicontrol Android > \uicontrol {AVD Manager}. This
    works only with a valid \uicontrol {SDK Tools} path being set. The value in
    \uicontrol {System/data partition size} is used to set the emulator's system
    partition size upon execution with \uicontrol {Start}.

    \image qtcreator-android-avd-manager.png "Android NDK and SDK checks"

    \section1 Creating a New AVD

    To create new virtual devices, select \uicontrol Tools > \uicontrol Options >
    \uicontrol Devices > \uicontrol Android > \uicontrol {AVD Manager} > \uicontrol {Add}.

    In the \uicontrol {Create new AVD} dialog, you can create a new custom AVD
    by setting the name, device type, skin, architecture, API level, and SD card
    size. You need to have a valid \uicontrol {System Image} installed
    before using this dialog, either from \QC's \uicontrol {SDK Manager} tab or
    from Android Studio.

    For more advanced options for creating a new AVD, use the command-line tool
    \l{https://developer.android.com/studio/command-line/avdmanager.html}{avdmanager},
    or use Android Studio's native AVD Manager's UI.

    \image qtcreator-android-create-avd.png "Android NDK and SDK checks"

    \section1 Selecting Android Devices

    When you deploy an application to an Android device with Android
    version 4.2 (API 16) or later, the \uicontrol {Select Android Device} dialog
    opens. It lists the devices that are connected to the development PC, as
    well as AVDs, and their status. You can select devices or AVDs from the
    \uicontrol {Compatible Devices} list for deployment.

    If \QC determines that a device is not ready for deployment, it places the
    device in the \uicontrol {Incompatible Devices} list, with information about the
    issue. For example, you might need to authorize the connection on the
    device. After you authorize the connection on the device, select
    \uicontrol {Refresh Device List}. The device is moved to the
    \uicontrol {Compatible Devices} list and you can select it for deployment.

    Other reasons for showing a device in \uicontrol {Incompatible Devices} are
    that the Android version on the device is too old or that the tool chain
    used for building does not match the Android architecture on the device
    (for example, you cannot deploy an ARM build on an x86 device).

    \image qtcreator-android-select-devices.png "Select Android Devices dialog"

    To \l{Creating a New AVD}{create a new AVD}, select \uicontrol {Create Android Virtual Device}.

    To set a device as the default device for a particular Android architecture
    for the current project, select the \uicontrol {Always use this device for architecture}
    check box. The \uicontrol {Select Android Devices} dialog will not appear
    until you switch to another project or restart \QC.

    \section1 Using the Android Emulator

    To run your application on the Android Emulator, you must have an Android
    virtual device (AVD). For more information about creating a new one, see
    \l{Creating a New AVD}. If you run an application without a device connected to the
    development PC and without an AVD specified, \QC asks you to add an AVD.

    For Android SDK Tools 25.2.5, or earlier, select \uicontrol {Native AVD Manager}
    to manage AVDs.

    \note The Android Emulator has a bug that prevents it from starting on some
    systems. If the Android Emulator does not start, you can try starting it
    manually by running the following commands:

    \badcode
    cd <ANDROID_SDK>/emulator
    ./emulator -avd <AVD_NAME>
    \endcode

    For more information, see \l{https://developer.android.com/studio/run/emulator-commandline}
    {Start the emulator from the command line}.

    \section1 Debugging on Android Devices

    Select a \l{glossary-build-config}{debug build configuration} to build
    the application for debugging.

    \note \QC cannot debug applications on Android devices if Android Studio is
    running. If the following message is displayed in the \uicontrol Output
    pane, close Android Studio and try again:

    \badcode
    Ignoring second debugger -accepting and dropping.
    \endcode
*/