This logic is triggered by two scenarios:
(A) During first bootup after OTA update to Android 16, if the
user had HCT enabled.
- Trigger: ACTION_PRE_BOOT_COMPLETED.
- Migration: HCT is disabled and notification is shown.
(B) Restore backup from Android 15 (or earlier), if the backup
had HCT enabled and new device does not.
- Trigger: SettingsProvider's restore process.
- Migration: HCT is not restored and notification is shown.
We store whether the user has seen this notification in a new secure
setting ACCESSIBILITY_HCT_SHOW_PROMPT. This setting is also backed up.
Bug: 369906140
Flag: com.android.graphics.hwui.flags.high_contrast_text_small_text_rect
Test: atest SettingsRoboTests:com.android.settings.accessibility.HighContrastTextMigrationReceiverTest
Test: flash an incremental update on a build with HCT enabled;
observe HCT is disabled and a notification is sent.
Test: flash an incremental update on a build with HCT disabled;
observe no change to HCT and no notification.
Change-Id: I4d294ffc0b2eabc59ee7988a579d678975a16380
108 lines
3.9 KiB
Java
108 lines
3.9 KiB
Java
/*
|
|
* Copyright (C) 2019 The Android Open Source 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.accessibility;
|
|
|
|
import android.content.Context;
|
|
import android.provider.Settings;
|
|
|
|
import androidx.preference.PreferenceScreen;
|
|
import androidx.preference.TwoStatePreference;
|
|
|
|
import com.android.graphics.hwui.flags.Flags;
|
|
import com.android.settings.R;
|
|
import com.android.settings.accessibility.TextReadingPreferenceFragment.EntryPoint;
|
|
import com.android.settings.core.TogglePreferenceController;
|
|
import com.android.settings.core.instrumentation.SettingsStatsLog;
|
|
|
|
/**
|
|
* PreferenceController for displaying all text in high contrast style.
|
|
*/
|
|
public class HighTextContrastPreferenceController extends TogglePreferenceController implements
|
|
TextReadingResetController.ResetStateListener {
|
|
private TwoStatePreference mSwitchPreference;
|
|
|
|
@EntryPoint
|
|
private int mEntryPoint;
|
|
|
|
public HighTextContrastPreferenceController(Context context, String preferenceKey) {
|
|
super(context, preferenceKey);
|
|
}
|
|
|
|
@Override
|
|
public int getAvailabilityStatus() {
|
|
return AVAILABLE;
|
|
}
|
|
|
|
@Override
|
|
public boolean isChecked() {
|
|
return Settings.Secure.getInt(mContext.getContentResolver(),
|
|
Settings.Secure.ACCESSIBILITY_HIGH_TEXT_CONTRAST_ENABLED, 0) == 1;
|
|
}
|
|
|
|
@Override
|
|
public boolean setChecked(boolean isChecked) {
|
|
SettingsStatsLog.write(
|
|
SettingsStatsLog.ACCESSIBILITY_TEXT_READING_OPTIONS_CHANGED,
|
|
AccessibilityStatsLogUtils.convertToItemKeyName(getPreferenceKey()),
|
|
isChecked ? 1 : 0,
|
|
AccessibilityStatsLogUtils.convertToEntryPoint(mEntryPoint));
|
|
|
|
if (Flags.highContrastTextSmallTextRect()) {
|
|
// Set PROMPT_UNNECESSARY when the user modifies the HighContrastText setting
|
|
// This is needed for the following scenario:
|
|
// On Android 16, create secondary user, ACTION_PRE_BOOT_COMPLETED won't be sent to
|
|
// the secondary user. The user enables HCT.
|
|
// When updating OS to Android 17, ACTION_PRE_BOOT_COMPLETED will be sent to the
|
|
// secondary user when switch to the secondary user.
|
|
// If the prompt status is not updated in Android 16, we would automatically disable
|
|
// HCT and show the HCT prompt, which is an undesired behavior.
|
|
Settings.Secure.putInt(mContext.getContentResolver(),
|
|
Settings.Secure.ACCESSIBILITY_HCT_RECT_PROMPT_STATUS,
|
|
HighContrastTextMigrationReceiver.PromptState.PROMPT_UNNECESSARY);
|
|
}
|
|
|
|
return Settings.Secure.putInt(mContext.getContentResolver(),
|
|
Settings.Secure.ACCESSIBILITY_HIGH_TEXT_CONTRAST_ENABLED, (isChecked ? 1 : 0));
|
|
}
|
|
|
|
@Override
|
|
public int getSliceHighlightMenuRes() {
|
|
return R.string.menu_key_accessibility;
|
|
}
|
|
|
|
@Override
|
|
public void displayPreference(PreferenceScreen screen) {
|
|
super.displayPreference(screen);
|
|
mSwitchPreference = screen.findPreference(getPreferenceKey());
|
|
}
|
|
|
|
@Override
|
|
public void resetState() {
|
|
setChecked(false);
|
|
updateState(mSwitchPreference);
|
|
}
|
|
|
|
/**
|
|
* The entry point is used for logging.
|
|
*
|
|
* @param entryPoint from which settings page
|
|
*/
|
|
void setEntryPoint(@EntryPoint int entryPoint) {
|
|
mEntryPoint = entryPoint;
|
|
}
|
|
}
|