Android Studio使用新的Gradle构建工具配置NDK环境

从Android Studio 1.3 Beta1开始,就支持了NDK。不过使用的是一个全新的实验性的gradle构建工具。官方地址http://tools.android.com/tech-docs/new-build-system/gradle-experimental,英文好的可以直接看原文。

在进行配置前请先将Android Studio更新至最新版本,目前最新版本是1.4 Bata4

这里写图片描述

并且使用Android Studio内置的SDK管理器下载NDK。

这里写图片描述

或者在项目上右键打开Project Structure,切到的SDK Location页进行安装

这里写图片描述

注意这个NDK安装好后其目录在SDK目录下的ndk-bundle目录下,与以往的不同。

要修改的文件见下图

这里写图片描述

首先需要将根目录下的gradle修改为实验性的gradle

classpath 'com.android.tools.build:gradle-experimental:0.2.0'

最终是这样的

这里写图片描述

并且需要gradle 2.5的支持,将gradle/gradle-wrapper.properties中的版本修改为2.5

distributionUrl=https\://services.gradle.org/distributions/gradle-2.5-all.zip

最终是这样的

这里写图片描述

然后修改原来的app/build.gradle,注意现在各项配置都是有等号的,并且使用的是com.android.model.application而不再是原来的com.android.application,如果是Library,则是com.android.model.library。然后android外围包了一层model。原来在android里面的buildTypes 移到了外面。等等,看下面内容,注意变化。

apply plugin: 'com.android.model.application'


model{
    android {
        compileSdkVersion = 22
        buildToolsVersion = "23.0.1"

        defaultConfig.with {
            applicationId = "com.kltz88.car.jnidemo"
            minSdkVersion.apiLevel = 14
            targetSdkVersion.apiLevel = 22
            versionCode = 1
            versionName = "1.0"
        }
        tasks.withType(JavaCompile) {
            //指定编译JDK版本
            sourceCompatibility = JavaVersion.VERSION_1_7
            targetCompatibility = JavaVersion.VERSION_1_7
        }
    }
    android.ndk {
        moduleName = "test"
        ldLibs +="log"
        abiFilters +="armeabi"
        abiFilters +="armeabi-v7a"
        abiFilters +="x86"
    }
    android.buildTypes {
        release {
            minifyEnabled = false
            proguardFiles += file( 'proguard-rules.pro')
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    compile 'com.android.support:appcompat-v7:22.2.1'
}

在android.ndk中进行ndk的配置,模块名字是必须的。然后使用了log,并且支持armeabi,armeabi-v7a,x86三个平台。

然后增加jni目录,在main上右键新建jni目录

这里写图片描述

在弹出的窗口中你可以修改jni目录,默认是在main/jni中

这里写图片描述

新建一个Test的类,加载jni库,声明native方法

public class Test {
    static {
        System.loadLibrary("test");
    }
    public native void test();
}

这时候你会发现test方法是红色的

这里写图片描述

在上面按alt+enter生成c层的方法

这里写图片描述

修改为下方的代码

#include <jni.h>
#include "android/log.h"
JNIEXPORT void JNICALL
Java_com_kltz88_car_jnidemo_Test_test(JNIEnv *env, jobject instance) {
    __android_log_write(ANDROID_LOG_ERROR,"TAG","TEST");

}

如果你需要生成头文件,使用命令行即可

这里写图片描述

之后会在jni目录生成对应的头文件

这里写图片描述

然后在java层调用

public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Test t=new Test();
        t.test();
    }
}

便会看到日志的输出。

这里写图片描述

注意如果没有在gradle中指定java的对应版本,运行时可能会报错

tasks.withType(JavaCompile) {
            //指定编译JDK版本
            sourceCompatibility = JavaVersion.VERSION_1_7
            targetCompatibility = JavaVersion.VERSION_1_7
        }

错误信息如下,遇到该错误加上上面的代码即可

这里写图片描述

最后就是调试的问题了,理论上来说应该是支持调试的,但是我在windows上并没有试验成功。下面贴出步骤。

这里写图片描述

增加native运行方法

这里写图片描述

修改为

这里写图片描述

然后下断点,理论上是能调试的,但是我遇到了下面的问题,导致无法继续,也查过了,查不出问题所在,就这样吧,改天在linux下试试是不是正常。

这里写图片描述

你会发现整个流程下来,原来的Android.mk和Application.mk都不再需要了,所有配置在gradle中配置即可。

官方的github示例代码
https://github.com/googlesamples/android-ndk

我的示例代码
http://download.csdn.net/detail/sbsujjbcy/9108775

  • 7
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Android Studio使用 Gradle 构建工具进行编译和打包,生成 .so 动态链接库,可以按照以下步骤进行: 1. 在 Android Studio 中创建一个 C/C++ 模块,选择 File -> New -> New Module -> C/C++ Library,然后按照向导设置模块名称、语言类型和支持的 ABI。 2. 在模块的 build.gradle 文件中,添加以下配置: ```groovy android { // 指定支持的 ABI,包括 armeabi-v7a、arm64-v8a、x86、x86_64 等 ndk { abiFilters 'armeabi-v7a', 'arm64-v8a', 'x86', 'x86_64' } // 配置 CMakeLists.txt 文件路径 externalNativeBuild { cmake { path "CMakeLists.txt" } } } // 配置 CMake 版本 cmake { version "3.10.2" } ``` 3. 在模块的 src/main 目录下创建 jni 文件夹,并将 C/C++ 代码放入该文件夹中。 4. 在 jni 文件夹下创建 CMakeLists.txt 文件,并编写编译选项和链接选项,指定生成 .so 文件的名称和路径,以及引入其他依赖库等。例如: ```cmake # 设置编译选项 set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11") # 设置源文件路径 file(GLOB_RECURSE SOURCE_FILES "*.cpp") # 设置头文件路径 include_directories(${CMAKE_CURRENT_SOURCE_DIR}/include) # 配置动态库输出路径和名称 set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${PROJECT_SOURCE_DIR}/src/main/jniLibs/${ANDROID_ABI}) set(CMAKE_LIBRARY_OUTPUT_DIRECTORY_DEBUG ${PROJECT_SOURCE_DIR}/src/main/jniLibs/${ANDROID_ABI}) set(CMAKE_LIBRARY_OUTPUT_DIRECTORY_RELEASE ${PROJECT_SOURCE_DIR}/src/main/jniLibs/${ANDROID_ABI}) set(CMAKE_LIBRARY_OUTPUT_NAME "native-lib") # 引入其他依赖库 find_library(log-lib log) # 生成动态库 add_library(native-lib SHARED ${SOURCE_FILES}) target_link_libraries(native-lib ${log-lib}) ``` 5. 点击 Android Studio 工具栏中的 Build -> Make Project,进行编译和打包,生成 .so 动态链接库。 6. 在模块的 build.gradle 文件中查看生成的 .so 文件路径,例如: ```groovy android { externalNativeBuild { cmake { path "CMakeLists.txt" } } sourceSets { main { jniLibs.srcDirs = ['src/main/jniLibs'] } } } ``` 以上就是在 Android Studio使用 Gradle 构建工具进行编译和打包,生成 .so 动态链接库的步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值