android framework添加系统服务

http://blog.csdn.net/pierce0young/article/details/24424991
在android源码中添加系统服务,如在android.app包下增加DevInfoManager.java, 按照如下步骤处理:
1. 在framework/base/core/java/android/app/目录下增加 DevInfoManager.java 及 IDevInfoManager.aidl 文件
注意:此处可以根据实际情况添加到合适的包中,在framework/base/core/java/andorid目录下。
DevInfoManager.java如下:
**************************************************************************************************
package android.app;

import android.os.Handler;
import andorid.os.RemoteException;
import android.util.Log;

public class DevInfoManager{

public static final String TAG = "DevInfoManager";
IDevInfoManager mService;
Handler mHandler;

public DevInfoManager(IDevInfoManager service, Handler handler){
mService = service;
mHandler = handler;
}

public String getValue(String name){
try{
return mService.getValue(name);
}catch(RemoteException e){
Log.d(TAG, "get value RemoteException");
}
return null;
}

public int update(String name, String value, int attribute){
try{
return mService.update(name, value, attribute);
}catch(RemoteException e){
Log.d(TAG, "update value RemoteException");
}
return -1;
}
}
**************************************************************************************************
IDevInfoManager.aidl文件如下:
**************************************************************************************************
package android.app;

/**{@hide}*/
interface IDevInfoManager{
String getValue(String name);
int setValue(String name, String value, int attribute);
}
**************************************************************************************************
如果在方法上面添加 /**{@hide}*/ 修饰的话,表示api不提供对外接口,在执行make update-api后不会出现在framework/base/core/java/android/content/Context中。

2. 添加相应的Service类,在framework/base/services/java/com/android/server下添加DevInfoService.java文件
DevInfoService.java文件如下:
**************************************************************************************************
package com.android.server;

import android.app.IDevInfoManager;
import android.util.Log;
import android.content.Context;

public class DevInfoService extends IDevInfoManager.Stub{

private static final String TAG = "DevInfoManagerService";
private Context mContext;

public DevInfoService(Context context){
mContext = context;
}

public String getValue(String name){
Log.d(TAG, "get name: " + name);
return name;
}

public int setValue(String name, String value, int attribute){
return 0;
}
}
**************************************************************************************************
注意:此处最好自建一个目录,不要打乱系统的存放目录的结构

3. 在SystemServer中生成该Service并添加到ServiceManager中:
在framework/base/services/java/com/android/server/SystemServer.java中添加:同其他服务一样,在startOtherServices()方法中添加:
**************************************************************************************************
DevInfoService devInfoService = null;

try{
devInfoService = new DevInfoService(context);
ServiceManager.addService(Context.DEVINFO_SERVICE, devInfoService);
}catch(Throwable e){
Slog.e(TAG, "add DevInfoService failure");
}
**************************************************************************************************
表示在SystemServer中启动服务

4. 需要在framework/base/core/java/android/app/ContextImpl.java中增加servcie注册,如下:
在StaticServiceFetcher抽象类中添加如下内容
**************************************************************************************************
registerService(DEVINFO_SERVICE, new DevInfoService(){
public Object createService(ContextImpl ctx){
IBinder b = ServiceManager.getService(DEVINFO_SERVICE);
IDevInfoManager service = IDevInfoManager.Stub.asInterface(b);
return new DevInfoManager(service, ctx.mMainThread.getHandler());
}
});
**************************************************************************************************

5. 在framework/base/core/java/android/content/Context.java中添加Services名称定义:
**************************************************************************************************
public static final String DEVINFO_SERVICE = "devinfo";
**************************************************************************************************

6. 在framework/base/Android.mk文件中的LOCAL_SRC_FILES添加 aidl 的声明:
LOCAL_SRC_FILES += \
core/java/android/app/IDevInfoManager.aidl \

7. 进行编译,因为framework有变更,所以需要先update-api,在然后编译framework
此处,执行make update-api去更新,如果方法没有家hide标记,就会在current.txt中找到你新加的服务方法。

