blob: 110646936e336ecde32c3eb34a72e987aa7c0de5 [file] [log] [blame]
Joseph Pirozzo317343d2016-01-25 10:22:37 -08001/*
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
14 * limitations under the License.
15 */
16
17package com.android.car;
18
Yao Chene33f07e2016-07-26 12:02:51 -070019import android.annotation.IntDef;
Joseph Pirozzo317343d2016-01-25 10:22:37 -080020import android.app.UiModeManager;
Steve Paik4d257022018-04-27 13:28:31 -070021import android.car.hardware.CarPropertyValue;
22import android.car.hardware.property.CarPropertyEvent;
23import android.car.hardware.property.ICarPropertyEventListener;
Joseph Pirozzo317343d2016-01-25 10:22:37 -080024import android.content.Context;
Steve Paik4d257022018-04-27 13:28:31 -070025import android.hardware.automotive.vehicle.V2_0.VehicleProperty;
26import android.os.RemoteException;
Felipe Leme176a5fd2021-01-20 15:48:33 -080027import android.util.IndentingPrintWriter;
Eric Jeongbd5fb562020-12-21 13:49:40 -080028import android.util.Slog;
Joseph Pirozzo317343d2016-01-25 10:22:37 -080029
Antonio Kantekb0de6ce2019-11-18 19:41:35 -080030import com.android.internal.annotations.GuardedBy;
31
Yao Chene33f07e2016-07-26 12:02:51 -070032import java.lang.annotation.Retention;
33import java.lang.annotation.RetentionPolicy;
Joseph Pirozzo317343d2016-01-25 10:22:37 -080034import java.util.List;
35
Antonio Kantekb0de6ce2019-11-18 19:41:35 -080036/**
37 * Class used to handle events used to set vehicle in night mode.
38 */
Joseph Pirozzo317343d2016-01-25 10:22:37 -080039public class CarNightService implements CarServiceBase {
40
Keun-young Park9ec05472016-04-26 21:18:18 -070041 public static final boolean DBG = false;
Yao Chene33f07e2016-07-26 12:02:51 -070042
43 @IntDef({FORCED_SENSOR_MODE, FORCED_DAY_MODE, FORCED_NIGHT_MODE})
44 @Retention(RetentionPolicy.SOURCE)
45 public @interface DayNightSensorMode {}
46
47 public static final int FORCED_SENSOR_MODE = 0;
48 public static final int FORCED_DAY_MODE = 1;
49 public static final int FORCED_NIGHT_MODE = 2;
50
Antonio Kantekb0de6ce2019-11-18 19:41:35 -080051 private final Object mLock = new Object();
52 @GuardedBy("mLock")
Joseph Pirozzo317343d2016-01-25 10:22:37 -080053 private int mNightSetting = UiModeManager.MODE_NIGHT_YES;
Antonio Kantekb0de6ce2019-11-18 19:41:35 -080054 @GuardedBy("mLock")
Yao Chene33f07e2016-07-26 12:02:51 -070055 private int mForcedMode = FORCED_SENSOR_MODE;
Antonio Kantekb0de6ce2019-11-18 19:41:35 -080056 @GuardedBy("mLock")
Kaia4481e12019-10-17 17:45:39 -070057 private long mLastSensorEventTime = -1;
Joseph Pirozzo317343d2016-01-25 10:22:37 -080058 private final Context mContext;
Antonio Kantekb0de6ce2019-11-18 19:41:35 -080059 @GuardedBy("mLock")
Joseph Pirozzo317343d2016-01-25 10:22:37 -080060 private final UiModeManager mUiModeManager;
Antonio Kantekb0de6ce2019-11-18 19:41:35 -080061 private final CarPropertyService mCarPropertyService;
Joseph Pirozzo317343d2016-01-25 10:22:37 -080062
Steve Paik4d257022018-04-27 13:28:31 -070063 private final ICarPropertyEventListener mICarPropertyEventListener =
64 new ICarPropertyEventListener.Stub() {
Antonio Kantekb0de6ce2019-11-18 19:41:35 -080065 @Override
66 public void onEvent(List<CarPropertyEvent> events) throws RemoteException {
67 synchronized (mLock) {
68 for (CarPropertyEvent event : events) {
69 onNightModeCarPropertyEventLocked(event);
70 }
71 }
72 }
73 };
Joseph Pirozzo317343d2016-01-25 10:22:37 -080074
Steve Paik4d257022018-04-27 13:28:31 -070075 /**
Antonio Kantekb0de6ce2019-11-18 19:41:35 -080076 * Acts on {@link CarPropertyEvent} events marked with
77 * {@link CarPropertyEvent.PROPERTY_EVENT_PROPERTY_CHANGE} and marked with {@link
78 * VehicleProperty.NIGHT_MODE} by
79 * setting the vehicle in night mode.
80 * <p>
81 * This method does nothing if the event parameter is {@code null}.
82 *
83 * @param event the car property event to be handled
Steve Paik4d257022018-04-27 13:28:31 -070084 */
Antonio Kantekb0de6ce2019-11-18 19:41:35 -080085 @GuardedBy("mLock")
86 private void onNightModeCarPropertyEventLocked(CarPropertyEvent event) {
Joseph Pirozzo317343d2016-01-25 10:22:37 -080087 if (event == null) {
88 return;
89 }
Steve Paik4d257022018-04-27 13:28:31 -070090 if (event.getEventType() == CarPropertyEvent.PROPERTY_EVENT_PROPERTY_CHANGE) {
91 // Only handle onChange events
92 CarPropertyValue value = event.getCarPropertyValue();
Kaia4481e12019-10-17 17:45:39 -070093 if (value.getPropertyId() == VehicleProperty.NIGHT_MODE
94 && value.getTimestamp() > mLastSensorEventTime) {
95 mLastSensorEventTime = value.getTimestamp();
Steve Paik4d257022018-04-27 13:28:31 -070096 boolean nightMode = (Boolean) value.getValue();
Eric Jeongbd5fb562020-12-21 13:49:40 -080097 Slog.i(CarLog.TAG_SENSOR, "Set dayNight Mode as "
Kaia4481e12019-10-17 17:45:39 -070098 + nightMode + " at timestamp: " + mLastSensorEventTime);
Antonio Kantekb0de6ce2019-11-18 19:41:35 -080099 setNightModeLocked(nightMode);
Joseph Pirozzo317343d2016-01-25 10:22:37 -0800100 }
101 }
102 }
103
Antonio Kantekb0de6ce2019-11-18 19:41:35 -0800104 @GuardedBy("mLock")
105 private void setNightModeLocked(boolean nightMode) {
Kai46f42a72018-06-22 14:41:57 -0700106 if (nightMode) {
107 mNightSetting = UiModeManager.MODE_NIGHT_YES;
Eric Jeongbd5fb562020-12-21 13:49:40 -0800108 if (DBG) Slog.d(CarLog.TAG_SENSOR, "CAR dayNight handleSensorEvent NIGHT");
Kai46f42a72018-06-22 14:41:57 -0700109 } else {
110 mNightSetting = UiModeManager.MODE_NIGHT_NO;
Eric Jeongbd5fb562020-12-21 13:49:40 -0800111 if (DBG) Slog.d(CarLog.TAG_SENSOR, "CAR dayNight handleSensorEvent DAY");
Kai46f42a72018-06-22 14:41:57 -0700112 }
113 if (mUiModeManager != null && (mForcedMode == FORCED_SENSOR_MODE)) {
114 mUiModeManager.setNightMode(mNightSetting);
Eric Jeongbd5fb562020-12-21 13:49:40 -0800115 if (DBG) Slog.d(CarLog.TAG_SENSOR, "CAR dayNight handleSensorEvent APPLIED");
Kai46f42a72018-06-22 14:41:57 -0700116 } else {
Eric Jeongbd5fb562020-12-21 13:49:40 -0800117 if (DBG) Slog.d(CarLog.TAG_SENSOR, "CAR dayNight handleSensorEvent IGNORED");
Kai46f42a72018-06-22 14:41:57 -0700118 }
119 }
120
Antonio Kantekb0de6ce2019-11-18 19:41:35 -0800121 /**
122 * Sets {@link UiModeManager} to night mode according to the {@link DayNightSensorMode} passed
123 * as parameter.
124 *
125 * @param mode the sensor mode used to set vehicle in night mode
126 * @return the current night mode, or {@code -1} on error
127 */
128 public int forceDayNightMode(@DayNightSensorMode int mode) {
129 synchronized (mLock) {
130 if (mUiModeManager == null) {
Yao Chene33f07e2016-07-26 12:02:51 -0700131 return -1;
Antonio Kantekb0de6ce2019-11-18 19:41:35 -0800132 }
133 int resultMode;
134 switch (mode) {
135 case FORCED_SENSOR_MODE:
136 resultMode = mNightSetting;
137 mForcedMode = FORCED_SENSOR_MODE;
138 break;
139 case FORCED_DAY_MODE:
140 resultMode = UiModeManager.MODE_NIGHT_NO;
141 mForcedMode = FORCED_DAY_MODE;
142 break;
143 case FORCED_NIGHT_MODE:
144 resultMode = UiModeManager.MODE_NIGHT_YES;
145 mForcedMode = FORCED_NIGHT_MODE;
146 break;
147 default:
Eric Jeongbd5fb562020-12-21 13:49:40 -0800148 Slog.e(CarLog.TAG_SENSOR, "Unknown forced day/night mode " + mode);
Antonio Kantekb0de6ce2019-11-18 19:41:35 -0800149 return -1;
150 }
151 mUiModeManager.setNightMode(resultMode);
152 return mUiModeManager.getNightMode();
Yao Chene33f07e2016-07-26 12:02:51 -0700153 }
Yao Chene33f07e2016-07-26 12:02:51 -0700154 }
155
Steve Paik4d257022018-04-27 13:28:31 -0700156 CarNightService(Context context, CarPropertyService propertyService) {
Joseph Pirozzo317343d2016-01-25 10:22:37 -0800157 mContext = context;
Steve Paik4d257022018-04-27 13:28:31 -0700158 mCarPropertyService = propertyService;
Joseph Pirozzo317343d2016-01-25 10:22:37 -0800159 mUiModeManager = (UiModeManager) mContext.getSystemService(Context.UI_MODE_SERVICE);
160 if (mUiModeManager == null) {
Eric Jeongbd5fb562020-12-21 13:49:40 -0800161 Slog.w(CarLog.TAG_SENSOR, "Failed to get UI_MODE_SERVICE");
Joseph Pirozzo317343d2016-01-25 10:22:37 -0800162 }
163 }
164
165 @Override
Antonio Kantekb0de6ce2019-11-18 19:41:35 -0800166 public void init() {
Joseph Pirozzo317343d2016-01-25 10:22:37 -0800167 if (DBG) {
Eric Jeongbd5fb562020-12-21 13:49:40 -0800168 Slog.d(CarLog.TAG_SENSOR, "CAR dayNight init.");
Joseph Pirozzo317343d2016-01-25 10:22:37 -0800169 }
Antonio Kantekb0de6ce2019-11-18 19:41:35 -0800170 synchronized (mLock) {
171 mCarPropertyService.registerListener(VehicleProperty.NIGHT_MODE, 0,
172 mICarPropertyEventListener);
Kai Wang301dd472021-05-18 06:09:44 +0000173 CarPropertyValue propertyValue = mCarPropertyService.getPropertySafe(
Antonio Kantekb0de6ce2019-11-18 19:41:35 -0800174 VehicleProperty.NIGHT_MODE, 0);
175 if (propertyValue != null && propertyValue.getTimestamp() != 0) {
176 mLastSensorEventTime = propertyValue.getTimestamp();
177 setNightModeLocked((Boolean) propertyValue.getValue());
178 } else {
Eric Jeongbd5fb562020-12-21 13:49:40 -0800179 Slog.w(CarLog.TAG_SENSOR, "Failed to get value of NIGHT_MODE");
Antonio Kantekb0de6ce2019-11-18 19:41:35 -0800180 setNightModeLocked(true);
181 }
Kai46f42a72018-06-22 14:41:57 -0700182 }
Joseph Pirozzo317343d2016-01-25 10:22:37 -0800183 }
184
185 @Override
Antonio Kantekb0de6ce2019-11-18 19:41:35 -0800186 public void release() {
Joseph Pirozzo317343d2016-01-25 10:22:37 -0800187 }
188
189 @Override
Felipe Leme176a5fd2021-01-20 15:48:33 -0800190 public void dump(IndentingPrintWriter writer) {
Antonio Kantekb0de6ce2019-11-18 19:41:35 -0800191 synchronized (mLock) {
192 writer.println("*DAY NIGHT POLICY*");
193 writer.println(
194 "Mode:" + ((mNightSetting == UiModeManager.MODE_NIGHT_YES) ? "night" : "day"));
195 writer.println("Forced Mode? " + (mForcedMode == FORCED_SENSOR_MODE
196 ? "false, timestamp of dayNight sensor is: " + mLastSensorEventTime
197 : (mForcedMode == FORCED_DAY_MODE ? "day" : "night")));
198 }
Joseph Pirozzo317343d2016-01-25 10:22:37 -0800199 }
200}
Antonio Kantekb0de6ce2019-11-18 19:41:35 -0800201