2024-04-30 16:40:02 +12:00
# Instructions for building the Android package from source
2023-05-21 00:42:00 +12:00
## In a Container
2024-04-30 16:40:02 +12:00
The easiest way to build a .apk package for Android is to use
our own docker image that has all of the build components
pre-assembled.
2023-05-21 00:42:00 +12:00
2024-04-30 16:40:02 +12:00
All it takes is this:
2023-05-21 00:42:00 +12:00
2024-04-30 16:40:02 +12:00
```.sh
export GIT_AUTHOR_NAME=< your name >
export GIT_AUTHOR_EMAIL=< email to be used with github >
2023-05-21 00:42:00 +12:00
2024-04-30 16:40:02 +12:00
cd /some/path
git clone https://github.com/subsurface/subsurface
cd subsurface
git submodule init
git submodule update
./packaging/android/docker-build.sh
2023-05-21 00:42:00 +12:00
```
_Caveat:_ With this build script `libdivecomputer` is pulled from git in the version specified in the submodule, so if you have changed `libdivecomputer` make sure to commit any changes and update the git submodule version before building.
2024-04-30 16:40:02 +12:00
This will result in Subsurface-mobile-VERSION.apk to be created in /some/path/subsurface/output/android/.
2023-05-21 00:42:00 +12:00
## On a Linux host
alternatively you can build locally without the help of our container.
Setup your build environment on a Ubuntu 20.04 Linux box
I think these packages should be enough:
```.sh
sudo apt-get update
sudo apt-get install -y \
autoconf \
automake \
cmake \
git \
libtool-bin \
make \
wget \
unzip \
python \
python3-pip \
bzip2 \
pkg-config \
libx11-xcb1 \
libgl1-mesa-glx \
libglib2.0-0 \
openjdk-8-jdk \
curl \
coreutils \
p7zip-full
sudo mkdir /android
sudo chown `id -un` /android
cd /android
wget https://dl.google.com/android/repository/commandlinetools-linux-6858069_latest.zip
unzip commandlinetools-linux-*.zip
git clone https://github.com/subsurface/subsurface
# now get the SDK, NDK, Qt, everything that's needed
2024-01-08 07:51:43 +13:00
bash /android/subsurface/scripts/docker/android-build-container/android-build-setup.sh
2023-05-21 00:42:00 +12:00
```
Once this has completed, you should have a working build environment.
```.sh
bash -x subsurface/packaging/android/qmake-build.sh
```
should build a working .aab as well as a .apk that can be installed on
your attached device:
```.sh
./platform-tools/adb install ./subsurface-mobile-build/android-build/build/outputs/apk/debug/android-build-debug.apk
```
Note that since you don't have the same signing key that I have,
2024-04-30 16:40:02 +12:00
you'll have to uninstall the 'official' Subsurface-mobile binary in
2023-05-21 00:42:00 +12:00
order for this to work. And likewise you have to uninstall yours
before you'll be able to install an official binary again.