Android 12 S java服务调用自定义native服务

系列文章

Android 12 S ServiceManager原理

Android 12 S Native Service的创建流程

Android 12 S Binder原理之BpBinder,BnBinder以及IInterface介绍

Android 12 S HIDL Service创建流程

Android 12 S 自定义Hal服务selinux权限添加

Android 12 S 自定义Native服务selinux权限添加

Android 12 S java服务调用native服务

Android 12 S 自定义native服务访问java服务


WMS作为Client端,其代码路径如下:

android/frameworks/base/services/core/java/com/android/server/wm

native层CustomizeManagerService作为Server端,其代码路径如下:

android/frameworks/native/services/customizemanagerservice

目录

1.首先定义一个aidl文件,可在如下目录添加

2. 至于Native层service则按照参考常规的native service创建流程就好了。

可参考

3. 但是要修改如下地方:


1.首先定义一个aidl文件,可在如下目录添加

android/frameworks/base/core/java/android/ipd/ICustomizeManagerService.aidl

package android.customize;
/**
 * customize interface.
 * {@hide}
 */
interface ICustomizeManagerService {
    int getcustomize();
}

若想将aidl生成java文件想看看里面的内容时,可用如下命令,会生成在java目录下,-o是指定生成路径。

$ aidl -o ./java --lang=java frameworks/base/core/java/android/ipd/ICustomizeManagerService.aidl

import android.ipd.ICustomizeManagerService;

private ICustomizeManagerService ipdService;

IBinder binder = ServiceManager.getService("customizemanagerservice");

if (binder != null) {

    customizeService = ICustomizeManagerService.Stub.asInterface(binder);

}

int getcustomize = customizeService.getcustomize();

2. 至于Native层service则按照参考常规的native service创建流程就好了。

可参考

https://blog.csdn.net/weixin_41028555/article/details/130322366?spm=1001.2014.3001.5502

3. 但是要修改如下地方:

#define NATIVESERVICE_NAME "android.customize.ICustomizeManagerService"
IMPLEMENT_META_INTERFACE(CustomizeManagerService, NATIVESERVICE_NAME);

这里的NATIVESERVICE_NAME要和ICustomizeManagerService.aidl中的package name保持一致。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Android 中,可以通过以下步骤将自定义的头文件.h 添加到编译器的类库路径下,以便调用者可以使用: 1. 在项目的根目录下创建一个名为“jni”的文件夹。 2. 在“jni”文件夹下创建一个名为“include”的文件夹,用于存放自定义的头文件.h。 3. 在项目的“build.gradle”文件中,添加以下代码段: ``` android { // ... defaultConfig { // ... externalNativeBuild { cmake { // ... cppFlags "-I${projectDir}/jni/include" } } } // ... } ``` 这段代码会告诉编译器在编译时将“jni/include”路径添加到类库路径中,以便可以引用自定义的头文件。 4. 在需要使用自定义头文件的源文件中,使用“#include”指令引入头文件,例如: ``` #include "myheader.h" ``` 这样就可以在 Android 项目中使用自定义的头文件了。 ### 回答2: 在Android中,将自定义的头文件(.h)添加到编译器的库路径下,以便调用者可以使用,可以按照以下步骤操作: 1. 在Android项目的目录结构中,创建一个名为"jni"的文件夹,并在该文件夹下创建一个名为"include"的文件夹。将自定义的头文件(.h)放入"include"文件夹中。 2. 在"jni"文件夹下新建一个名为"Android.mk"的文件,并在该文件中添加如下内容: ``` LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := your_module_name LOCAL_SRC_FILES := your_source_files LOCAL_C_INCLUDES := $(LOCAL_PATH)/include include $(BUILD_SHARED_LIBRARY) ``` 其中,your_module_name是你的模块名,your_source_files是你的源文件路径(可以是.c文件或.cpp文件)。 3. 在"jni"文件夹下新建一个名为"Application.mk"的文件,并在该文件中添加如下内容: ``` APP_ABI := all ``` 这样可以确保生成全部支持的CPU架构。 4. 在Android Studio的"Project"视图中,找到你的Android项目,右键选择"Open Module Settings"。 5. 在弹出的窗口中,选择左侧的"app"模块,然后切换到"Flavors"选项卡。 6. 在"External Native Build"部分,选择"CMakeLists.txt"文件。 7. 在CMakeLists.txt文件中,添加以下内容: ``` set(path_to_include ${CMAKE_SOURCE_DIR}/jni/include) include_directories(${path_to_include}) add_library(your_module_name SHARED your_source_files) ``` 注意将your_module_name和your_source_files替换为实际的模块名和源文件路径。 8. 点击"Apply"按钮,然后点击"OK"按钮。 经过以上步骤,自定义的头文件(.h)就会被添加到编译器的库路径下。如果需要在代码中调用这些头文件,可以在需要使用的地方包含对应头文件的代码,然后就可以正常调用了。 ### 回答3: 要把自定义的头文件.h添加到Android编译器的类库路径下,需要以下步骤: 1. 在Android项目的目录下创建一个新的文件夹,例如"jniLibs"。 2. 在新建的文件夹中创建一个子文件夹,命名为对应的CPU架构,例如"armeabi-v7a"。 3. 将自定义的头文件.h复制到该子文件夹中。 4. 在build.gradle文件中添加以下代码: ```groovy android { // ... sourceSets { main { jniLibs.srcDirs = ['jniLibs'] } } // ... } ``` 5. 然后,在你的Java代码中引入并调用自定义的头文件.h。 这样做的意义是,将自定义的头文件.h放在jniLibs文件夹中可以让Android编译器在编译时找到并将其编译进来,在使用者调用时可以直接引用。 另外,如果你的自定义头文件.h还依赖于其他的C++库文件,你需要将这些库文件一起放入对应的jniLibs子文件夹中,然后在需要的地方引入。例如,如果有一个名为libcustom.so的库文件,你可以将其放入armeabi-v7a文件夹下,然后在Java代码中使用System.loadLibrary("custom")来加载它。 总之,通过将自定义的头文件.h放在jniLibs文件夹下,并在build.gradle文件中配置相应的路径,就可以让Android编译器将其编译为类库的一部分,使用者可以通过引入并调用这些头文件.h来使用相关功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值