Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2016 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 |
Adrian Roos | ff2c456 | 2016-11-03 12:13:36 -0700 | [diff] [blame] | 14 | * limitations under the License. |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 15 | */ |
| 16 | |
| 17 | package com.android.systemui.doze; |
| 18 | |
Lucas Dupin | b2d9f48 | 2018-11-16 18:55:13 -0800 | [diff] [blame] | 19 | import static com.android.systemui.plugins.SensorManagerPlugin.Sensor.TYPE_WAKE_DISPLAY; |
Lucas Dupin | de64ee0 | 2018-12-21 14:45:12 -0800 | [diff] [blame] | 20 | import static com.android.systemui.plugins.SensorManagerPlugin.Sensor.TYPE_WAKE_LOCK_SCREEN; |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 21 | |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 22 | import android.annotation.AnyThread; |
| 23 | import android.app.ActivityManager; |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 24 | import android.app.AlarmManager; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 25 | import android.content.ContentResolver; |
| 26 | import android.content.Context; |
| 27 | import android.database.ContentObserver; |
| 28 | import android.hardware.Sensor; |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 29 | import android.hardware.SensorEventListener; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 30 | import android.hardware.SensorManager; |
| 31 | import android.hardware.TriggerEvent; |
| 32 | import android.hardware.TriggerEventListener; |
Issei Suzuki | ca19e6e | 2019-02-26 12:39:11 +0100 | [diff] [blame] | 33 | import android.hardware.display.AmbientDisplayConfiguration; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 34 | import android.net.Uri; |
| 35 | import android.os.Handler; |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 36 | import android.os.SystemClock; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 37 | import android.os.UserHandle; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 38 | import android.provider.Settings; |
| 39 | import android.text.TextUtils; |
| 40 | import android.util.Log; |
| 41 | |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 42 | import androidx.annotation.VisibleForTesting; |
| 43 | |
Adrian Roos | ff2c456 | 2016-11-03 12:13:36 -0700 | [diff] [blame] | 44 | import com.android.internal.logging.MetricsLogger; |
Tamas Berghammer | 383db5eb | 2016-06-22 15:21:38 +0100 | [diff] [blame] | 45 | import com.android.internal.logging.nano.MetricsProto; |
Lucas Dupin | f61c104 | 2019-07-19 12:16:25 -0700 | [diff] [blame] | 46 | import com.android.systemui.R; |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 47 | import com.android.systemui.plugins.SensorManagerPlugin; |
Adrian Roos | ff2c456 | 2016-11-03 12:13:36 -0700 | [diff] [blame] | 48 | import com.android.systemui.statusbar.phone.DozeParameters; |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 49 | import com.android.systemui.util.AlarmTimeout; |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 50 | import com.android.systemui.util.AsyncSensorManager; |
Adrian Roos | c1b5032 | 2017-02-27 21:07:58 +0100 | [diff] [blame] | 51 | import com.android.systemui.util.wakelock.WakeLock; |
Adrian Roos | ff2c456 | 2016-11-03 12:13:36 -0700 | [diff] [blame] | 52 | |
| 53 | import java.io.PrintWriter; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 54 | import java.util.List; |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 55 | import java.util.function.Consumer; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 56 | |
| 57 | public class DozeSensors { |
| 58 | |
| 59 | private static final boolean DEBUG = DozeService.DEBUG; |
| 60 | |
| 61 | private static final String TAG = "DozeSensors"; |
| 62 | |
| 63 | private final Context mContext; |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 64 | private final AlarmManager mAlarmManager; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 65 | private final SensorManager mSensorManager; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 66 | private final ContentResolver mResolver; |
| 67 | private final TriggerSensor mPickupSensor; |
| 68 | private final DozeParameters mDozeParameters; |
| 69 | private final AmbientDisplayConfiguration mConfig; |
Adrian Roos | c1b5032 | 2017-02-27 21:07:58 +0100 | [diff] [blame] | 70 | private final WakeLock mWakeLock; |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 71 | private final Consumer<Boolean> mProxCallback; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 72 | private final Callback mCallback; |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 73 | @VisibleForTesting |
lpeter | aca9763 | 2019-06-11 11:13:54 +0800 | [diff] [blame] | 74 | protected TriggerSensor[] mSensors; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 75 | |
| 76 | private final Handler mHandler = new Handler(); |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 77 | private final ProxSensor mProxSensor; |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 78 | private long mDebounceFrom; |
lpeter | aca9763 | 2019-06-11 11:13:54 +0800 | [diff] [blame] | 79 | private boolean mSettingRegistered; |
Lucas Dupin | fac2e8e | 2019-06-27 16:10:19 -0700 | [diff] [blame] | 80 | private boolean mListening; |
| 81 | private boolean mPaused; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 82 | |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 83 | public DozeSensors(Context context, AlarmManager alarmManager, SensorManager sensorManager, |
Lucas Dupin | 323f9ff | 2018-08-27 16:55:56 -0700 | [diff] [blame] | 84 | DozeParameters dozeParameters, AmbientDisplayConfiguration config, WakeLock wakeLock, |
Lucas Dupin | b2d9f48 | 2018-11-16 18:55:13 -0800 | [diff] [blame] | 85 | Callback callback, Consumer<Boolean> proxCallback, AlwaysOnDisplayPolicy policy) { |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 86 | mContext = context; |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 87 | mAlarmManager = alarmManager; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 88 | mSensorManager = sensorManager; |
| 89 | mDozeParameters = dozeParameters; |
| 90 | mConfig = config; |
| 91 | mWakeLock = wakeLock; |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 92 | mProxCallback = proxCallback; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 93 | mResolver = mContext.getContentResolver(); |
| 94 | |
Lucas Dupin | 70bda67 | 2018-12-27 15:43:40 -0800 | [diff] [blame] | 95 | boolean alwaysOn = mConfig.alwaysOnEnabled(UserHandle.USER_CURRENT); |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 96 | mSensors = new TriggerSensor[] { |
| 97 | new TriggerSensor( |
| 98 | mSensorManager.getDefaultSensor(Sensor.TYPE_SIGNIFICANT_MOTION), |
| 99 | null /* setting */, |
| 100 | dozeParameters.getPulseOnSigMotion(), |
Adrian Roos | 98d3198 | 2017-08-02 20:50:16 +0200 | [diff] [blame] | 101 | DozeLog.PULSE_REASON_SENSOR_SIGMOTION, false /* touchCoords */, |
| 102 | false /* touchscreen */), |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 103 | mPickupSensor = new TriggerSensor( |
| 104 | mSensorManager.getDefaultSensor(Sensor.TYPE_PICK_UP_GESTURE), |
Lucas Dupin | 4359b55 | 2018-08-09 15:07:54 -0700 | [diff] [blame] | 105 | Settings.Secure.DOZE_PICK_UP_GESTURE, |
Lucas Dupin | fac2e8e | 2019-06-27 16:10:19 -0700 | [diff] [blame] | 106 | true /* settingDef */, |
Lucas Dupin | 4359b55 | 2018-08-09 15:07:54 -0700 | [diff] [blame] | 107 | config.dozePickupSensorAvailable(), |
Lucas Dupin | 3d05353 | 2019-01-29 12:35:22 -0800 | [diff] [blame] | 108 | DozeLog.REASON_SENSOR_PICKUP, false /* touchCoords */, |
Lucas Dupin | fac2e8e | 2019-06-27 16:10:19 -0700 | [diff] [blame] | 109 | false /* touchscreen */, |
Lucas Dupin | f40bd8f | 2019-08-07 15:55:00 -0700 | [diff] [blame] | 110 | false /* ignoresSetting */), |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 111 | new TriggerSensor( |
| 112 | findSensorWithType(config.doubleTapSensorType()), |
Lucas Dupin | 4359b55 | 2018-08-09 15:07:54 -0700 | [diff] [blame] | 113 | Settings.Secure.DOZE_DOUBLE_TAP_GESTURE, |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 114 | true /* configured */, |
Lucas Dupin | 3d05353 | 2019-01-29 12:35:22 -0800 | [diff] [blame] | 115 | DozeLog.REASON_SENSOR_DOUBLE_TAP, |
Adrian Roos | 98d3198 | 2017-08-02 20:50:16 +0200 | [diff] [blame] | 116 | dozeParameters.doubleTapReportsTouchCoordinates(), |
| 117 | true /* touchscreen */), |
Adrian Roos | d0963a0 | 2017-05-15 14:33:37 -0700 | [diff] [blame] | 118 | new TriggerSensor( |
Lucas Dupin | d43bf70 | 2019-01-15 13:40:42 -0800 | [diff] [blame] | 119 | findSensorWithType(config.tapSensorType()), |
| 120 | Settings.Secure.DOZE_TAP_SCREEN_GESTURE, |
| 121 | true /* configured */, |
Lucas Dupin | 3d05353 | 2019-01-29 12:35:22 -0800 | [diff] [blame] | 122 | DozeLog.REASON_SENSOR_TAP, |
Lucas Dupin | d43bf70 | 2019-01-15 13:40:42 -0800 | [diff] [blame] | 123 | false /* reports touch coordinates */, |
| 124 | true /* touchscreen */), |
| 125 | new TriggerSensor( |
Adrian Roos | d0963a0 | 2017-05-15 14:33:37 -0700 | [diff] [blame] | 126 | findSensorWithType(config.longPressSensorType()), |
| 127 | Settings.Secure.DOZE_PULSE_ON_LONG_PRESS, |
| 128 | false /* settingDef */, |
| 129 | true /* configured */, |
| 130 | DozeLog.PULSE_REASON_SENSOR_LONG_PRESS, |
Adrian Roos | 98d3198 | 2017-08-02 20:50:16 +0200 | [diff] [blame] | 131 | true /* reports touch coordinates */, |
| 132 | true /* touchscreen */), |
Lucas Dupin | 1ae6cf9 | 2018-12-14 18:06:38 -0800 | [diff] [blame] | 133 | new PluginSensor( |
Lucas Dupin | b2d9f48 | 2018-11-16 18:55:13 -0800 | [diff] [blame] | 134 | new SensorManagerPlugin.Sensor(TYPE_WAKE_DISPLAY), |
Lucas Dupin | 7c7b8c2 | 2019-06-12 15:23:17 -0700 | [diff] [blame] | 135 | Settings.Secure.DOZE_WAKE_DISPLAY_GESTURE, |
Lucas Dupin | 70bda67 | 2018-12-27 15:43:40 -0800 | [diff] [blame] | 136 | mConfig.wakeScreenGestureAvailable() && alwaysOn, |
Lucas Dupin | b2d9f48 | 2018-11-16 18:55:13 -0800 | [diff] [blame] | 137 | DozeLog.REASON_SENSOR_WAKE_UP, |
| 138 | false /* reports touch coordinates */, |
| 139 | false /* touchscreen */), |
Lucas Dupin | de64ee0 | 2018-12-21 14:45:12 -0800 | [diff] [blame] | 140 | new PluginSensor( |
| 141 | new SensorManagerPlugin.Sensor(TYPE_WAKE_LOCK_SCREEN), |
Lucas Dupin | 7c7b8c2 | 2019-06-12 15:23:17 -0700 | [diff] [blame] | 142 | Settings.Secure.DOZE_WAKE_LOCK_SCREEN_GESTURE, |
| 143 | mConfig.wakeScreenGestureAvailable(), |
Lucas Dupin | de64ee0 | 2018-12-21 14:45:12 -0800 | [diff] [blame] | 144 | DozeLog.PULSE_REASON_SENSOR_WAKE_LOCK_SCREEN, |
| 145 | false /* reports touch coordinates */, |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 146 | false /* touchscreen */, mConfig.getWakeLockScreenDebounce()), |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 147 | }; |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 148 | |
jackqdyulei | 8443dd0 | 2017-08-24 16:14:34 -0700 | [diff] [blame] | 149 | mProxSensor = new ProxSensor(policy); |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 150 | mCallback = callback; |
| 151 | } |
| 152 | |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 153 | /** |
| 154 | * Temporarily disable some sensors to avoid turning on the device while the user is |
| 155 | * turning it off. |
| 156 | */ |
| 157 | public void requestTemporaryDisable() { |
| 158 | mDebounceFrom = SystemClock.uptimeMillis(); |
| 159 | } |
| 160 | |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 161 | private Sensor findSensorWithType(String type) { |
Adrian Roos | 2981eb0 | 2017-05-26 18:40:09 -0700 | [diff] [blame] | 162 | return findSensorWithType(mSensorManager, type); |
| 163 | } |
| 164 | |
| 165 | static Sensor findSensorWithType(SensorManager sensorManager, String type) { |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 166 | if (TextUtils.isEmpty(type)) { |
| 167 | return null; |
| 168 | } |
Adrian Roos | 2981eb0 | 2017-05-26 18:40:09 -0700 | [diff] [blame] | 169 | List<Sensor> sensorList = sensorManager.getSensorList(Sensor.TYPE_ALL); |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 170 | for (Sensor s : sensorList) { |
| 171 | if (type.equals(s.getStringType())) { |
| 172 | return s; |
| 173 | } |
| 174 | } |
| 175 | return null; |
| 176 | } |
| 177 | |
Lucas Dupin | fac2e8e | 2019-06-27 16:10:19 -0700 | [diff] [blame] | 178 | /** |
| 179 | * If sensors should be registered and sending signals. |
| 180 | */ |
Adrian Roos | d6ec1313 | 2016-10-27 11:50:47 -0700 | [diff] [blame] | 181 | public void setListening(boolean listen) { |
Lucas Dupin | fac2e8e | 2019-06-27 16:10:19 -0700 | [diff] [blame] | 182 | if (mListening == listen) { |
| 183 | return; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 184 | } |
Lucas Dupin | fac2e8e | 2019-06-27 16:10:19 -0700 | [diff] [blame] | 185 | mListening = listen; |
| 186 | updateListening(); |
| 187 | } |
| 188 | |
| 189 | /** |
| 190 | * Unregister sensors, when listening, unless they are prox gated. |
| 191 | * @see #setListening(boolean) |
| 192 | */ |
| 193 | public void setPaused(boolean paused) { |
| 194 | if (mPaused == paused) { |
| 195 | return; |
| 196 | } |
| 197 | mPaused = paused; |
| 198 | updateListening(); |
| 199 | } |
| 200 | |
Lucas Dupin | 3174c66 | 2019-07-15 15:49:54 -0700 | [diff] [blame] | 201 | /** |
| 202 | * Registers/unregisters sensors based on internal state. |
| 203 | */ |
| 204 | public void updateListening() { |
Lucas Dupin | fac2e8e | 2019-06-27 16:10:19 -0700 | [diff] [blame] | 205 | boolean anyListening = false; |
| 206 | for (TriggerSensor s : mSensors) { |
Lucas Dupin | f40bd8f | 2019-08-07 15:55:00 -0700 | [diff] [blame] | 207 | s.setListening(mListening); |
| 208 | if (mListening) { |
Lucas Dupin | fac2e8e | 2019-06-27 16:10:19 -0700 | [diff] [blame] | 209 | anyListening = true; |
| 210 | } |
| 211 | } |
| 212 | |
| 213 | if (!anyListening) { |
| 214 | mResolver.unregisterContentObserver(mSettingsObserver); |
| 215 | } else if (!mSettingRegistered) { |
| 216 | for (TriggerSensor s : mSensors) { |
| 217 | s.registerSettingsObserver(mSettingsObserver); |
| 218 | } |
| 219 | } |
| 220 | mSettingRegistered = anyListening; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 221 | } |
| 222 | |
Adrian Roos | 98d3198 | 2017-08-02 20:50:16 +0200 | [diff] [blame] | 223 | /** Set the listening state of only the sensors that require the touchscreen. */ |
| 224 | public void setTouchscreenSensorsListening(boolean listening) { |
| 225 | for (TriggerSensor sensor : mSensors) { |
| 226 | if (sensor.mRequiresTouchscreen) { |
| 227 | sensor.setListening(listening); |
| 228 | } |
| 229 | } |
| 230 | } |
| 231 | |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 232 | public void onUserSwitched() { |
| 233 | for (TriggerSensor s : mSensors) { |
Lucas Dupin | 3174c66 | 2019-07-15 15:49:54 -0700 | [diff] [blame] | 234 | s.updateListening(); |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 235 | } |
| 236 | } |
| 237 | |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 238 | public void setProxListening(boolean listen) { |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 239 | mProxSensor.setRequested(listen); |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 240 | } |
| 241 | |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 242 | private final ContentObserver mSettingsObserver = new ContentObserver(mHandler) { |
| 243 | @Override |
| 244 | public void onChange(boolean selfChange, Uri uri, int userId) { |
| 245 | if (userId != ActivityManager.getCurrentUser()) { |
| 246 | return; |
| 247 | } |
| 248 | for (TriggerSensor s : mSensors) { |
Lucas Dupin | 3174c66 | 2019-07-15 15:49:54 -0700 | [diff] [blame] | 249 | s.updateListening(); |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 250 | } |
| 251 | } |
| 252 | }; |
| 253 | |
| 254 | public void setDisableSensorsInterferingWithProximity(boolean disable) { |
| 255 | mPickupSensor.setDisabled(disable); |
| 256 | } |
| 257 | |
lpeter | 8a5f470 | 2019-01-18 16:53:07 +0800 | [diff] [blame] | 258 | /** Ignore the setting value of only the sensors that require the touchscreen. */ |
| 259 | public void ignoreTouchScreenSensorsSettingInterferingWithDocking(boolean ignore) { |
| 260 | for (TriggerSensor sensor : mSensors) { |
| 261 | if (sensor.mRequiresTouchscreen) { |
| 262 | sensor.ignoreSetting(ignore); |
| 263 | } |
| 264 | } |
| 265 | } |
| 266 | |
Adrian Roos | ff2c456 | 2016-11-03 12:13:36 -0700 | [diff] [blame] | 267 | /** Dump current state */ |
| 268 | public void dump(PrintWriter pw) { |
| 269 | for (TriggerSensor s : mSensors) { |
Lucas Dupin | dc13fe4 | 2019-04-10 16:07:50 -0700 | [diff] [blame] | 270 | pw.print(" Sensor: "); pw.println(s.toString()); |
Adrian Roos | ff2c456 | 2016-11-03 12:13:36 -0700 | [diff] [blame] | 271 | } |
Lucas Dupin | dc13fe4 | 2019-04-10 16:07:50 -0700 | [diff] [blame] | 272 | pw.print(" ProxSensor: "); pw.println(mProxSensor.toString()); |
Adrian Roos | ff2c456 | 2016-11-03 12:13:36 -0700 | [diff] [blame] | 273 | } |
| 274 | |
Adrian Roos | 70da03a | 2017-07-24 16:42:57 +0200 | [diff] [blame] | 275 | /** |
| 276 | * @return true if prox is currently far, false if near or null if unknown. |
| 277 | */ |
| 278 | public Boolean isProximityCurrentlyFar() { |
| 279 | return mProxSensor.mCurrentlyFar; |
| 280 | } |
| 281 | |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 282 | private class ProxSensor implements SensorEventListener { |
| 283 | |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 284 | boolean mRequested; |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 285 | boolean mRegistered; |
| 286 | Boolean mCurrentlyFar; |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 287 | long mLastNear; |
| 288 | final AlarmTimeout mCooldownTimer; |
jackqdyulei | 8443dd0 | 2017-08-24 16:14:34 -0700 | [diff] [blame] | 289 | final AlwaysOnDisplayPolicy mPolicy; |
Lucas Dupin | f61c104 | 2019-07-19 12:16:25 -0700 | [diff] [blame] | 290 | final Sensor mSensor; |
Lucas Dupin | cf06eb3 | 2019-08-12 14:14:08 -0700 | [diff] [blame] | 291 | final boolean mUsingBrightnessSensor; |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 292 | |
jackqdyulei | 8443dd0 | 2017-08-24 16:14:34 -0700 | [diff] [blame] | 293 | public ProxSensor(AlwaysOnDisplayPolicy policy) { |
| 294 | mPolicy = policy; |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 295 | mCooldownTimer = new AlarmTimeout(mAlarmManager, this::updateRegistered, |
| 296 | "prox_cooldown", mHandler); |
Lucas Dupin | f61c104 | 2019-07-19 12:16:25 -0700 | [diff] [blame] | 297 | |
| 298 | // The default prox sensor can be noisy, so let's use a prox gated brightness sensor |
| 299 | // if available. |
| 300 | Sensor sensor = DozeSensors.findSensorWithType(mSensorManager, |
| 301 | mContext.getString(R.string.doze_brightness_sensor_type)); |
Lucas Dupin | cf06eb3 | 2019-08-12 14:14:08 -0700 | [diff] [blame] | 302 | mUsingBrightnessSensor = sensor != null; |
Lucas Dupin | f61c104 | 2019-07-19 12:16:25 -0700 | [diff] [blame] | 303 | if (sensor == null) { |
| 304 | sensor = mSensorManager.getDefaultSensor(Sensor.TYPE_PROXIMITY); |
| 305 | } |
| 306 | mSensor = sensor; |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 307 | } |
| 308 | |
| 309 | void setRequested(boolean requested) { |
| 310 | if (mRequested == requested) { |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 311 | // Send an update even if we don't re-register. |
| 312 | mHandler.post(() -> { |
| 313 | if (mCurrentlyFar != null) { |
| 314 | mProxCallback.accept(mCurrentlyFar); |
| 315 | } |
| 316 | }); |
| 317 | return; |
| 318 | } |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 319 | mRequested = requested; |
| 320 | updateRegistered(); |
| 321 | } |
| 322 | |
| 323 | private void updateRegistered() { |
| 324 | setRegistered(mRequested && !mCooldownTimer.isScheduled()); |
| 325 | } |
| 326 | |
| 327 | private void setRegistered(boolean register) { |
| 328 | if (mRegistered == register) { |
| 329 | return; |
| 330 | } |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 331 | if (register) { |
Lucas Dupin | cf06eb3 | 2019-08-12 14:14:08 -0700 | [diff] [blame] | 332 | mRegistered = mSensorManager.registerListener(this, mSensor, |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 333 | SensorManager.SENSOR_DELAY_NORMAL, mHandler); |
| 334 | } else { |
| 335 | mSensorManager.unregisterListener(this); |
| 336 | mRegistered = false; |
| 337 | mCurrentlyFar = null; |
| 338 | } |
| 339 | } |
| 340 | |
| 341 | @Override |
Lucas Dupin | 1ae6cf9 | 2018-12-14 18:06:38 -0800 | [diff] [blame] | 342 | public void onSensorChanged(android.hardware.SensorEvent event) { |
Lucas Dupin | 5854384 | 2018-02-15 14:00:54 -0800 | [diff] [blame] | 343 | if (DEBUG) Log.d(TAG, "onSensorChanged " + event); |
| 344 | |
Lucas Dupin | cf06eb3 | 2019-08-12 14:14:08 -0700 | [diff] [blame] | 345 | if (mUsingBrightnessSensor) { |
| 346 | // The custom brightness sensor is gated by the proximity sensor and will return 0 |
| 347 | // whenever prox is covered. |
| 348 | mCurrentlyFar = event.values[0] > 0; |
| 349 | } else { |
| 350 | mCurrentlyFar = event.values[0] >= event.sensor.getMaximumRange(); |
| 351 | } |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 352 | mProxCallback.accept(mCurrentlyFar); |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 353 | |
| 354 | long now = SystemClock.elapsedRealtime(); |
Adrian Roos | 8f72b3c | 2017-07-07 12:20:21 +0200 | [diff] [blame] | 355 | if (mCurrentlyFar == null) { |
| 356 | // Sensor has been unregistered by the proxCallback. Do nothing. |
| 357 | } else if (!mCurrentlyFar) { |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 358 | mLastNear = now; |
jackqdyulei | 8443dd0 | 2017-08-24 16:14:34 -0700 | [diff] [blame] | 359 | } else if (mCurrentlyFar && now - mLastNear < mPolicy.proxCooldownTriggerMs) { |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 360 | // If the last near was very recent, we might be using more power for prox |
| 361 | // wakeups than we're saving from turning of the screen. Instead, turn it off |
| 362 | // for a while. |
jackqdyulei | 8443dd0 | 2017-08-24 16:14:34 -0700 | [diff] [blame] | 363 | mCooldownTimer.schedule(mPolicy.proxCooldownPeriodMs, |
| 364 | AlarmTimeout.MODE_IGNORE_IF_SCHEDULED); |
Adrian Roos | 6023ccb | 2017-06-28 16:22:02 +0200 | [diff] [blame] | 365 | updateRegistered(); |
| 366 | } |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 367 | } |
| 368 | |
| 369 | @Override |
| 370 | public void onAccuracyChanged(Sensor sensor, int accuracy) { |
| 371 | } |
Adrian Roos | 2ca9cd7 | 2017-07-03 15:14:37 +0200 | [diff] [blame] | 372 | |
| 373 | @Override |
| 374 | public String toString() { |
Lucas Dupin | f61c104 | 2019-07-19 12:16:25 -0700 | [diff] [blame] | 375 | return String.format("{registered=%s, requested=%s, coolingDown=%s, currentlyFar=%s," |
| 376 | + " sensor=%s}", mRegistered, mRequested, mCooldownTimer.isScheduled(), |
| 377 | mCurrentlyFar, mSensor); |
Adrian Roos | 2ca9cd7 | 2017-07-03 15:14:37 +0200 | [diff] [blame] | 378 | } |
Adrian Roos | 67cca74 | 2017-04-13 16:52:51 -0700 | [diff] [blame] | 379 | } |
| 380 | |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 381 | @VisibleForTesting |
| 382 | class TriggerSensor extends TriggerEventListener { |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 383 | final Sensor mSensor; |
| 384 | final boolean mConfigured; |
| 385 | final int mPulseReason; |
Lucas Dupin | fac2e8e | 2019-06-27 16:10:19 -0700 | [diff] [blame] | 386 | private final String mSetting; |
| 387 | private final boolean mReportsTouchCoordinates; |
| 388 | private final boolean mSettingDefault; |
| 389 | private final boolean mRequiresTouchscreen; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 390 | |
Lucas Dupin | 323f9ff | 2018-08-27 16:55:56 -0700 | [diff] [blame] | 391 | protected boolean mRequested; |
| 392 | protected boolean mRegistered; |
| 393 | protected boolean mDisabled; |
lpeter | 8a5f470 | 2019-01-18 16:53:07 +0800 | [diff] [blame] | 394 | protected boolean mIgnoresSetting; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 395 | |
Adrian Roos | 25c7a58 | 2017-06-02 12:50:38 -0700 | [diff] [blame] | 396 | public TriggerSensor(Sensor sensor, String setting, boolean configured, int pulseReason, |
Adrian Roos | 98d3198 | 2017-08-02 20:50:16 +0200 | [diff] [blame] | 397 | boolean reportsTouchCoordinates, boolean requiresTouchscreen) { |
Adrian Roos | d0963a0 | 2017-05-15 14:33:37 -0700 | [diff] [blame] | 398 | this(sensor, setting, true /* settingDef */, configured, pulseReason, |
Adrian Roos | 98d3198 | 2017-08-02 20:50:16 +0200 | [diff] [blame] | 399 | reportsTouchCoordinates, requiresTouchscreen); |
Adrian Roos | d0963a0 | 2017-05-15 14:33:37 -0700 | [diff] [blame] | 400 | } |
| 401 | |
| 402 | public TriggerSensor(Sensor sensor, String setting, boolean settingDef, |
Adrian Roos | 98d3198 | 2017-08-02 20:50:16 +0200 | [diff] [blame] | 403 | boolean configured, int pulseReason, boolean reportsTouchCoordinates, |
| 404 | boolean requiresTouchscreen) { |
lpeter | 8a5f470 | 2019-01-18 16:53:07 +0800 | [diff] [blame] | 405 | this(sensor, setting, settingDef, configured, pulseReason, reportsTouchCoordinates, |
Lucas Dupin | f40bd8f | 2019-08-07 15:55:00 -0700 | [diff] [blame] | 406 | requiresTouchscreen, false /* ignoresSetting */); |
lpeter | 8a5f470 | 2019-01-18 16:53:07 +0800 | [diff] [blame] | 407 | } |
| 408 | |
| 409 | private TriggerSensor(Sensor sensor, String setting, boolean settingDef, |
| 410 | boolean configured, int pulseReason, boolean reportsTouchCoordinates, |
Lucas Dupin | f40bd8f | 2019-08-07 15:55:00 -0700 | [diff] [blame] | 411 | boolean requiresTouchscreen, boolean ignoresSetting) { |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 412 | mSensor = sensor; |
| 413 | mSetting = setting; |
Adrian Roos | d0963a0 | 2017-05-15 14:33:37 -0700 | [diff] [blame] | 414 | mSettingDefault = settingDef; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 415 | mConfigured = configured; |
| 416 | mPulseReason = pulseReason; |
Adrian Roos | 25c7a58 | 2017-06-02 12:50:38 -0700 | [diff] [blame] | 417 | mReportsTouchCoordinates = reportsTouchCoordinates; |
Adrian Roos | 98d3198 | 2017-08-02 20:50:16 +0200 | [diff] [blame] | 418 | mRequiresTouchscreen = requiresTouchscreen; |
lpeter | 8a5f470 | 2019-01-18 16:53:07 +0800 | [diff] [blame] | 419 | mIgnoresSetting = ignoresSetting; |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 420 | } |
| 421 | |
| 422 | public void setListening(boolean listen) { |
| 423 | if (mRequested == listen) return; |
| 424 | mRequested = listen; |
Lucas Dupin | 3174c66 | 2019-07-15 15:49:54 -0700 | [diff] [blame] | 425 | updateListening(); |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 426 | } |
| 427 | |
| 428 | public void setDisabled(boolean disabled) { |
| 429 | if (mDisabled == disabled) return; |
| 430 | mDisabled = disabled; |
Lucas Dupin | 3174c66 | 2019-07-15 15:49:54 -0700 | [diff] [blame] | 431 | updateListening(); |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 432 | } |
| 433 | |
lpeter | 8a5f470 | 2019-01-18 16:53:07 +0800 | [diff] [blame] | 434 | public void ignoreSetting(boolean ignored) { |
| 435 | if (mIgnoresSetting == ignored) return; |
| 436 | mIgnoresSetting = ignored; |
Lucas Dupin | 3174c66 | 2019-07-15 15:49:54 -0700 | [diff] [blame] | 437 | updateListening(); |
lpeter | 8a5f470 | 2019-01-18 16:53:07 +0800 | [diff] [blame] | 438 | } |
| 439 | |
Lucas Dupin | 3174c66 | 2019-07-15 15:49:54 -0700 | [diff] [blame] | 440 | public void updateListening() { |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 441 | if (!mConfigured || mSensor == null) return; |
lpeter | 8a5f470 | 2019-01-18 16:53:07 +0800 | [diff] [blame] | 442 | if (mRequested && !mDisabled && (enabledBySetting() || mIgnoresSetting) |
| 443 | && !mRegistered) { |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 444 | mRegistered = mSensorManager.requestTriggerSensor(this, mSensor); |
| 445 | if (DEBUG) Log.d(TAG, "requestTriggerSensor " + mRegistered); |
| 446 | } else if (mRegistered) { |
| 447 | final boolean rt = mSensorManager.cancelTriggerSensor(this, mSensor); |
| 448 | if (DEBUG) Log.d(TAG, "cancelTriggerSensor " + rt); |
| 449 | mRegistered = false; |
| 450 | } |
| 451 | } |
| 452 | |
Lucas Dupin | 323f9ff | 2018-08-27 16:55:56 -0700 | [diff] [blame] | 453 | protected boolean enabledBySetting() { |
Jerry Chang | 5d3eb447 | 2018-12-21 11:49:06 +0800 | [diff] [blame] | 454 | if (!mConfig.enabled(UserHandle.USER_CURRENT)) { |
| 455 | return false; |
| 456 | } else if (TextUtils.isEmpty(mSetting)) { |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 457 | return true; |
| 458 | } |
Adrian Roos | d0963a0 | 2017-05-15 14:33:37 -0700 | [diff] [blame] | 459 | return Settings.Secure.getIntForUser(mResolver, mSetting, mSettingDefault ? 1 : 0, |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 460 | UserHandle.USER_CURRENT) != 0; |
| 461 | } |
| 462 | |
| 463 | @Override |
| 464 | public String toString() { |
| 465 | return new StringBuilder("{mRegistered=").append(mRegistered) |
| 466 | .append(", mRequested=").append(mRequested) |
| 467 | .append(", mDisabled=").append(mDisabled) |
| 468 | .append(", mConfigured=").append(mConfigured) |
lpeter | 8a5f470 | 2019-01-18 16:53:07 +0800 | [diff] [blame] | 469 | .append(", mIgnoresSetting=").append(mIgnoresSetting) |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 470 | .append(", mSensor=").append(mSensor).append("}").toString(); |
| 471 | } |
| 472 | |
| 473 | @Override |
| 474 | @AnyThread |
| 475 | public void onTrigger(TriggerEvent event) { |
Adrian Roos | 2ca9cd7 | 2017-07-03 15:14:37 +0200 | [diff] [blame] | 476 | DozeLog.traceSensor(mContext, mPulseReason); |
Adrian Roos | 79bacbb | 2016-10-26 11:00:12 -0700 | [diff] [blame] | 477 | mHandler.post(mWakeLock.wrap(() -> { |
Adrian Roos | d6ec1313 | 2016-10-27 11:50:47 -0700 | [diff] [blame] | 478 | if (DEBUG) Log.d(TAG, "onTrigger: " + triggerEventToString(event)); |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 479 | if (mSensor != null && mSensor.getType() == Sensor.TYPE_PICK_UP_GESTURE) { |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 480 | int subType = (int) event.values[0]; |
| 481 | MetricsLogger.action( |
Adrian Roos | 79bacbb | 2016-10-26 11:00:12 -0700 | [diff] [blame] | 482 | mContext, MetricsProto.MetricsEvent.ACTION_AMBIENT_GESTURE, |
| 483 | subType); |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 484 | } |
| 485 | |
| 486 | mRegistered = false; |
Adrian Roos | 25c7a58 | 2017-06-02 12:50:38 -0700 | [diff] [blame] | 487 | float screenX = -1; |
| 488 | float screenY = -1; |
| 489 | if (mReportsTouchCoordinates && event.values.length >= 2) { |
| 490 | screenX = event.values[0]; |
| 491 | screenY = event.values[1]; |
| 492 | } |
Lucas Dupin | f40bd8f | 2019-08-07 15:55:00 -0700 | [diff] [blame] | 493 | mCallback.onSensorPulse(mPulseReason, screenX, screenY, event.values); |
Lucas Dupin | 6510438 | 2018-12-04 11:53:42 -0800 | [diff] [blame] | 494 | if (!mRegistered) { |
Lucas Dupin | 3174c66 | 2019-07-15 15:49:54 -0700 | [diff] [blame] | 495 | updateListening(); // reregister, this sensor only fires once |
Lucas Dupin | 6510438 | 2018-12-04 11:53:42 -0800 | [diff] [blame] | 496 | } |
Adrian Roos | 79bacbb | 2016-10-26 11:00:12 -0700 | [diff] [blame] | 497 | })); |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 498 | } |
| 499 | |
| 500 | public void registerSettingsObserver(ContentObserver settingsObserver) { |
| 501 | if (mConfigured && !TextUtils.isEmpty(mSetting)) { |
| 502 | mResolver.registerContentObserver( |
| 503 | Settings.Secure.getUriFor(mSetting), false /* descendants */, |
| 504 | mSettingsObserver, UserHandle.USER_ALL); |
| 505 | } |
| 506 | } |
| 507 | |
Lucas Dupin | 323f9ff | 2018-08-27 16:55:56 -0700 | [diff] [blame] | 508 | protected String triggerEventToString(TriggerEvent event) { |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 509 | if (event == null) return null; |
Lucas Dupin | 1ae6cf9 | 2018-12-14 18:06:38 -0800 | [diff] [blame] | 510 | final StringBuilder sb = new StringBuilder("SensorEvent[") |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 511 | .append(event.timestamp).append(',') |
| 512 | .append(event.sensor.getName()); |
| 513 | if (event.values != null) { |
| 514 | for (int i = 0; i < event.values.length; i++) { |
| 515 | sb.append(',').append(event.values[i]); |
| 516 | } |
| 517 | } |
| 518 | return sb.append(']').toString(); |
| 519 | } |
| 520 | } |
| 521 | |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 522 | /** |
Kevin Chyn | f7c3903 | 2018-10-11 00:44:39 -0700 | [diff] [blame] | 523 | * A Sensor that is injected via plugin. |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 524 | */ |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 525 | @VisibleForTesting |
| 526 | class PluginSensor extends TriggerSensor implements SensorManagerPlugin.SensorEventListener { |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 527 | |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 528 | final SensorManagerPlugin.Sensor mPluginSensor; |
| 529 | private long mDebounce; |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 530 | |
Lucas Dupin | 1ae6cf9 | 2018-12-14 18:06:38 -0800 | [diff] [blame] | 531 | PluginSensor(SensorManagerPlugin.Sensor sensor, String setting, boolean configured, |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 532 | int pulseReason, boolean reportsTouchCoordinates, boolean requiresTouchscreen) { |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 533 | this(sensor, setting, configured, pulseReason, reportsTouchCoordinates, |
| 534 | requiresTouchscreen, 0L /* debounce */); |
| 535 | } |
| 536 | |
| 537 | PluginSensor(SensorManagerPlugin.Sensor sensor, String setting, boolean configured, |
| 538 | int pulseReason, boolean reportsTouchCoordinates, boolean requiresTouchscreen, |
| 539 | long debounce) { |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 540 | super(null, setting, configured, pulseReason, reportsTouchCoordinates, |
| 541 | requiresTouchscreen); |
| 542 | mPluginSensor = sensor; |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 543 | mDebounce = debounce; |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 544 | } |
| 545 | |
| 546 | @Override |
Lucas Dupin | 3174c66 | 2019-07-15 15:49:54 -0700 | [diff] [blame] | 547 | public void updateListening() { |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 548 | if (!mConfigured) return; |
| 549 | AsyncSensorManager asyncSensorManager = (AsyncSensorManager) mSensorManager; |
lpeter | 8a5f470 | 2019-01-18 16:53:07 +0800 | [diff] [blame] | 550 | if (mRequested && !mDisabled && (enabledBySetting() || mIgnoresSetting) |
| 551 | && !mRegistered) { |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 552 | asyncSensorManager.registerPluginListener(mPluginSensor, this); |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 553 | mRegistered = true; |
Lucas Dupin | 1ae6cf9 | 2018-12-14 18:06:38 -0800 | [diff] [blame] | 554 | if (DEBUG) Log.d(TAG, "registerPluginListener"); |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 555 | } else if (mRegistered) { |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 556 | asyncSensorManager.unregisterPluginListener(mPluginSensor, this); |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 557 | mRegistered = false; |
Lucas Dupin | 1ae6cf9 | 2018-12-14 18:06:38 -0800 | [diff] [blame] | 558 | if (DEBUG) Log.d(TAG, "unregisterPluginListener"); |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 559 | } |
| 560 | } |
| 561 | |
| 562 | @Override |
| 563 | public String toString() { |
| 564 | return new StringBuilder("{mRegistered=").append(mRegistered) |
| 565 | .append(", mRequested=").append(mRequested) |
| 566 | .append(", mDisabled=").append(mDisabled) |
| 567 | .append(", mConfigured=").append(mConfigured) |
lpeter | 8a5f470 | 2019-01-18 16:53:07 +0800 | [diff] [blame] | 568 | .append(", mIgnoresSetting=").append(mIgnoresSetting) |
Lucas Dupin | 3d95175 | 2018-10-10 12:00:40 -0700 | [diff] [blame] | 569 | .append(", mSensor=").append(mPluginSensor).append("}").toString(); |
| 570 | } |
| 571 | |
Lucas Dupin | 1ae6cf9 | 2018-12-14 18:06:38 -0800 | [diff] [blame] | 572 | private String triggerEventToString(SensorManagerPlugin.SensorEvent event) { |
Lucas Dupin | b2d9f48 | 2018-11-16 18:55:13 -0800 | [diff] [blame] | 573 | if (event == null) return null; |
| 574 | final StringBuilder sb = new StringBuilder("PluginTriggerEvent[") |
| 575 | .append(event.getSensor()).append(',') |
| 576 | .append(event.getVendorType()); |
| 577 | if (event.getValues() != null) { |
| 578 | for (int i = 0; i < event.getValues().length; i++) { |
| 579 | sb.append(',').append(event.getValues()[i]); |
| 580 | } |
| 581 | } |
| 582 | return sb.append(']').toString(); |
Lucas Dupin | 323f9ff | 2018-08-27 16:55:56 -0700 | [diff] [blame] | 583 | } |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 584 | |
| 585 | @Override |
| 586 | public void onSensorChanged(SensorManagerPlugin.SensorEvent event) { |
| 587 | DozeLog.traceSensor(mContext, mPulseReason); |
| 588 | mHandler.post(mWakeLock.wrap(() -> { |
| 589 | final long now = SystemClock.uptimeMillis(); |
| 590 | if (now < mDebounceFrom + mDebounce) { |
Lucas Dupin | bca7ec7 | 2019-05-30 10:24:54 -0700 | [diff] [blame] | 591 | Log.d(TAG, "onSensorEvent dropped: " + triggerEventToString(event)); |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 592 | return; |
| 593 | } |
| 594 | if (DEBUG) Log.d(TAG, "onSensorEvent: " + triggerEventToString(event)); |
Lucas Dupin | f40bd8f | 2019-08-07 15:55:00 -0700 | [diff] [blame] | 595 | mCallback.onSensorPulse(mPulseReason, -1, -1, event.getValues()); |
Lucas Dupin | 8a13aa7 | 2019-02-22 12:45:21 -0800 | [diff] [blame] | 596 | })); |
| 597 | } |
Lucas Dupin | 323f9ff | 2018-08-27 16:55:56 -0700 | [diff] [blame] | 598 | } |
| 599 | |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 600 | public interface Callback { |
Adrian Roos | d6ec1313 | 2016-10-27 11:50:47 -0700 | [diff] [blame] | 601 | |
| 602 | /** |
| 603 | * Called when a sensor requests a pulse |
Lucas Dupin | 3d05353 | 2019-01-29 12:35:22 -0800 | [diff] [blame] | 604 | * @param pulseReason Requesting sensor, e.g. {@link DozeLog#REASON_SENSOR_PICKUP} |
Adrian Roos | 25c7a58 | 2017-06-02 12:50:38 -0700 | [diff] [blame] | 605 | * @param screenX the location on the screen where the sensor fired or -1 |
Lucas Dupin | f40bd8f | 2019-08-07 15:55:00 -0700 | [diff] [blame] | 606 | * if the sensor doesn't support reporting screen locations. |
Adrian Roos | 25c7a58 | 2017-06-02 12:50:38 -0700 | [diff] [blame] | 607 | * @param screenY the location on the screen where the sensor fired or -1 |
Lucas Dupin | b2d9f48 | 2018-11-16 18:55:13 -0800 | [diff] [blame] | 608 | * @param rawValues raw values array from the event. |
Adrian Roos | d6ec1313 | 2016-10-27 11:50:47 -0700 | [diff] [blame] | 609 | */ |
Lucas Dupin | f40bd8f | 2019-08-07 15:55:00 -0700 | [diff] [blame] | 610 | void onSensorPulse(int pulseReason, float screenX, float screenY, float[] rawValues); |
Adrian Roos | ea8d6ae | 2016-10-26 10:40:12 -0700 | [diff] [blame] | 611 | } |
| 612 | } |