编译错误:
1. Error:Cause: failed to find target android-10 : /home/wigooe/project/winxp_soft/androidStudio/android-studio/sdk
<a href="install.android.platform">Install missing platform(s) and sync project</a>
解决办法:
- 打开SDK Manager,可以看到安装的build-tool版本是20,SDK platform版本是 20
- 打开build-gradle,修改其中的
apply plugin: 'com.android.application'
android {
compileSdkVersion 20 //10
buildToolsVersion "20.0.0"
defaultConfig {
applicationId "android_serialport_api.sample"
minSdkVersion 15 //3
targetSdkVersion 20 // 3
ndk {
moduleName "serial_port"
ldLibs "log", "z", "m" //链接时使用到的库,对应LOCAL_LDLIBS
}
}
buildTypes {
release {
runProguard false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
}
}
http://blog.csdn.net/yuxiangyunei/article/details/38982815
在AS中打包.so文件很方便,直接在app/src/main目录下新建jniLibs文件夹,将.so文件copy进来,AS会自动打包进APK中。
不过在大多数情况下,APK运行时会提示找不到.so文件。问题出在,新建工程中的文件的路径名称与.so文件中是不符的。直接用写字板打开.so文件,可以看到文件中的函数接口路径。
以前的做法是在linux环境下,根据写好的函数接口名称生成头文件,然后再实现头文件里的函数声明,并且写一个编译时需要用到.mk文件。现在不用这么麻烦了,AS早就帮我们搞定了所有步骤。
首先新建一个工程,默认情况下在app/src/main/java/com.jnisample下生成一个MainActivity.java,为了更好的演示路径问题的重要性,这里把native函数接口放到另一个类中,例如app/src/main/java/com/jnisample/jnicall/jnicall.java,注意jnicall文件夹与MainActivity.java文件同级。
- package com.jnisample.jnicall;
- public class jnicall {
- // JNI
- private native static void open();
- public native void close();
- static {
- System.loadLibrary("myLib");
- }
- }
jnicall.java内容很简单,调用两个native函数、声明要使用的.so名称。
接下来,在app/src/main目录下新建jni文件夹,在jni文件夹下创建一个.c文件,这里命名为test。可以没有.h文件,不过由于NDK的bug,必须再新建一个空的.c文件,文件名任意,否则编译时会报NDK_PROJECT_PATH=NULL错误。
test.c
- #include <termios.h>
- #include <unistd.h>
- #include <sys/types.h>
- #include <sys/stat.h>
- #include <fcntl.h>
- #include <string.h>
- #include <jni.h>
- //#include "test.h" //可以不用.h文件
- #include "android/log.h"
- static const char *TAG="test";
- #define LOGI(fmt, args...) __android_log_print(ANDROID_LOG_INFO, TAG, fmt, ##args)
- #define LOGD(fmt, args...) __android_log_print(ANDROID_LOG_DEBUG, TAG, fmt, ##args)
- #define LOGE(fmt, args...) __android_log_print(ANDROID_LOG_ERROR, TAG, fmt, ##args)
- /*
- * Class: com_jnisample_jnicall_jnicall
- * Method: open
- * Signature: ()V
- */
- JNIEXPORT void JNICALL Java_com_jnisample_jnicall_jnicall_open
- ()
- {
- LOGD("open");
- }
- /*
- * Class: com_jnisample_jnicall_jnicall
- * Method: close
- * Signature: ()V
- */
- JNIEXPORT void JNICALL Java_com_jnisample_jnicall_jnicall_close
- ()
- {
- LOGD("close");
- }
这里把test.h文件内容也贴出来
test.h
- /* DO NOT EDIT THIS FILE - it is machine generated */
- #include <jni.h>
- /* Header for class com_jnisample_jnicall_jnicall */
- #ifndef _Included_com_jnisample_jnicall_jnicall
- #define _Included_com_jnisample_jnicall_jnicall
- #ifdef __cplusplus
- extern "C" {
- #endif
- /*
- * Class: com_jnisample_jnicall_jnicall
- * Method: open
- * Signature: ()V
- */
- JNIEXPORT void JNICALL Java_com_jnisample_jnicall_jnicall_open
- ();
- /*
- * Class: com_jnisample_jnicall_jnicall
- * Method: close
- * Signature: ()V
- */
- JNIEXPORT void JNICALL Java_com_jnisample_jnicall_jnicall_close
- ();
- #ifdef __cplusplus
- }
- #endif
- #endif
最后要指示AS把c文件编译成我们想要的.so文件 — myLib.so
打开app/下的build.gradle,添加如下代码
- android {
- ……
- defaultConfig {
- ……
- ndk{
- moduleName "myLib" //lib的名称,对应LOCAL_MODULE
- //stl "stlport_shared" //对应APP_STL
- ldLibs "log", "z", "m" //链接时使用到的库,对应LOCAL_LDLIBS
- //cFlags 编译gcc的flag,对应LOCAL_CFLAGS
- }
- }
- }
*注意ldLibs "log"一行,由于在test.c中#include "android/log.h",所以必须把log.h包含进来。
NDK的路径也要指明,打开工程根目录下的local.properties,里面只有一行
########sdk.dir=C\:\\Android\\android-studio\\sdk,换行添加ndk.dir=C\:\\Android\\android-ndk-r10。
本人系统是ubuntu系统,安装的也是linux 下64位的android studio,其路径如下
#Wed Aug 17 15:45:50 CST 2016
sdk.dir=/home/wigooe/project/winxp_soft/androidStudio/android-studio/sdk
ndk.dir=/home/wigooe/project/document/android-ndk-r10b
以上内容总结自:
http://zhiwei.li/text/2014/03/android-studio%E5%A6%82%E4%BD%95%E5%90%8Cndk%E9%9B%86%E6%88%90/http://ph0b.com/android-studio-gradle-and-ndk-integration/
http://www.flakor.cn/2014-02-07-198.html