First check out the source code. The following commands will fetch the latest code and also make sure that submodules are properly initialized.
# For this document we will assume you are inside a folder for development.
# We will refer to that as `dev`.
#
# I usually have a folder called `dev` in my user folder and inside a subfolder
# for each software project, here that would be `/home/user/dev/qfield`.
# You are free to choose yours.
git clone [email protected]:opengisch/QField.git
git submodule update --init --recursive
# Alternatively you can ues the following URL in case you have not set up SSH keys for github
# https://github.com/opengisch/QField.git
You need to have cmake installed.
You have two options to build QField. Using system packages which will reuse packages installed from your package manager. Or using vcpkg which will build all the packages from source.
This will use your system packages.
Make sure you have installed the appropriate -dev
or -devel
packages
using your system package manager.
This is much faster to build than the using vcpkg and often the preferred
development method.
cmake -S QField -B build
This will build the complete dependency chain from scratch. Except Qt which is still taken from the system. You can also try to build Qt, it's known to be hard work.
cmake -S QField -B build -DSYSTEM_QT=ON
Since this is now building a lot, grab yourself a cold or hot drink and take a good break. It could well take several hours.
Now build the application.
cmake --build build
You need to have cmake and Xcode installed.
The following line will configure the build.
# We call this from the `dev` folder again
cmake -S QField -B build -GXcode -Tbuildsystem=1 -DWITH_VCPKG=ON
Please note that this will download and build the complete dependency chain of QField. If you ever wanted to read a good book, you will have a couple of hours to get started.
cmake --build build
You need to have the following tools available to build
- cmake
- Visual Studio
QField on Windows will always be built using vcpkg.
cmake -S QField -B build \
-D VCPKG_TARGET_TRIPLET=x64-windows-static \
-D CMAKE_MSVC_RUNTIME_LIBRARY=MultiThreaded\$<\$<CONFIG:Debug>:Debug> \
-D PKG_CONFIG_EXECUTABLE=build/vcpkg_installed/x64-windows/tools/pkgconf/pkgconf.exe
cmake --build build
Android runs on a number of different CPU architectures.
The most common one is arm64
. The platform to build for is specified via triplet.
The following triplets are
arm64-android
arm-android
x64-android
x86-android
There is a simple script that helps building everything by using a docker image.
triplet=arm-android ./scripts/build.sh
Make sure you have the following tools installed
- cmake
- The Android SDK including NDK
- Qt for Android
- This list is incomplete, please let us know what is missing
To install Qt, aqtinstall
is a nifty little helper
pip3 install aqtinstall
aqt install-qt linux android 5.14.2 -m qtcharts
export ANDROID_NDK_HOME=[path to your android ndk]
cmake -S QField \
-B build \
-D VCPKG_TARGET_TRIPLET=arm64-android
cmake --build build