Есть несколько шагов, необходимых для подключения NDK к Android Studio. В настоящее время поддержка отмечена как экспериментальной и AS начинает связывать возможность загрузки NDK в среде IDE. По умолчанию AS использует общие Android.mk
и Application.mk
, когда источник и/или библиотеки размещаются в папке jni
или jniLibs
. Приведенные ниже инструкции переопределяют эти значения по умолчанию, чтобы обеспечить дополнительную возможность настройки.
Короче говоря, вам нужно:
- Создать параметр по умолчанию
jni
и jniLibs
каталоги для источника и LIBS.
- Расскажите Android Studio, где найти ваше NDK строить цепь
- Расскажите Gradle, как собрать и где разместить ваш ЛИЭС
- Создать
Android.mk
файл указать здание и привязку заказ
- Создать какой-то источник
Создание каталогов
Внутри /app/src/main
создать jni
и jniLibs
.
Update local.properties
Внутри файла local.properties
, добавьте строку, подобную:
ndk.dir=/home/nathan/development/bin/android-ndk-r10e
Update build.gradle
Это относится к уровню модуля , а не уровень приложения. Это гарантирует, что мы определили путь сборки на шаге выше и удалим возможность Android Studio автоматически вызывать ndk-build. Используйте следующий пример в качестве руководства.
apply plugin: 'com.android.model.application'
model {
android {
compileSdkVersion = 23
buildToolsVersion = "23.0.0"
defaultConfig.with {
applicationId = "com.example.hellojni"
minSdkVersion.apiLevel = 4
targetSdkVersion.apiLevel = 23
}
}
compileOptions.with {
sourceCompatibility=JavaVersion.VERSION_1_7
targetCompatibility=JavaVersion.VERSION_1_7
}
/*
* native build settings
*/
android.ndk {
moduleName = "hello-jni"
/*
* Other ndk flags configurable here are
* cppFlags += "-fno-rtti"
* cppFlags += "-fno-exceptions"
* ldLibs = ["android", "log"]
* stl = "system"
*/
}
android.buildTypes {
release {
minifyEnabled = false
proguardFiles += file('proguard-rules.txt')
}
}
android.productFlavors {
// for detailed abiFilter descriptions, refer to "Supported ABIs" @
// https://developer.android.com/ndk/guides/abis.html#sa
create("arm") {
ndk.abiFilters += "armeabi"
}
create("arm7") {
ndk.abiFilters += "armeabi-v7a"
}
create("arm8") {
ndk.abiFilters += "arm64-v8a"
}
create("x86") {
ndk.abiFilters += "x86"
}
create("x86-64") {
ndk.abiFilters += "x86_64"
}
create("mips") {
ndk.abiFilters += "mips"
}
create("mips-64") {
ndk.abiFilters += "mips64"
}
// To include all cpu architectures, leaves abiFilters empty
create("all")
}
}
Android.mk
Вам потребуется Android.mk
файл в директории /app/src/main/jni
LOCAL_PATH := $(call my-dir)
# Builds a dylib out of test.cpp
include $(CLEAR_VARS)
LOCAL_MODULE := test
LOCAL_SRC_FILES := test.cpp
LOCAL_LDLIBS := -llog
include $(BUILD_SHARED_LIBRARY)
test.cpp
Добавьте удивительный C/C++ исходный код для вашей библиотеки. Эти файлы будут стартовать в /app/src/main/jni
и будут скомпилированы и скомпонованы, как указаны в вашем Android.mk
Примере файл
#include <jni.h>
#include <android/log.h>
static const char *SOME_TAG = "MyAwesomeTag";
extern "C"
{
void
Java_com_something_something_1android_ClassName_some_fn(JNIEnv *env, jobject obj)
{
__android_log_print(ANDROID_LOG_VERBOSE, SOME_TAG, "Hello from NDK :)");
}
} // End extern
компилировать и запускать.
Вы могли сгенерировать файл .so с помощью студии 2.1? – Hunt