編譯錯誤:
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