framework下添加自定jni

framework添加自定jni

   本文章适用于在源码环境下在framework添加自定的jni供上层Apk调用。

    • framework添加自定jni
      • 添加自定义的jni文件和Androidmk
      • 添加系统编译配置


添加自定义的jni文件和Android.mk

首先在frameworks/base/下新建一个文件夹,命名可以自定义,例如/frameworks/base/jnitest/,在其目录下添加两个子目录/java , /jni ,依据包名在/java下添加子目录/java/com/rabi/testing/。
目录添加完成之后在jni文件夹中添加两个文件,分别是源码的source.c和编译使用的Android.mk。
source.c的代码如下:

#include <jni.h>
#include <android/log.h>

#define TAG "rabi"
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,TAG ,__VA_ARGS__)

JNIEXPORT void JNICALL
Java_com_rabi_testing_JniUtil_Exam(JNIEnv *env, jclass type) {
    // TODO
    LOGD("this is a jni test!");
}

Android.mk代码如下:

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

LOCAL_SRC_FILES  := source.c
LOCAL_MODULE     := libsource

LOCAL_LDLIBS := -llog

include $(BUILD_SHARED_LIBRARY)

在java/com/rabi/testing/目录下添加自定义的JniUtil.java,作为提供给上层的调用接口。JniUtil代码如下:

package com.rabi.testing;

public class JniUtil {
    static {
        System.loadLibrary("source");
    }
    public static native void Exam();
}

添加源码完成后就可以执行模块编译,编译结果是一个libsource.so的库,这个库会在system/lib生成。

添加系统编译配置

源码添加完成之后就是将jni加入Android客服端中,能够作为接口提供给每一个上层应用。
首先在/build/core/pathmap.mk中添加自定义的文件夹名:

--- a/core/pathmap.mk
+++ b/core/pathmap.mk
@@ -92,6 +92,7 @@ FRAMEWORKS_BASE_SUBDIRS := \
            keystore \
            rs \
+           jnitest \

然后在/device/product/common/device.mk中添加自定义的MODULE。

--- a/device.mk
+++ b/device.mk
@@ -121,6 +121,7 @@ ifeq ($(strip $(TARGET_ARCH)), arm)

 PRODUCT_PACKAGES += \
+          libsource \

添加完成后,进行整体编译即可。


你可能感兴趣的:(framework)