Building applications for Android
Learn how to build your applications for Android
Building .apk files from Qt Applications requires a cross-compiling toolchain, which is hard to setup. To simplify this, there is a ready-to-use Docker container for building KDE applications.
This only applies to applications that have a Craft blueprint in the craft-blueprints-kde repository. If the application you want does not have such a blueprint yet, have a look at the documentation.
Setting up the image
First create a mountable folder used for the image:
If you want to build Qt6 applications, download the qt67
image:
If the application is using Qt5, use the qt515
image:
Note If this fails with an error similar to "Permission denied", you may need to disable SELinux while using craft by running `sudo setenforce 0`
After the image is done downloading, you should be in a new shell which is running inside of the container. Now it's time to initialize Craft:
It will ask several questions such as which Qt version to use, and the target architecture. Once that's complete, enter the Craft environment:
Your shell prompt should now look something like this:
Building applications
To build an application and it's dependencies, simply run the craft command with the application as the sole argument. For example, to build KDE Itinerary:
You can search for blueprints using the --search
command:
When compilation is finished, the APK packaging step is not run automatically. Invoke it manually using --package
:
Signing APKs
The .apk
file can be found at /home/user/CraftRoot/tmp
. This folder is also available as craft-kde-android/tmp
on the host system. Craft does not sign the apks, so you need to do that yourself before being able to install it onto a device. For signing an apk, you need to create a signing key first, which can be done using
This key can be reused to sign all of your development apks.
Before signing the apk, it might be needed to align it. This can be done using
You can finally sign the aligned apk with your key using
The zipalign
and apksigner
binaries can be found at /opt/android-sdk/build-tools/<version>/
inside the Craft container environment.
Iterating on blueprints
Inside the Craft environment, the blueprints can be found by running cs craft-blueprints-kde
and can be edited there to quickly test changes.
The source folder for an application or library can be found the same way by running cs <projectname>
; the build folder can be found by running cb <projectname>
.
You can quickly iterate on patches for a project by editing it in the source folder, followed by calling ninja install
in the build folder and creating an apk file using craft --package <appname>
.
There are much more Craft commands, take a look at the Craft documentation to learn about them.
Last updated