如何向android的framework里添加新类

google对于所有的类和API,分为开放式和不开放式两种。所谓的开放式就是值javadoc所包含的,并不是java中有public和private,而是跟javadoc有关系,代码 没有关系。
在开放式的类中增加了一个变量,而又没隐藏,导致和原API的doc不一致造成的就会有错。
通过提示,有2个方法可以解决 该问题:
1、将新增加的变量或方法加上"@hide" 的注释,注意一点,加"@hide" 不是简简单单的/*@hide */就行了,标准的javadoc要这样 /** */ 而且对于 format 变量 应该加上 { },也就是/**{@hide}*/
2、如果想在生成的doc中增加该变量或方法的话,必须输入:
make update-api
这样的话,系统 自动 将新增加的API添加到current.xml中了。


所以如果要加方法就是按上面的方法加。


如果需要加进新的类 这时候又分2种 一种是原有的包下面加类 这个最简单 加完之后直接make update-api就好了 还有一种是加在framework/base下面 这个时候你make update-api是不会在current。xml里生成你的类的。 看了Android。mk才知道 原来需要修改android源码根目录下的build/core/pathmap.mk把你的目录加进去。然后就好了。
Android Framework添加公开API供应用程序调用是一个涉及多个步骤的过程,通常包括在Java层定义接口、注册JNI方法(如果涉及底层交互)、构建系统配置调整以及确保上层应用能够正确调用这些API。以下是实现这一目标的详细流程: ### 添加Java层API接口 首先,在Framework的Java代码中定义一个或接口,或者在已有添加的方法。例如,可以在`frameworks/base/core/java/android/app/`目录下创建或修改已有: ```java package android.app; public class CustomApi { public static int performCustomOperation(int param) { // 实现逻辑 return param * 2; } } ``` 该可以包含静态方法或实例方法,具体取决于设计需求。 ### 在JNI层实现功能(可选) 如果增的API需要与底层系统交互,则需要在C/C++中实现JNI方法。例如,在`frameworks/base/core/jni/`目录下创建或修改对应的JNI实现文件: ```cpp #include <jni.h> #include <android_runtime/AndroidRuntime.h> extern "C" JNIEXPORT jint JNICALL Java_android_app_CustomApi_nativePerformCustomOperation(JNIEnv* env, jclass clazz, jint param) { return param * 2; } ``` 同时,需要在`AndroidRuntime.cpp`中注册该JNI方法,确保Java层能够正确调用: ```cpp static const JNINativeMethod gCustomApiMethods[] = { { "nativePerformCustomOperation", "(I)I", (void*) Java_android_app_CustomApi_nativePerformCustomOperation }, }; int register_android_app_CustomApi(JNIEnv* env) { return jniRegisterNativeMethods(env, "android/app/CustomApi", gCustomApiMethods, NELEM(gCustomApiMethods)); } ``` ### 修改构建配置 为了使增的或方法能够被正确编译和打包,需要更`Android.bp`文件以包含的Java或JNI模块: ```starlark java_library { name: "framework-custom-api", srcs: ["CustomApi.java"], platform_apis: true, static_libs: ["framework"], sdk_version: "current", } ``` 对于JNI部分,也需要在`Android.mk`或`Android.bp`中添加对应的模块声明。 ### 使API对上层应用可见 增的API默认可能不会被导出到`android.jar`中,因此需要修改`frameworks/base/api/current.txt`文件,将增的或方法添加进去: ``` added class android.app.CustomApi added method public static int performCustomOperation(int) ``` 这样,构建系统在生成`android.jar`时会包含这些API,供上层应用引用。 ### 应用程序调用增API 应用程序可以直接通过标准的Java调用方式访问这些公开API: ```java int result = CustomApi.performCustomOperation(5); Log.d("CustomApi", "Result: " + result); ``` 如果增的API被标记为`@hide`,则上层应用无法直接调用,此时可以使用反射机制: ```java try { Class<?> clazz = Class.forName("android.app.CustomApi"); Method method = clazz.getMethod("performCustomOperation", int.class); int result = (int) method.invoke(null, 5); Log.d("CustomApi", "Result: " + result); } catch (Exception e) { e.printStackTrace(); } ``` ### 注意事项 - **兼容性**:增API需考虑版本兼容性,避免破坏现有应用。 - **安全性**:确保API不会暴露敏感功能或导致系统不稳定。 - **文档**:提供清晰的API文档,便于开发者理解和使用。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值