NDK With Android Studio
NDK With Android Studio
Unless you are using a game engine with an integrated scripting language, game development is usually done with C++. On the other hand, most Android applications are developed with Java.
This post will explain how to integrate C++ code into Android Studio, usegradleto build it and clear out some misconceptions.
If you used Eclipse you probably know there was a relatively easy way to add “native library” support to your project but now that most projects are being moved to the newer Android Studio it seems like there is no more C++ support. That is incorrect.
There are two ways to add C++ code code into your project. The first is by including prebuilt libraries which you have compiled elsehwere or were pre-compiled for you. The other is to compile them directly from your Android Studio project.
Including pre-built C++ libraries
Including pre-built libraries is simple. Android Studio will look for a specific directory tree and copy all libraries it finds.
The folder structure should be in your Android Studio module’s folder and look like this
- [module_name]
- [src]
- [main]
- [jniLibs]
- [armeabi]
- [armeabi-v7a]
- [x86]
- [mips]
Make sure the folder tree is located inside your module, not inside your project root. For example[project_root]/app/…
The names of the end folders are the same as the ABI the library was compiled for. Make sure to add new ones when you compile forarm64-v8a,x86-64andmips64.
This is how it looks like from Android Studio:
Now you can load your shared libraries (.so) from Android using
12 | |
Note that compiling a shared library with the ndk generatres a lib + yourModuleName + .so. When loading your library you should only call your module’s name, without the prefix and suffix.
Changing the jniLibs folder
If for some reason you want your C++ libraries path to be somewhere else, you can change it by settingsourceSets.main.jniLibs.srcDirsin your module’sbuild.gradle:
12345678 | |
Compiling C++ in Android Studio
Adding precompiled libraries is easy but tabbing between terminal and Android Studio can be annoying. If you are developing your C++ code with Android Studio and want it to be compiled when you build your .apk this is how you can do it.
There are 3 things you need to do:
- Addndk.dirvariable inside thelocal.propertiesfile.
- Configurendkmodule with gradle.
- Add C++ files to the expected folder.
- (Optional)Set product flavors.
Adding ndk.dir variable
The first thing to do is to configure the path to your ndk folder. Inside your proejct’s root folder there should be a file calledlocal.properties. Add andk.dirvariable directing to your ndk folder. For example:
12 | |
That was easy!
Configuring ndk with gradle
Ok, now to tell gradle to compile our C++ code.
Inside your module’sbuild.gradlefile locate your android’sdefaultConfigsection and add the following:
123 | |
Make sure to replace the string with your module’s name!
Here is mine for reference:
12345678910111213141516171819 | |
Note that you can also add additional C++ configuration such ascFlags,stlandldLibs.
123456 | |
Adding C++ source files
Now that Android Studio and Gradle are configured to compile C++ source code it is time to feed them some files!
Naturally, Gradle expects the C++ files to be inside[module]/src/main/jni/. Simply adding your files there will do the trick:
The next time you try to run the application, gradle will build the C++ module for you. It will even shout at you for C++ errors in the gradle console, for example I added thisbad_function:
12345 | |
And gradle responded with:
Changing the folder of your source files
Just like with thejniLibsfolder, you can tell gradle to look for your C++ files in a different path. I for example prefer my source code insidesource. I can set it by editing thesourceSets.main.jni.srcDirsvariable:
12345678 | |
(Optional)Setting product flavors
You can set different compilation variables for different platforms. For example you might want to define a different macro for x86 and arm to use different optimizations or to include different header files.
You can do this by adding theproductFlavorssection underandroidin the module’sbuild.gradlefile.
The most obvious setting would be to avoid compiling the library for all platforms when building the .apk for a specific ABI. For that you can use theabiFiltervariable:
1234567891011121314151617181920212223 | |
The next time you build your project for a specific ABI target the ndk will know which build type it should create and not to use the default abi settings which is to compile for all platforms.
You can also override the defaultcFlagsand other settings here, just add them inside thendksection under the build of your choice.
Summary
I oriented this guide toward people who are looking to convert their project from Eclipse to Android Studio and omitted explanation on how to use JNI and call C++ functions from Java/Android. If there is demand for a JNI tutorial I will write a post for it.
Hope this post was helpful for you! Keep making awesome games for Android :)
更多相关文章
- Android在Button按钮上同时显示文字和图片
- Android如何使用XML创建一个环形渐变颜色图片
- Android 旋转图片
- Android 获取网络图片
- Android 图片加载缓存
- Android 系统图片
- 图片压缩
- Android三种方法设置ImageView的图片
- Android 如何加载大图片