资讯专栏INFORMATION COLUMN

Andorid Studio NDK开发- NDK开发利器gradle-experimental

Half / 714人阅读

摘要:在项目主目录下的中更改配置增加的配置在中。源代码配置默认情况下,在下使用的是文件。也可以在中指定在分别指定了源代码和源代码的目录。以上的配置完成之后,就可以使用开始开发了。

使用NDK开发有件比较麻烦的事情就是编写Application.mkAndroid.mk的,而Android Studio 的插件gradle-experimental就是用来解决这个这个问题的。使用gradle-experimental插件可以不用再编写*.mk文件的情况下进行NDK开发。
gradle-experimental是Android Studio的一个实验性的项目,是基于gradle的一个插件,主要用来自动化NDK的配置实现,无需自己编写Application.mkAndroid.mk,对于调试NDK项目也更加的友好,支持对于NDK的Debug。
下面就来尝试下gradle-experimental的便利吧!

环境要求:

Android Studio > 2.0

gradle>2.10

Android NDK r10e

Build Tools > 19.0.0

配置gradle-experimental

添加gradle-experimental依赖
在项目的主目录下./build.gradle中替换掉以前的build tools,使用最新版本的gradle-experimental

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath "com.android.tools.build:gradle-experimental:0.7.0"
    }
}

替换插件(plugin)
使用gradle-experimental就不能再使用com.android.application了,需要使用com.android.model.application替代。

在项目主目录下的./app/build.gradle中更改plugin

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

配置model{}

增加model{},android的配置在model{}中。

   model {
          android {
        compileSdkVersion 23
        buildToolsVersion "25.0.0"
        ndk {
            moduleName "experiment"
            //stl = "gnustl_static"
            //toolchain = "clang"
            //todo 指定cpu
            abiFilters.addAll(["armeabi", "armeabi-v7a"]) //this is default
            ldLibs.addAll([ "log"]);
        }
        defaultConfig {
            applicationId "com.jjz"
            //需要使用.apiLevel
            minSdkVersion.apiLevel 15
            targetSdkVersion.apiLevel 23
            versionCode 1
            versionName "1.0"
        }
        buildTypes {
            release {
                minifyEnabled false
            }
        }
    }
}
配置NDK

在配置NDK之前需要确认:

NDK包是否下载

NDK的环境变量是否配置

能够正确运行命令:ndk-build

以上配置完成之后,在./app/build.gradle中配置要配置android.ndk的相关内容:

model {
    android {
        compileSdkVersion 23
        buildToolsVersion "23.0.2"
        ndk{
             moduleName "experiment"
            //toolchain = "clang"
            abiFilters.addAll(["armeabi", "armeabi-v7a"]) //this is default
            ldLibs.addAll([ "log"]);
        }

    }

}

这里定义的moduleName就是后面生成的NDK的包名。我们还可以指定其编译成对应的cpu,编译工具,使用的类库等。

源代码配置

默认情况下,在src/main/jni下使用的是c/c++文件。也可以在model.android中指定:

model {
    android {
        compileSdkVersion 23
        buildToolsVersion "23.0.2"
        ndk {
            moduleName "experiment"
        }
        sources {
             main {
                jni {
                    source {
                        srcDir "src/main/jni"
                    }
                }
                java{
                    source{
                        srcDir "src/main/java"
                    }
                }
            }
        }
    }
}

sources分别指定了java源代码和jni源代码的目录。
以上的配置完成之后,就可以使用gradle experimental开始NDK开发了。

使用gradle experimental

在java里面定义一个native方法,native标识的方法会需要在jni中实现,可以在java中调用,还需要加载NDK生成的.so类库。

public class NativeUtil {
    //加载类库
    static {
        System.loadLibrary("experiment");
    }
    public static native String firstNative();
}

这个时候编译器会出现一个红色的警告,因为定义的native方法编译器并没有找到对应的实现:

可以使用alt+enter键可以自动生成jni文件:

注意这个时候生成直接的是experiment.c,没有.h文件,生成的jni文件的内容:

**#include **
JNIEXPORT jstring JNICALL
Java_com_jjz_NativeUtil_firstNative(JNIEnv *env, jclass type) {
    // TODO
    return (*env)->NewStringUTF(env, returnValue);
}

