Skip to content

Android NDK Setup

seanpaultaylor edited this page Oct 10, 2014 · 42 revisions

This page explains how to compile gameplay for Android devices on Windows 7.

Install the External Dependencies

Before you get started you will have to download the dependencies separately:

Install Tools

Install the Android SDK

  1. Download and install the Android SDK.
  2. Make sure <android-sdk-path>/tools and <android-sdk-path>/platform-tools are added to PATH.

Install the Android NDK

  1. Download and install the Android NDK.
  2. Make sure <android-ndk-path> is added to PATH.

Install Apache Ant

  1. Download and install Apache Ant.
  2. Make sure <ant-path>/bin is added the PATH.

Building Library and Samples

  1. Change directory to: <gameplay-root>
  2. Run the following command:
    ant

Customizing for a Target

android.bat list targets

This will print the available Android targets. Remember the id of the target you wish to target (such as Android 2.3.3). You will need the id in the next part. Gameplay requires at least version 2.3.3.

Available Android targets:
----------
id: 1 or "android-15"
     Name: Android 4.0.3
     API level: 15
     Revision: 1
----------
id: 3 or "android-20"
     Name: Android 4.4
     API level: 20
     Revision: 1
...

Building for an specific Android Target:

  1. Change directory to <gameplay-root>/gameplay/android

  2. Run the following command to generate the needed files to build the project:

    android.bat update project -t 1 -p . -s

    Where -t 1 is the id of the target you picked in the previous step. You can also use -t "android-10".

  3. Build the gameplay library:

    ndk-build

Building a sample game

  1. Change directory to <gameplay-root/samples/sample-XXXXX>/android

  2. Run this command to generate the needed files to build the project:

    android.bat update project -t 1 -p . -s

    Where -t 1 is the id of the target you picked in the previous step. You can also use -t "android-20".

  3. Build the gameplay sample:

    ndk-build

Packaging/Installing a sample game

Make sure developer mode is enabled and USB debugging is turned on.

  1. Change directory to <gameplay-root/samples/sample-XXXXX>/android
  2. Install the app: ant debug install

Troubleshooting

Device not detected

If ant debug install does not work, ensure your device is being detected properly by running adb devices. If no devices are reported, try downloading the correct USB drivers from you phone manufacturer's website. (OEM Drivers)

Android NDK permissions errors

If you see an error like ./obj/local/armeabi/libpng.a: No such file: Permission denied, make sure that the *.a files have read permission by running: chmod +r obj/local/armeabi/*.a

Debugging

Use logcat to capture the log file from the device.

adb logcat -d > logcat.txt

If your program crashed then the log file will contain the stack trace without symbols. Use ndk-stack to make the stack trace readable.

-sym points to the directory that contains the symbols while -dump points to the log file.

ndk-stack -sym C:\Git\gaming\GamePlay\samples\sample-mesh\android\obj\local\armeabi -dump d:\logcat.txt

How to build in ARM mode (instead of thumb mode)

Note: You will have to re-run android.bat update (....) to update the build settings. (More information)

Clone this wiki locally