Most Qt applications should be portable to Android with ease unless they depend on a specific hardware or software feature not supported by Android.
The porting approach differs depending on whether the existing application is QML or Widget based, your intended build tool, and if you are porting from a mobile or desktop application.
QML-based applications built with CMake are considered the best approach for mobile applications.
Most of your existing Qt code should work, but you must make some decisions around your UI scalability and layout for different orientations and screen sizes. Consider a responsive layouts approach to fully take advantage of Qt Qml Applications.
There are considerations that are not directly impacted by using Qt, such as app store guidelines, theme guidelines, and others that may impact the way you develop your application. These won't be discussed here.
Most applications need resources. Here, we discuss how that impacts porting your application to Android.
Like most UI applications, Qt applications also depend on resources such as images, icons, translation files, and so on. These resources must be made available on the device as they are required for the application to function correctly.
The most convenient option is to bundle the resources into a qrc file, which gets built into the application binary. This approach reduces the porting effort considerably and provides faster access to the resources. It is also a cross-platform approach, which makes porting to other platforms easier.
By default, all Qt applications can access the contents of a qrc file using the ":/" prefix or the URL scheme prefix, "qrc:". To know more about qrc files and how they are handled, see the Qt Resource System .
The asset approach is the best option for better interoperability with the Android APIs. You can access all resources in the directory using the "assets:" prefix. Unlike qrc, this approach is Android-specific, not a cross-platform solution.
If you are new to using CMake or CMake with Qt for the first time, see 构建采用 CMake . Here, the focus is on the steps applicable for adding resources.
You will likely want to modify a few things that are controlled by the Android Manifest file. See Qt Android Manifest File Configuration for more information on that. So you likely have already set QT_ANDROID_PACKAGE_SOURCE_DIR like so:
set_property(TARGET target_name PROPERTY QT_ANDROID_PACKAGE_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/android")
Once that is done, you can access your assets in your application as detailed in Assets File System .
To use the "assets:" approach, for example, add the following lines into the
.pro
文件:
android { assets.files = images/happy.png assets.path = /assets/images/ INSTALLS += assets }
Then, you can access that image asset from C++ as follows:
QImage image("assets:/images/happy.png");
The following step-by-step instructions guide you to port an existing Qt Quick application to Android using the qrc approach:
main.qml
file from
resources.qrc
, you can use the following C++ code:
QQuickView viewer; viewer . setSource( QUrl ( "qrc:/qml/main.qml" )); viewer . show();
注意:
QML documents can refer to the contents in qrc files using the relative path to the document. Such references do not require the "
qrc:
" or "
:/
" prefix.
注意: Qt Quick Controls will use the 材质风格 if the target device is running Android 3.0 (API 11) or later. The application should function normally on devices with Android versions earlier than v3.0 but without a native style for controls.