diff --git a/res/values/evolution_arrays.xml b/res/values/evolution_arrays.xml index ef0a8d9e475..2ae1a16816c 100644 --- a/res/values/evolution_arrays.xml +++ b/res/values/evolution_arrays.xml @@ -118,4 +118,21 @@ 600000 1800000 + + + + @string/string_disabled + @string/night_display_auto_mode_twilight + @string/always_on_display_schedule_mixed_sunset + @string/always_on_display_schedule_mixed_sunrise + @string/night_display_auto_mode_custom + + + + 0 + 1 + 3 + 4 + 2 + diff --git a/res/values/evolution_strings.xml b/res/values/evolution_strings.xml index 84ea3f54cb2..664a18c1569 100644 --- a/res/values/evolution_strings.xml +++ b/res/values/evolution_strings.xml @@ -274,4 +274,12 @@ Calls Alarms steps + + + Always on display schedule + Disabled + Sunset + Sunrise + Turns on from sunset till a time + Turns on from a time till sunrise diff --git a/res/xml/always_on_display_schedule.xml b/res/xml/always_on_display_schedule.xml new file mode 100644 index 00000000000..127099f71ab --- /dev/null +++ b/res/xml/always_on_display_schedule.xml @@ -0,0 +1,33 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/res/xml/security_lockscreen_settings.xml b/res/xml/security_lockscreen_settings.xml index 6a736f2a1f8..64d54e57474 100644 --- a/res/xml/security_lockscreen_settings.xml +++ b/res/xml/security_lockscreen_settings.xml @@ -118,6 +118,12 @@ android:summary="@string/doze_on_charge_summary" android:defaultValue="false" /> + + + updateTimeSetting(isSince, hourOfDay, minute1); + final TimePickerDialog dialog = new TimePickerDialog(getContext(), listener, + hour, minute, DateFormat.is24HourFormat(getContext())); + dialog.show(); + return true; + } + + private String[] getCustomTimeSetting() { + final String value = Settings.Secure.getStringForUser(getActivity().getContentResolver(), + Settings.Secure.DOZE_ALWAYS_ON_AUTO_TIME, UserHandle.USER_CURRENT); + if (value == null || value.isEmpty()) return new String[] { "20:00", "07:00" }; + return value.split(",", 0); + } + + private void updateTimeEnablement(int mode) { + mSincePref.setEnabled(mode == MODE_TIME || mode == MODE_MIXED_SUNRISE); + mTillPref.setEnabled(mode == MODE_TIME || mode == MODE_MIXED_SUNSET); + } + + private void updateTimeSummary(int mode) { + updateTimeSummary(getCustomTimeSetting(), mode); + } + + private void updateTimeSummary(String[] times, int mode) { + if (mode == MODE_DISABLED) { + mSincePref.setSummary("-"); + mTillPref.setSummary("-"); + return; + } + + if (mode == MODE_NIGHT) { + mSincePref.setSummary(R.string.always_on_display_schedule_sunset); + mTillPref.setSummary(R.string.always_on_display_schedule_sunrise); + return; + } + + final String outputFormat = DateFormat.is24HourFormat(getContext()) ? "HH:mm" : "hh:mm a"; + final DateTimeFormatter outputFormatter = DateTimeFormatter.ofPattern(outputFormat); + final DateTimeFormatter formatter = DateTimeFormatter.ofPattern("HH:mm"); + final LocalTime sinceDT = LocalTime.parse(times[0], formatter); + final LocalTime tillDT = LocalTime.parse(times[1], formatter); + + if (mode == MODE_MIXED_SUNSET) { + mSincePref.setSummary(R.string.always_on_display_schedule_sunset); + mTillPref.setSummary(tillDT.format(outputFormatter)); + } else if (mode == MODE_MIXED_SUNRISE) { + mTillPref.setSummary(R.string.always_on_display_schedule_sunrise); + mSincePref.setSummary(sinceDT.format(outputFormatter)); + } else { + mSincePref.setSummary(sinceDT.format(outputFormatter)); + mTillPref.setSummary(tillDT.format(outputFormatter)); + } + } + + private void updateTimeSetting(boolean since, int hour, int minute) { + final String[] times = getCustomTimeSetting(); + String nHour = ""; + String nMinute = ""; + if (hour < 10) nHour += "0"; + if (minute < 10) nMinute += "0"; + nHour += String.valueOf(hour); + nMinute += String.valueOf(minute); + times[since ? 0 : 1] = nHour + ":" + nMinute; + Settings.Secure.putStringForUser(getActivity().getContentResolver(), + Settings.Secure.DOZE_ALWAYS_ON_AUTO_TIME, + times[0] + "," + times[1], UserHandle.USER_CURRENT); + updateTimeSummary(times, Integer.parseInt(mModePref.getValue())); + } +} diff --git a/src/com/android/settings/display/AODSchedulePreferenceController.kt b/src/com/android/settings/display/AODSchedulePreferenceController.kt new file mode 100644 index 00000000000..a1d991d0d88 --- /dev/null +++ b/src/com/android/settings/display/AODSchedulePreferenceController.kt @@ -0,0 +1,76 @@ +/* + * Copyright (C) 2021 Yet Another AOSP Project + * Copyright (C) 2022 FlamingoOS Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the + * License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the specific language governing + * permissions and limitations under the License. + */ + +package com.android.settings.display + +import android.content.Context +import android.hardware.display.AmbientDisplayConfiguration +import android.os.SystemProperties +import android.os.UserHandle +import android.provider.Settings + +import com.android.settings.R +import com.android.settings.core.BasePreferenceController + +class AODSchedulePreferenceController( + context: Context, + key: String, +) : BasePreferenceController(context, key) { + + private var ambientDisplayConfig: AmbientDisplayConfiguration? = null + + override fun getAvailabilityStatus() = + if (isAODAvailable()) AVAILABLE else UNSUPPORTED_ON_DEVICE + + override fun getSummary(): CharSequence { + val mode = Settings.Secure.getIntForUser(mContext.contentResolver, + Settings.Secure.DOZE_ALWAYS_ON_AUTO_MODE, 0, UserHandle.USER_CURRENT) + return when (mode) { + MODE_NIGHT -> mContext.getString(R.string.night_display_auto_mode_twilight) + MODE_TIME -> mContext.getString(R.string.night_display_auto_mode_custom) + MODE_MIXED_SUNSET -> mContext.getString(R.string.always_on_display_schedule_mixed_sunset) + MODE_MIXED_SUNRISE -> mContext.getString(R.string.always_on_display_schedule_mixed_sunrise) + else -> mContext.getString(R.string.string_disabled) + } + } + + fun setConfig(config: AmbientDisplayConfiguration): AODSchedulePreferenceController { + ambientDisplayConfig = config + return this + } + + private fun getConfig(): AmbientDisplayConfiguration { + if (ambientDisplayConfig == null) { + ambientDisplayConfig = AmbientDisplayConfiguration(mContext) + } + return ambientDisplayConfig!! + } + + private fun isAODAvailable(): Boolean { + return getConfig().alwaysOnAvailableForUser(UserHandle.myUserId()) && + !SystemProperties.getBoolean(PROP_AWARE_AVAILABLE, false) + } + + companion object { + const val MODE_DISABLED = 0 + const val MODE_NIGHT = 1 + const val MODE_TIME = 2 + const val MODE_MIXED_SUNSET = 3 + const val MODE_MIXED_SUNRISE = 4 + + private const val PROP_AWARE_AVAILABLE = "ro.vendor.aware_available" + } +} diff --git a/src/com/android/settings/security/LockscreenDashboardFragment.java b/src/com/android/settings/security/LockscreenDashboardFragment.java index 0e547603727..a0c9d3891aa 100644 --- a/src/com/android/settings/security/LockscreenDashboardFragment.java +++ b/src/com/android/settings/security/LockscreenDashboardFragment.java @@ -39,6 +39,7 @@ import com.android.settings.R; import com.android.settings.dashboard.DashboardFragment; import com.android.settings.display.AmbientDisplayAlwaysOnPreferenceController; import com.android.settings.display.AmbientDisplayNotificationsPreferenceController; +import com.android.settings.display.AODSchedulePreferenceController; import com.android.settings.gestures.DoubleTapScreenPreferenceController; import com.android.settings.gestures.PickupGesturePreferenceController; import com.android.settings.notification.LockScreenNotificationPreferenceController; @@ -59,7 +60,6 @@ import org.evolution.settings.utils.DeviceUtils; @SearchIndexable public class LockscreenDashboardFragment extends DashboardFragment implements OwnerInfoPreferenceController.OwnerInfoCallback { - private static final String TAG = "LockscreenDashboardFragment"; @VisibleForTesting @@ -133,6 +133,7 @@ public class LockscreenDashboardFragment extends DashboardFragment use(AmbientDisplayNotificationsPreferenceController.class).setConfig(getConfig(context)); use(DoubleTapScreenPreferenceController.class).setConfig(getConfig(context)); use(PickupGesturePreferenceController.class).setConfig(getConfig(context)); + use(AODSchedulePreferenceController.class).setConfig(getConfig(context)); mControlsContentObserver = new ContentObserver( new Handler(Looper.getMainLooper())) {