blob: 257c7dadfc5dec74b8c3d8af0ca9e743740a7dd4 [file] [log] [blame]
Mike Lockwood3a322132009-11-24 00:30:52 -05001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Adam Lesinski182f73f2013-12-05 16:48:06 -080017package com.android.server.lights;
18
19import com.android.server.SystemService;
Ruben Brunk8ad3f202015-12-28 14:45:11 -080020import com.android.server.vr.VrManagerInternal;
21import com.android.server.vr.VrStateListener;
Mike Lockwood3a322132009-11-24 00:30:52 -050022
23import android.content.Context;
24import android.os.Handler;
25import android.os.Message;
Jeff Brown3edf5272014-08-14 19:25:14 -070026import android.os.Trace;
Joe Onorato8a9b2202010-02-26 18:56:32 -080027import android.util.Slog;
Mike Lockwood3a322132009-11-24 00:30:52 -050028
Adam Lesinski182f73f2013-12-05 16:48:06 -080029public class LightsService extends SystemService {
30 static final String TAG = "LightsService";
31 static final boolean DEBUG = false;
Mike Lockwood3a322132009-11-24 00:30:52 -050032
Adam Lesinski182f73f2013-12-05 16:48:06 -080033 final LightImpl mLights[] = new LightImpl[LightsManager.LIGHT_ID_COUNT];
Mike Lockwood3a322132009-11-24 00:30:52 -050034
Adam Lesinski182f73f2013-12-05 16:48:06 -080035 private final class LightImpl extends Light {
Mike Lockwood3a322132009-11-24 00:30:52 -050036
Adam Lesinski182f73f2013-12-05 16:48:06 -080037 private LightImpl(int id) {
Mike Lockwood3cb67a32009-11-27 14:25:58 -050038 mId = id;
39 }
40
Adam Lesinski182f73f2013-12-05 16:48:06 -080041 @Override
Mike Lockwood3cb67a32009-11-27 14:25:58 -050042 public void setBrightness(int brightness) {
43 setBrightness(brightness, BRIGHTNESS_MODE_USER);
44 }
45
Adam Lesinski182f73f2013-12-05 16:48:06 -080046 @Override
Mike Lockwood3cb67a32009-11-27 14:25:58 -050047 public void setBrightness(int brightness, int brightnessMode) {
48 synchronized (this) {
49 int color = brightness & 0x000000ff;
50 color = 0xff000000 | (color << 16) | (color << 8) | color;
51 setLightLocked(color, LIGHT_FLASH_NONE, 0, 0, brightnessMode);
52 }
53 }
54
Adam Lesinski182f73f2013-12-05 16:48:06 -080055 @Override
Mike Lockwood3cb67a32009-11-27 14:25:58 -050056 public void setColor(int color) {
57 synchronized (this) {
58 setLightLocked(color, LIGHT_FLASH_NONE, 0, 0, 0);
59 }
60 }
61
Adam Lesinski182f73f2013-12-05 16:48:06 -080062 @Override
Mike Lockwood3cb67a32009-11-27 14:25:58 -050063 public void setFlashing(int color, int mode, int onMS, int offMS) {
64 synchronized (this) {
65 setLightLocked(color, mode, onMS, offMS, BRIGHTNESS_MODE_USER);
66 }
67 }
68
Adam Lesinski182f73f2013-12-05 16:48:06 -080069 @Override
Mike Lockwood3cb67a32009-11-27 14:25:58 -050070 public void pulse() {
Mike Lockwood670f9322010-01-20 12:13:36 -050071 pulse(0x00ffffff, 7);
72 }
73
Adam Lesinski182f73f2013-12-05 16:48:06 -080074 @Override
Mike Lockwood670f9322010-01-20 12:13:36 -050075 public void pulse(int color, int onMS) {
Mike Lockwood3cb67a32009-11-27 14:25:58 -050076 synchronized (this) {
Ruben Brunk8ad3f202015-12-28 14:45:11 -080077 if (mBrightnessMode == BRIGHTNESS_MODE_LOW_PERSISTENCE) {
78 return;
79 }
Mike Lockwood3cb67a32009-11-27 14:25:58 -050080 if (mColor == 0 && !mFlashing) {
Mike Lockwood670f9322010-01-20 12:13:36 -050081 setLightLocked(color, LIGHT_FLASH_HARDWARE, onMS, 1000, BRIGHTNESS_MODE_USER);
Oskar Anderoe8467192013-12-03 17:41:27 +010082 mColor = 0;
Mike Lockwood670f9322010-01-20 12:13:36 -050083 mH.sendMessageDelayed(Message.obtain(mH, 1, this), onMS);
Mike Lockwood3cb67a32009-11-27 14:25:58 -050084 }
85 }
86 }
87
Adam Lesinski182f73f2013-12-05 16:48:06 -080088 @Override
Mike Lockwood3cb67a32009-11-27 14:25:58 -050089 public void turnOff() {
90 synchronized (this) {
91 setLightLocked(0, LIGHT_FLASH_NONE, 0, 0, 0);
92 }
93 }
94
Ruben Brunk8ad3f202015-12-28 14:45:11 -080095 void enableLowPersistence() {
96 synchronized(this) {
97 setLightLocked(0, LIGHT_FLASH_NONE, 0, 0, BRIGHTNESS_MODE_LOW_PERSISTENCE);
98 mLocked = true;
99 }
100 }
101
102 void disableLowPersistence() {
103 synchronized(this) {
104 mLocked = false;
105 setLightLocked(mLastColor, LIGHT_FLASH_NONE, 0, 0, mLastBrightnessMode);
106 }
107 }
108
Mike Lockwood3cb67a32009-11-27 14:25:58 -0500109 private void stopFlashing() {
110 synchronized (this) {
111 setLightLocked(mColor, LIGHT_FLASH_NONE, 0, 0, BRIGHTNESS_MODE_USER);
112 }
113 }
114
115 private void setLightLocked(int color, int mode, int onMS, int offMS, int brightnessMode) {
Ruben Brunk8ad3f202015-12-28 14:45:11 -0800116 if (!mLocked && (color != mColor || mode != mMode || onMS != mOnMS || offMS != mOffMS ||
117 mBrightnessMode != brightnessMode)) {
Dianne Hackbornff801ec2011-01-22 18:05:38 -0800118 if (DEBUG) Slog.v(TAG, "setLight #" + mId + ": color=#"
Ruben Brunk8ad3f202015-12-28 14:45:11 -0800119 + Integer.toHexString(color) + ": brightnessMode=" + brightnessMode);
120 mLastColor = mColor;
Mike Lockwood3cb67a32009-11-27 14:25:58 -0500121 mColor = color;
122 mMode = mode;
123 mOnMS = onMS;
124 mOffMS = offMS;
Ruben Brunk8ad3f202015-12-28 14:45:11 -0800125 mLastBrightnessMode = mBrightnessMode;
126 mBrightnessMode = brightnessMode;
Jeff Brownfaec22c82015-04-10 12:58:52 -0700127 Trace.traceBegin(Trace.TRACE_TAG_POWER, "setLight(" + mId + ", 0x"
128 + Integer.toHexString(color) + ")");
Jeff Brown3edf5272014-08-14 19:25:14 -0700129 try {
130 setLight_native(mNativePointer, mId, color, mode, onMS, offMS, brightnessMode);
131 } finally {
132 Trace.traceEnd(Trace.TRACE_TAG_POWER);
133 }
Mike Lockwood3cb67a32009-11-27 14:25:58 -0500134 }
135 }
136
137 private int mId;
138 private int mColor;
139 private int mMode;
140 private int mOnMS;
141 private int mOffMS;
142 private boolean mFlashing;
Ruben Brunk8ad3f202015-12-28 14:45:11 -0800143 private int mBrightnessMode;
144 private int mLastBrightnessMode;
145 private int mLastColor;
146 private boolean mLocked;
Mike Lockwood3cb67a32009-11-27 14:25:58 -0500147 }
Mike Lockwood3a322132009-11-24 00:30:52 -0500148
Jeff Brownb880d882014-02-10 19:47:07 -0800149 public LightsService(Context context) {
150 super(context);
151
Mike Lockwood3a322132009-11-24 00:30:52 -0500152 mNativePointer = init_native();
Mike Lockwood3cb67a32009-11-27 14:25:58 -0500153
Adam Lesinski182f73f2013-12-05 16:48:06 -0800154 for (int i = 0; i < LightsManager.LIGHT_ID_COUNT; i++) {
155 mLights[i] = new LightImpl(i);
Mike Lockwood3cb67a32009-11-27 14:25:58 -0500156 }
Mike Lockwood3a322132009-11-24 00:30:52 -0500157 }
158
Adam Lesinski182f73f2013-12-05 16:48:06 -0800159 @Override
160 public void onStart() {
Adam Lesinski182f73f2013-12-05 16:48:06 -0800161 publishLocalService(LightsManager.class, mService);
162 }
163
Ruben Brunk8ad3f202015-12-28 14:45:11 -0800164 @Override
165 public void onBootPhase(int phase) {
166 if (phase == PHASE_SYSTEM_SERVICES_READY) {
167 getLocalService(VrManagerInternal.class).registerListener(mVrStateListener);
168 }
169 }
170
171 private final VrStateListener mVrStateListener = new VrStateListener() {
172 @Override
173 public void onVrStateChanged(boolean enabled) {
174 LightImpl l = mLights[LightsManager.LIGHT_ID_BACKLIGHT];
175 if (enabled) {
176 if (DEBUG) Slog.v(TAG, "VR mode enabled, setting brightness to low persistence");
177 l.enableLowPersistence();
178
179 } else {
180 if (DEBUG) Slog.v(TAG, "VR mode disabled, resetting brightnes");
181 l.disableLowPersistence();
182 }
183 }
184 };
185
Adam Lesinski182f73f2013-12-05 16:48:06 -0800186 private final LightsManager mService = new LightsManager() {
187 @Override
Jeff Brown5d6443b2015-04-10 20:15:01 -0700188 public Light getLight(int id) {
Adam Lesinski182f73f2013-12-05 16:48:06 -0800189 if (id < LIGHT_ID_COUNT) {
190 return mLights[id];
191 } else {
192 return null;
193 }
194 }
195 };
196
Jeff Brownb880d882014-02-10 19:47:07 -0800197 @Override
Mike Lockwood3a322132009-11-24 00:30:52 -0500198 protected void finalize() throws Throwable {
199 finalize_native(mNativePointer);
200 super.finalize();
201 }
202
Mike Lockwood3a322132009-11-24 00:30:52 -0500203 private Handler mH = new Handler() {
204 @Override
205 public void handleMessage(Message msg) {
Adam Lesinski182f73f2013-12-05 16:48:06 -0800206 LightImpl light = (LightImpl)msg.obj;
Mike Lockwood3cb67a32009-11-27 14:25:58 -0500207 light.stopFlashing();
Mike Lockwood3a322132009-11-24 00:30:52 -0500208 }
209 };
210
Ashok Bhat7e2a9dc2014-01-02 19:43:30 +0000211 private static native long init_native();
212 private static native void finalize_native(long ptr);
Mike Lockwood3a322132009-11-24 00:30:52 -0500213
Narayan Kamath3f7b8d02014-01-08 12:19:40 +0000214 static native void setLight_native(long ptr, int light, int color, int mode,
Mike Lockwood3a322132009-11-24 00:30:52 -0500215 int onMS, int offMS, int brightnessMode);
216
Ashok Bhat7e2a9dc2014-01-02 19:43:30 +0000217 private long mNativePointer;
Mike Lockwood3a322132009-11-24 00:30:52 -0500218}