LightsService.java

本文深入解析了Android系统中LightsService的工作原理及其实现细节,包括如何控制不同类型的指示灯,如背光、键盘灯等,并介绍了核心函数setBrightness的调用流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

lightservice 主要用于指示灯的闪烁等操作,具体源码
/frameworks/base/services/core/java/com/android/server/lights/LightsService.java
122    public LightsService(Context context) {
123        super(context);
124
125        mNativePointer = init_native();
126
127        for (int i = 0; i < LightsManager.LIGHT_ID_COUNT; i++) {
128            mLights[i] = new LightImpl(i);
129        }
130    }
init_native 如下,可以看到只要是open hal层最多可以支持8个灯的控制.
/frameworks/base/services/core/jni/com_android_server_lights_LightsService.cpp
static jlong init_native(JNIEnv* /* env */, jobject /* clazz */)
64{
65    int err;
66    hw_module_t* module;
67    Devices* devices;
68
69    devices = (Devices*)malloc(sizeof(Devices));
70
71    err = hw_get_module(LIGHTS_HARDWARE_MODULE_ID, (hw_module_t const**)&module);
72    if (err == 0) {
73        devices->lights[LIGHT_INDEX_BACKLIGHT]
74                = get_device(module, LIGHT_ID_BACKLIGHT);
75        devices->lights[LIGHT_INDEX_KEYBOARD]
76                = get_device(module, LIGHT_ID_KEYBOARD);
77        devices->lights[LIGHT_INDEX_BUTTONS]
78                = get_device(module, LIGHT_ID_BUTTONS);
79        devices->lights[LIGHT_INDEX_BATTERY]
80                = get_device(module, LIGHT_ID_BATTERY);
81        devices->lights[LIGHT_INDEX_NOTIFICATIONS]
82                = get_device(module, LIGHT_ID_NOTIFICATIONS);
83        devices->lights[LIGHT_INDEX_ATTENTION]
84                = get_device(module, LIGHT_ID_ATTENTION);
85        devices->lights[LIGHT_INDEX_BLUETOOTH]
86                = get_device(module, LIGHT_ID_BLUETOOTH);
87        devices->lights[LIGHT_INDEX_WIFI]
88                = get_device(module, LIGHT_ID_WIFI);
89    } else {
90        memset(devices, 0, sizeof(Devices));
91    }
92
93    return (jlong)devices;
94}
LightImpl也是定义在/frameworks/base/services/core/java/com/android/server/lights/LightsService.java 中是lightService的具体实现.其所有函数:
如setBrightness 最终都是调用setLight_native 来实现的
106static void setLight_native(JNIEnv* /* env */, jobject /* clazz */, jlong ptr,
107        jint light, jint colorARGB, jint flashMode, jint onMS, jint offMS, jint brightnessMode)
108{
109    Devices* devices = (Devices*)ptr;
110    light_state_t state;
111
112    if (light < 0 || light >= LIGHT_COUNT || devices->lights[light] == NULL) {
113        return ;
114    }
115
116    memset(&state, 0, sizeof(light_state_t));
117    state.color = colorARGB;
118    state.flashMode = flashMode;
119    state.flashOnMS = onMS;
120    state.flashOffMS = offMS;
121    state.brightnessMode = brightnessMode;
122
123    {
124        ALOGD_IF_SLOW(50, "Excessive delay setting light");
125        devices->lights[light]->set_light(devices->lights[light], &state);
126    }
可见都是调用hal层的函数来实现的。


132    @Override
133    public void onStart() {
134        publishLocalService(LightsManager.class, mService);
135    }
发布一个service
137    private final LightsManager mService = new LightsManager() {
138        @Override
139        public Light getLight(int id) {
140            if (id < LIGHT_ID_COUNT) {
141                return mLights[id];
142            } else {
143                return null;
144            }
145        }
146    };

如果要实现闪灯操作的话,一般通过mService,得到lightsManager如下所示:
171                LightsManager lights = LocalServices.getService(LightsManager.class);
172                mBacklight = lights.getLight(LightsManager.LIGHT_ID_BACKLIGHT);


使用的话可以直接调用lightsManager的成员函数,如setBrightness 来执行.
mBacklight.setBrightness(brightness);

### ILights.aidl 中 setLightState 和 getLights 方法的使用说明 #### 方法功能概述 #### setLightState - **功能**:此方法用于设置由 `id` 标识的逻辑灯到指定的状态。如果尝试控制无效的灯,则该方法将以 `EX_UNSUPPORTED_OPERATION` 退出[^1]。 - **方法签名**:`void setLightState(in int id, in HwLightState state)` - **参数说明**: - `id`:要设置的逻辑灯的 ID,该 ID 由 `getLights()` 方法返回。 - `state`:描述灯应该如何显示的 `HwLightState` 对象。 - **返回值**:无返回值。 - **示例代码**: ```java try { // 假设 lightId 是通过 getLights() 获取的有效灯 ID int lightId = 0; // 创建一个 HwLightState 对象来定义灯的状态 HwLightState state = new HwLightState(); state.setBrightnessMode(HwLightState.BRIGHTNESS_MODE_USER); state.setColor(0xFF00FF); // 设置颜色为紫色 state.setFlashMode(HwLightState.FLASH_HARDWARE); // 设置硬件闪烁模式 state.setFlashOnMs(500); // 设置亮起时间为 500 毫秒 state.setFlashOffMs(500); // 设置熄灭时间为 500 毫秒 // 调用 setLightState 方法设置灯的状态 ILights lightsService = ILights.Stub.asInterface(ServiceManager.getService("lights")); lightsService.setLightState(lightId, state); } catch (RemoteException e) { e.printStackTrace(); } ``` #### getLights - **功能**:此方法用于发现 HAL 实现支持哪些灯。它返回一个包含可用灯的列表[^3]。 - **方法签名**:`HwLight[] getLights()` - **参数说明**:无参数。 - **返回值**:返回一个 `HwLight` 数组,表示所有可用的灯。 - **示例代码**: ```java try { ILights lightsService = ILights.Stub.asInterface(ServiceManager.getService("lights")); HwLight[] availableLights = lightsService.getLights(); for (HwLight light : availableLights) { System.out.println("Available Light: " + light.getId()); } } catch (RemoteException e) { e.printStackTrace(); } ``` --- ### 注意事项 1. **设备兼容性**:并非所有设备都支持相同的灯类型或功能。在调用 `setLightState` 或 `getLights` 方法之前,应检查设备是否支持相关硬件功能。 2. **权限要求**:使用灯控制功能可能需要声明相关权限。确保在应用的 `AndroidManifest.xml` 文件中添加适当的权限声明。 3. **错误处理**:当调用 `setLightState` 方法时,如果指定的灯 ID 无效,可能会抛出异常。因此,在调用前建议先验证灯 ID 的有效性。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值