自动生成的jni文件并没有具体的实现,需要修改jni文件让其返回一段测试内容:

>JNIEXPORT jstring JNICALL
Java_com_jjz_NativeUtil_firstNative(JNIEnv **env, jclass type) {
    char chars[] = "i am test";
    return (*env)->NewStringUTF(env, chars);
}

这样就完成了一个JNI开发调用,定义了一个native方法,在.c文件中对其进行了实现。如果没有gradle experimental插件的话,现在就需要使用ndk-build命令编译成.so文件,然后在运行Android项目,调用方法看下是否能够调用成功,而现在有了gradle experimental就变的了如此简单,下一步就需要直接运行就可以了,对!就是直接运行,省略了中间的ndk-build环节,就和编写Java代码一样,直接运行即可。

直接运行

打开Toolbar中的运行配置菜单,可以看到:

除了app以外,多出了一个app-native的菜单,这个选项可以直接编译NDK源码之后再运行Android,这样编写完NDK之后可以运行了,不需要再进行ndk-build:
在Java中调用NativeUtil.firstNative,会得到jni中写好的返回值:i am test,在这个例子中,我让这个这字段显示在主页面上。

可以看到使用gradle-experimental开发NDK,不需要再做复杂的配置,自动化native方法,不需要自定义.h头文件,对开发更加友好。

文中源代码地址:https://github.com/jjz/android/tree/master/experimental

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/12884.html

相关文章

  • Andorid Studio NDK开发-LLDB调试

    摘要:是一个高效的的调试器,是与编译器一起使用,提供了丰富的流程控制和数据检测有效的帮忙我们调试程序。常用命令打印命令,打印变量以及其值仅打印变量的值就是调用的意思,上述和也有调用的功能。一般只在不需要显示输出,或是方法无返回值时使用。 LLDB是一个高效的c/c++的调试器,是与LLVM编译器一起使用,提供了丰富的流程控制和数据检测,有效的帮忙我们调试程序。LLDB也已经取代GDB成为XC...

    cppprimer 评论0 收藏0
  • Andorid Studio NDK开发-使用库

    摘要:总而言之,会在开发的过程中会使用大量的库,系统自带的库,第三方库等。在中使用语言的库是非常便利的。这里引入的库为静态链接库,名称为指定库依赖动态链接库这里在中指定库的依赖为上面定义的类型为如果是动态链接库就是。 C语言是一个巨大的宝库,系统底层的很多的实现都是基于C语言实现的,比如图像处理,加密等。C语言的运行效率也是很高的,因此为了效率有时候也会引入第三方的C语言库。总而言之,会在N...

    Freeman 评论0 收藏0
  • Andorid Studio NDK开发-使用NDK

    摘要:首先定义一个方法,该方法的目的是从中读取随机数对应的方法引入的使用的方法是的方法,能够读取随机数。这段代码的意思就是读取一个位的随机数,然后转换为的数组。 C语言是一个巨大的宝库,Android是一个以Linux为基础的开源操作系统,系统底层很多的实现都是基于C语言开发,比如图像处理,加密等。另一方面C语言的运行效率也比Java开发要高很多,因此为了高效率的运行有时候也会使用C语言开发...

    Leck1e 评论0 收藏0
  • NDK开发 - Android Studio环境搭建

    摘要:传送门开发环境搭建是版本所以在使用的时候和正式版本的配置还是有挺大的差别的。是官方文档,上面给出了版本使用说明,但是实际使用中还是发现了不少问题,比如签名配置。示例项目地址下一篇将会介绍开发的调用 Android studio在很早版本已经开始支持NDK开发了,但是好像一直没有出正式版的gradle插件,现在最新的版本插件版本是0.6.0-alpha5。之前使用好像有点问题,具体忘记了...

    Jrain 评论0 收藏0
  • Andorid Studio NDK开发-Hello World

    摘要:介绍了在中配置的开发环境开发环境配置,开发环境配置完成之后,就要写一下著名的程序了。尤其是但是并不妨碍你使用其他语言,只要调用约定支持就可以了。是指定所在的目录,项目成功之后,会在目录里生成文件。是包名加上类名。 介绍了在Android Studio中配置NDK的开发环境:Android Studio NDK开发-环境配置,NDK开发环境配置完成之后,就要写一下著名的Hello Wor...

    melody_lql 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<