8. 调用
import android.app.DevInfoService;
DevInfoService devInfoservice = (DevInfoService)this.getSystemService(Context.DEVINFO_SERVICE);






















  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Android 9.0和10.0的Framework系统API上添加JNI方法需要经过以下步骤: 1. 在Java层调用JNI方法前,需要先创建定义JNI方法的C++文件和对应的头文件。这些文件应该保存在frameworks/native/libs/目录下的对应模块中。例如,如果想要在WebView模块中添加JNI方法,则应该在frameworks/native/libs/webviewchromium/目录下创建文件并进行定义。 2. 编写C++代码实现JNI方法。在代码中,需要采用JNI函数以及Java Native Interface标准库的方法来实现该方法的功能。具体实现过程可以参考Android源码中frameworks/native/libs/input/Input.cpp文件的实现。 3. 在C++代码的头文件中定义JNI方法。为了让Java层正确调用JNI方法,需要在C++头文件中定义JNI函数名称、Java包名、Java类名以及方法参数的信息。参考Android源码中frameworks/native/libs/webviewchromium/webviewchromium_jni.h文件。 4. 在Java层调用JNI方法。要调用JNI方法,需要在Java代码中加载C++库。可以使用静态代码块System.loadLibrary("yourlibrary")来加载C++库,并在程序中使用对应的Java扩展头文件。在Java代码中,需要使用JNI函数来调用JNI方法。参考Android源码中frameworks/native/libs/webviewchromium/WebBackForwardList.java文件。 通过以上步骤,即可在Android 9.0和10.0的Framework系统API中添加JNI方法。需要注意的是,添加JNI方法需要遵循JNI标准,使用合适的JNI库函数和API接口,以确保程序代码的正确性和稳定性。 ### 回答2: Android 9.0和10.0的Framework系统API都支持添加JNI方法。 首先,要添加一个JNI方法,您需要在Java中编写该方法的实现,然后在C / C ++中编写对应的本地代码,然后使用JNI将二者连接起来。 为了在Framework添加新的JNI方法,您需要找到Framework源代码中对应的Java类和C ++代码。然后按照以下步骤进行操作: 1. 在Java类中添加新的JNI方法声明,方法名必须与您要添加的本地方法的名称匹配。例如,如果您要添加一个名为newMethod的本地方法,则需要在Java类中声明以下内容: ```java public native void newMethod(int arg1, String arg2); ``` 注意:在声明中,您不能提供方法的实现。 2. 在C / C ++代码中实现新的本地方法,方法名称必须与您在Java中声明的方法名称一致。 ```cpp JNIEXPORT void JNICALL Java_com_example_MyClass_newMethod(JNIEnv *env, jobject obj, jint arg1, jstring arg2) { // 实现您的代码 } ``` 3. 最后,在您的C / C ++代码中获取Java类的引用,以便在Native代码中调用该方法。 ```cpp jclass clazz = env->FindClass("com/example/MyClass"); jmethodID methodId = env->GetMethodID(clazz, "newMethod", "(ILjava/lang/String;)V"); ``` 通过此方法ID,您可以使用JNI在C / C ++中调用该方法。 ```cpp env->CallVoidMethod(obj, methodId, arg1, arg2); ``` 这样,您就可以在Android 9.0和10.0的Framework系统API中添加新的JNI方法了。 ### 回答3: Android操作系统使用Java语言实现,但是也支持通过JNI机制(Java Native Interface)来调用C/C++编写的代码。在Android 9.0和10.0版本中,如果需要在Framework系统层中添加JNI方法,需要进行以下步骤: 1. 编写C/C++代码实现需要的功能,并将其编译成动态库(.so文件)。 2. 在Framework层中找到对应的Java类,并添加需要的Native方法声明。例如,如果要在TelephonyManager类中添加一个名为getSignalStrengthDbm的方法,则应该在TelephonyManager.java中添加以下Native方法声明: ``` private native int getSignalStrengthDbm(); ``` 3. 在frameworks/base目录下的services/core/jni目录中添加一个名为TelephonyManager.cpp的文件,并实现getSignalStrengthDbm方法: ``` static jint TelephonyManager_getSignalStrengthDbm(JNIEnv *env, jobject thiz){ // TODO: 通过调用C/C++代码实现需要的功能,并返回结果 return 0; } static const JNINativeMethod gMethods[] = { { "getSignalStrengthDbm", "()I", (void*)TelephonyManager_getSignalStrengthDbm}, }; int register_android_telephony_TelephonyManager(JNIEnv* env) { jclass clazz = env->FindClass("android/telephony/TelephonyManager"); if (clazz == NULL) { ALOGE("Can't find android/telephony/TelephonyManager"); return -1; } return env->RegisterNatives(clazz, gMethods, sizeof(gMethods) / sizeof(JNINativeMethod)); } ``` 4. 在frameworks/base目录下的services/core目录中找到文件Android.bp,将添加的TelephonyManager.cpp文件加入build文件中: ``` cc_library_shared { name: "libandroidfw", srcs: [ "jni/Animation.cpp", ... "jni/TelephonyManager.cpp", ], ... } ``` 5. 在Android.mk文件中添加TelephonyManager.cpp的编译规则: ``` LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := TelephonyManager LOCAL_CFLAGS := -Werror LOCAL_SRC_FILES := TelephonyManager.cpp LOCAL_SHARED_LIBRARIES := libutils libcutils libbinder include $(BUILD_SHARED_LIBRARY) ``` 6. 重新编译Framework层并运行即可。 以上是在Android 9.0和10.0系统添加JNI方法的步骤,其中涉及到的文件和目录可能有所不同,在实际开发中需要根据具体情况进行调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值