Color correction improvement (2/n)
Implement RadioButtonPreference and its controller to replace ListPreference New strings for accessibility daltonizer service - radio button title and summary Bug: 145968068 Test: make RunSettingsRoboTests ROBOTEST_FILTER=DaltonizerPreferenceControllerTest Change-Id: Ic91d8648906f35991682a259879095cbbd4cc678
This commit is contained in:
@@ -1014,19 +1014,19 @@
|
|||||||
<item>\?</item>
|
<item>\?</item>
|
||||||
</string-array>
|
</string-array>
|
||||||
|
|
||||||
<!-- Display color space adjustment modes for accessibility -->
|
<!-- Keys for color space adjustment modes for accessibility -->
|
||||||
<string-array name="daltonizer_type_entries" translatable="false">
|
<string-array name="daltonizer_mode_keys" translatable="false">
|
||||||
<item>@string/daltonizer_mode_deuteranomaly</item>
|
<item>daltonizer_mode_deuteranomaly</item>
|
||||||
<item>@string/daltonizer_mode_protanomaly</item>
|
<item>daltonizer_mode_protanomaly</item>
|
||||||
<item>@string/daltonizer_mode_tritanomaly</item>
|
<item>daltonizer_mode_tritanomaly</item>
|
||||||
</string-array>
|
</string-array>
|
||||||
|
|
||||||
<!-- Values for display color space adjustment modes for accessibility -->
|
<!-- Values for display color space adjustment modes for accessibility -->
|
||||||
<string-array name="daltonizer_type_values" translatable="false">
|
<integer-array name="daltonizer_type_values" translatable="false">
|
||||||
<item>12</item>
|
<item>12</item>
|
||||||
<item>11</item>
|
<item>11</item>
|
||||||
<item>13</item>
|
<item>13</item>
|
||||||
</string-array>
|
</integer-array>
|
||||||
|
|
||||||
<!-- Battery saver mode: allowable trigger threshold levels. -->
|
<!-- Battery saver mode: allowable trigger threshold levels. -->
|
||||||
<integer-array name="battery_saver_trigger_values" translatable="false" >
|
<integer-array name="battery_saver_trigger_values" translatable="false" >
|
||||||
|
@@ -4922,6 +4922,18 @@
|
|||||||
<string name="enable_quick_setting">Show in Quick Settings</string>
|
<string name="enable_quick_setting">Show in Quick Settings</string>
|
||||||
<!-- Title for the preference to configure the type of color space correction to apply. [CHAR LIMIT=NONE] -->
|
<!-- Title for the preference to configure the type of color space correction to apply. [CHAR LIMIT=NONE] -->
|
||||||
<string name="daltonizer_type">Correction mode</string>
|
<string name="daltonizer_type">Correction mode</string>
|
||||||
|
<!-- Title shown for deuteranomaly (red-green color blindness) [CHAR LIMIT=45] -->
|
||||||
|
<string name="daltonizer_mode_deuteranomaly_title">Red-green</string>
|
||||||
|
<!-- Title shown for protanomaly (red-green color blindness) [CHAR LIMIT=45] -->
|
||||||
|
<string name="daltonizer_mode_protanomaly_title">Green-red</string>
|
||||||
|
<!-- Title shown for tritanomaly (blue-yellow color blindness) [CHAR LIMIT=45] -->
|
||||||
|
<string name="daltonizer_mode_tritanomaly_title">Blue-yellow</string>
|
||||||
|
<!-- Summary shown for deuteranomaly (red-green color blindness) [CHAR LIMIT=45] -->
|
||||||
|
<string name="daltonizer_mode_deuteranomaly_summary">Deuteranomaly</string>
|
||||||
|
<!-- Summary shown for protanomaly (red-green color blindness) [CHAR LIMIT=45] -->
|
||||||
|
<string name="daltonizer_mode_protanomaly_summary">Protanomaly</string>
|
||||||
|
<!-- Summary shown for tritanomaly (blue-yellow color blindness) [CHAR LIMIT=45] -->
|
||||||
|
<string name="daltonizer_mode_tritanomaly_summary">Tritanomaly</string>
|
||||||
|
|
||||||
<!-- Subtitle for the accessibility preference to configure feature that performs click action soon after mouse/trackpad pointer stops moving, in case delay before click is extremely short. Placeholder will be set to the number of milliseconds to which the delay amounts. [CHAR LIMIT=NONE] -->
|
<!-- Subtitle for the accessibility preference to configure feature that performs click action soon after mouse/trackpad pointer stops moving, in case delay before click is extremely short. Placeholder will be set to the number of milliseconds to which the delay amounts. [CHAR LIMIT=NONE] -->
|
||||||
<plurals name="accessibilty_autoclick_preference_subtitle_extremely_short_delay">
|
<plurals name="accessibilty_autoclick_preference_subtitle_extremely_short_delay">
|
||||||
|
@@ -18,19 +18,32 @@
|
|||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:settings="http://schemas.android.com/apk/res-auto"
|
xmlns:settings="http://schemas.android.com/apk/res-auto"
|
||||||
android:key="daltonizer_preference_screen"
|
android:key="daltonizer_preference_screen"
|
||||||
|
android:persistent="false"
|
||||||
android:title="@string/accessibility_display_daltonizer_preference_title">
|
android:title="@string/accessibility_display_daltonizer_preference_title">
|
||||||
|
|
||||||
<ListPreference
|
<com.android.settingslib.widget.RadioButtonPreference
|
||||||
android:entries="@array/daltonizer_type_entries"
|
android:key="daltonizer_mode_deuteranomaly"
|
||||||
android:entryValues="@array/daltonizer_type_values"
|
android:persistent="false"
|
||||||
android:key="type"
|
android:summary="@string/daltonizer_mode_deuteranomaly_summary"
|
||||||
android:summary="%s"
|
android:title="@string/daltonizer_mode_deuteranomaly_title"
|
||||||
android:title="@string/daltonizer_type"
|
settings:allowDividerAbove="true" />
|
||||||
android:icon="@drawable/ic_accessibility_illustration_colorblind" />
|
|
||||||
|
<com.android.settingslib.widget.RadioButtonPreference
|
||||||
|
android:key="daltonizer_mode_protanomaly"
|
||||||
|
android:persistent="false"
|
||||||
|
android:summary="@string/daltonizer_mode_protanomaly_summary"
|
||||||
|
android:title="@string/daltonizer_mode_protanomaly_title" />
|
||||||
|
|
||||||
|
<com.android.settingslib.widget.RadioButtonPreference
|
||||||
|
android:key="daltonizer_mode_tritanomaly"
|
||||||
|
android:persistent="false"
|
||||||
|
android:summary="@string/daltonizer_mode_tritanomaly_summary"
|
||||||
|
android:title="@string/daltonizer_mode_tritanomaly_title" />
|
||||||
|
|
||||||
<com.android.settingslib.widget.FooterPreference
|
<com.android.settingslib.widget.FooterPreference
|
||||||
android:key="daltonizer_footer"
|
android:key="daltonizer_footer"
|
||||||
android:title="@string/accessibility_display_daltonizer_preference_subtitle"
|
android:persistent="false"
|
||||||
android:selectable="false"
|
android:selectable="false"
|
||||||
settings:searchable="false"/>
|
android:title="@string/accessibility_display_daltonizer_preference_subtitle"
|
||||||
|
settings:searchable="false" />
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
@@ -18,68 +18,78 @@
|
|||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:settings="http://schemas.android.com/apk/res-auto"
|
xmlns:settings="http://schemas.android.com/apk/res-auto"
|
||||||
android:key="accessibility_settings_screen"
|
android:key="accessibility_settings_screen"
|
||||||
android:title="@string/accessibility_settings"
|
android:persistent="false"
|
||||||
android:persistent="true">
|
android:title="@string/accessibility_settings">
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="accessibility_shortcut_preference"
|
|
||||||
android:title="@string/accessibility_global_gesture_preference_title"
|
|
||||||
android:fragment="com.android.settings.accessibility.AccessibilityShortcutPreferenceFragment"
|
android:fragment="com.android.settings.accessibility.AccessibilityShortcutPreferenceFragment"
|
||||||
|
android:key="accessibility_shortcut_preference"
|
||||||
|
android:persistent="false"
|
||||||
|
android:title="@string/accessibility_global_gesture_preference_title"
|
||||||
settings:controller="com.android.settings.accessibility.AccessibilityShortcutPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.AccessibilityShortcutPreferenceController"/>
|
||||||
|
|
||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
android:key="user_installed_services_category"
|
android:key="user_installed_services_category"
|
||||||
android:title="@string/user_installed_services_category_title">
|
android:persistent="false"
|
||||||
</PreferenceCategory>
|
android:title="@string/user_installed_services_category_title"/>
|
||||||
|
|
||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
android:key="screen_reader_category"
|
android:key="screen_reader_category"
|
||||||
|
android:persistent="false"
|
||||||
android:title="@string/screen_reader_category_title">
|
android:title="@string/screen_reader_category_title">
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="tts_settings_preference"
|
|
||||||
android:title="@string/tts_settings_title"
|
|
||||||
android:fragment="com.android.settings.tts.TextToSpeechSettings"
|
android:fragment="com.android.settings.tts.TextToSpeechSettings"
|
||||||
|
android:key="tts_settings_preference"
|
||||||
|
android:persistent="false"
|
||||||
|
android:title="@string/tts_settings_title"
|
||||||
settings:controller="com.android.settings.language.TtsPreferenceController"/>
|
settings:controller="com.android.settings.language.TtsPreferenceController"/>
|
||||||
</PreferenceCategory>
|
</PreferenceCategory>
|
||||||
|
|
||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
android:key="display_category"
|
android:key="display_category"
|
||||||
|
android:persistent="false"
|
||||||
android:title="@string/display_category_title">
|
android:title="@string/display_category_title">
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="font_size_preference_screen"
|
|
||||||
android:title="@string/title_font_size"
|
|
||||||
android:fragment="com.android.settings.display.ToggleFontSizePreferenceFragment"
|
android:fragment="com.android.settings.display.ToggleFontSizePreferenceFragment"
|
||||||
|
android:key="font_size_preference_screen"
|
||||||
|
android:persistent="false"
|
||||||
|
android:title="@string/title_font_size"
|
||||||
settings:controller="com.android.settings.display.FontSizePreferenceController"
|
settings:controller="com.android.settings.display.FontSizePreferenceController"
|
||||||
settings:searchable="false"/>
|
settings:searchable="false"/>
|
||||||
|
|
||||||
<com.android.settings.display.ScreenZoomPreference
|
<com.android.settings.display.ScreenZoomPreference
|
||||||
android:key="accessibility_settings_screen_zoom"
|
|
||||||
android:fragment="com.android.settings.display.ScreenZoomSettings"
|
android:fragment="com.android.settings.display.ScreenZoomSettings"
|
||||||
|
android:key="accessibility_settings_screen_zoom"
|
||||||
|
android:persistent="false"
|
||||||
android:title="@string/screen_zoom_title"
|
android:title="@string/screen_zoom_title"
|
||||||
settings:searchable="false"/>
|
settings:searchable="false"/>
|
||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="dark_ui_mode_accessibility"
|
android:key="dark_ui_mode_accessibility"
|
||||||
|
android:persistent="false"
|
||||||
android:title="@string/dark_ui_mode"
|
android:title="@string/dark_ui_mode"
|
||||||
settings:controller="com.android.settings.display.DarkUIPreferenceController"
|
settings:controller="com.android.settings.display.DarkUIPreferenceController"
|
||||||
settings:searchable="false"/>
|
settings:searchable="false"/>
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="magnification_preference_screen"
|
|
||||||
android:title="@string/accessibility_screen_magnification_title"
|
|
||||||
android:icon="@drawable/ic_accessibility_magnification"
|
|
||||||
android:fragment="com.android.settings.accessibility.MagnificationPreferenceFragment"
|
android:fragment="com.android.settings.accessibility.MagnificationPreferenceFragment"
|
||||||
|
android:icon="@drawable/ic_accessibility_magnification"
|
||||||
|
android:key="magnification_preference_screen"
|
||||||
|
android:persistent="false"
|
||||||
|
android:title="@string/accessibility_screen_magnification_title"
|
||||||
settings:controller="com.android.settings.accessibility.MagnificationPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.MagnificationPreferenceController"/>
|
||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="toggle_large_pointer_icon"
|
android:key="toggle_large_pointer_icon"
|
||||||
|
android:persistent="false"
|
||||||
android:title="@string/accessibility_toggle_large_pointer_icon_title"
|
android:title="@string/accessibility_toggle_large_pointer_icon_title"
|
||||||
settings:controller="com.android.settings.accessibility.LargePointerIconPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.LargePointerIconPreferenceController"/>
|
||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="toggle_disable_animations"
|
android:key="toggle_disable_animations"
|
||||||
|
android:persistent="false"
|
||||||
android:title="@string/accessibility_disable_animations"
|
android:title="@string/accessibility_disable_animations"
|
||||||
settings:controller="com.android.settings.accessibility.DisableAnimationsPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.DisableAnimationsPreferenceController"/>
|
||||||
|
|
||||||
@@ -87,111 +97,124 @@
|
|||||||
|
|
||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
android:key="interaction_control_category"
|
android:key="interaction_control_category"
|
||||||
|
android:persistent="false"
|
||||||
android:title="@string/interaction_control_category_title">
|
android:title="@string/interaction_control_category_title">
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="autoclick_preference"
|
|
||||||
android:title="@string/accessibility_autoclick_preference_title"
|
|
||||||
android:fragment="com.android.settings.accessibility.ToggleAutoclickPreferenceFragment"
|
android:fragment="com.android.settings.accessibility.ToggleAutoclickPreferenceFragment"
|
||||||
|
android:key="autoclick_preference"
|
||||||
|
android:persistent="false"
|
||||||
|
android:title="@string/accessibility_autoclick_preference_title"
|
||||||
settings:controller="com.android.settings.accessibility.AutoclickPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.AutoclickPreferenceController"/>
|
||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="toggle_power_button_ends_call_preference"
|
android:key="toggle_power_button_ends_call_preference"
|
||||||
android:title="@string/accessibility_power_button_ends_call_prerefence_title"
|
|
||||||
android:persistent="false"
|
android:persistent="false"
|
||||||
|
android:title="@string/accessibility_power_button_ends_call_prerefence_title"
|
||||||
settings:controller="com.android.settings.accessibility.PowerButtonEndsCallPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.PowerButtonEndsCallPreferenceController"/>
|
||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="toggle_lock_screen_rotation_preference"
|
android:key="toggle_lock_screen_rotation_preference"
|
||||||
android:title="@string/accelerometer_title"
|
|
||||||
android:persistent="false"
|
android:persistent="false"
|
||||||
|
android:title="@string/accelerometer_title"
|
||||||
settings:controller="com.android.settings.accessibility.LockScreenRotationPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.LockScreenRotationPreferenceController"/>
|
||||||
|
|
||||||
<ListPreference
|
<ListPreference
|
||||||
android:key="select_long_press_timeout_preference"
|
|
||||||
android:title="@string/accessibility_long_press_timeout_preference_title"
|
|
||||||
android:entries="@array/long_press_timeout_selector_titles"
|
android:entries="@array/long_press_timeout_selector_titles"
|
||||||
android:entryValues="@array/long_press_timeout_selector_values"
|
android:entryValues="@array/long_press_timeout_selector_values"
|
||||||
|
android:key="select_long_press_timeout_preference"
|
||||||
android:persistent="false"
|
android:persistent="false"
|
||||||
|
android:title="@string/accessibility_long_press_timeout_preference_title"
|
||||||
settings:controller="com.android.settings.accessibility.SelectLongPressTimeoutPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.SelectLongPressTimeoutPreferenceController"/>
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="accessibility_control_timeout_preference_fragment"
|
|
||||||
android:title="@string/accessibility_setting_item_control_timeout_title"
|
|
||||||
android:persistent="false"
|
|
||||||
android:fragment="com.android.settings.accessibility.AccessibilityControlTimeoutPreferenceFragment"
|
android:fragment="com.android.settings.accessibility.AccessibilityControlTimeoutPreferenceFragment"
|
||||||
|
android:key="accessibility_control_timeout_preference_fragment"
|
||||||
|
android:persistent="false"
|
||||||
|
android:title="@string/accessibility_setting_item_control_timeout_title"
|
||||||
settings:controller="com.android.settings.accessibility.AccessibilityTimeoutPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.AccessibilityTimeoutPreferenceController"/>
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="vibration_preference_screen"
|
|
||||||
android:title="@string/accessibility_vibration_settings_title"
|
|
||||||
android:fragment="com.android.settings.accessibility.VibrationSettings"
|
android:fragment="com.android.settings.accessibility.VibrationSettings"
|
||||||
|
android:key="vibration_preference_screen"
|
||||||
|
android:persistent="false"
|
||||||
|
android:title="@string/accessibility_vibration_settings_title"
|
||||||
settings:controller="com.android.settings.accessibility.VibrationPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.VibrationPreferenceController"/>
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="gesture_system_navigation_input_summary_accessibility"
|
|
||||||
android:title="@string/system_navigation_title"
|
|
||||||
android:fragment="com.android.settings.gestures.SystemNavigationGestureSettings"
|
android:fragment="com.android.settings.gestures.SystemNavigationGestureSettings"
|
||||||
settings:controller="com.android.settings.gestures.SystemNavigationPreferenceController" />
|
android:key="gesture_system_navigation_input_summary_accessibility"
|
||||||
|
android:persistent="false"
|
||||||
|
android:title="@string/system_navigation_title"
|
||||||
|
settings:controller="com.android.settings.gestures.SystemNavigationPreferenceController"/>
|
||||||
|
|
||||||
</PreferenceCategory>
|
</PreferenceCategory>
|
||||||
|
|
||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
android:key="audio_and_captions_category"
|
android:key="audio_and_captions_category"
|
||||||
|
android:persistent="false"
|
||||||
android:title="@string/audio_and_captions_category_title">
|
android:title="@string/audio_and_captions_category_title">
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="live_caption"
|
android:key="live_caption"
|
||||||
android:title="@string/live_caption_title"
|
android:persistent="false"
|
||||||
android:summary="@string/live_caption_summary"
|
android:summary="@string/live_caption_summary"
|
||||||
|
android:title="@string/live_caption_title"
|
||||||
settings:controller="com.android.settings.accessibility.LiveCaptionPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.LiveCaptionPreferenceController"/>
|
||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="toggle_master_mono"
|
android:key="toggle_master_mono"
|
||||||
android:title="@string/accessibility_toggle_master_mono_title"
|
|
||||||
android:summary="@string/accessibility_toggle_master_mono_summary"
|
|
||||||
android:persistent="false"
|
android:persistent="false"
|
||||||
|
android:summary="@string/accessibility_toggle_master_mono_summary"
|
||||||
|
android:title="@string/accessibility_toggle_master_mono_title"
|
||||||
settings:controller="com.android.settings.accessibility.MasterMonoPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.MasterMonoPreferenceController"/>
|
||||||
|
|
||||||
<com.android.settings.accessibility.BalanceSeekBarPreference
|
<com.android.settings.accessibility.BalanceSeekBarPreference
|
||||||
android:key="seekbar_master_balance"
|
android:key="seekbar_master_balance"
|
||||||
|
android:persistent="false"
|
||||||
android:title="@string/accessibility_toggle_master_balance_title"/>
|
android:title="@string/accessibility_toggle_master_balance_title"/>
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="hearing_aid_preference"
|
android:key="hearing_aid_preference"
|
||||||
|
android:persistent="false"
|
||||||
android:summary="@string/accessibility_hearingaid_not_connected_summary"
|
android:summary="@string/accessibility_hearingaid_not_connected_summary"
|
||||||
android:title="@string/accessibility_hearingaid_title"
|
android:title="@string/accessibility_hearingaid_title"
|
||||||
settings:controller="com.android.settings.accessibility.AccessibilityHearingAidPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.AccessibilityHearingAidPreferenceController"/>
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="captioning_preference_screen"
|
|
||||||
android:title="@string/accessibility_captioning_title"
|
|
||||||
android:fragment="com.android.settings.accessibility.CaptionPropertiesFragment"
|
android:fragment="com.android.settings.accessibility.CaptionPropertiesFragment"
|
||||||
|
android:key="captioning_preference_screen"
|
||||||
|
android:persistent="false"
|
||||||
|
android:title="@string/accessibility_captioning_title"
|
||||||
settings:controller="com.android.settings.accessibility.CaptioningPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.CaptioningPreferenceController"/>
|
||||||
|
|
||||||
</PreferenceCategory>
|
</PreferenceCategory>
|
||||||
|
|
||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
android:key="experimental_category"
|
android:key="experimental_category"
|
||||||
|
android:persistent="false"
|
||||||
android:title="@string/experimental_category_title">
|
android:title="@string/experimental_category_title">
|
||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="toggle_high_text_contrast_preference"
|
android:key="toggle_high_text_contrast_preference"
|
||||||
|
android:persistent="false"
|
||||||
android:title="@string/accessibility_toggle_high_text_contrast_preference_title"
|
android:title="@string/accessibility_toggle_high_text_contrast_preference_title"
|
||||||
settings:controller="com.android.settings.accessibility.HighTextContrastPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.HighTextContrastPreferenceController"/>
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="daltonizer_preference"
|
|
||||||
android:title="@string/accessibility_display_daltonizer_preference_title"
|
|
||||||
android:icon="@drawable/ic_daltonizer"
|
|
||||||
android:fragment="com.android.settings.accessibility.ToggleDaltonizerPreferenceFragment"
|
android:fragment="com.android.settings.accessibility.ToggleDaltonizerPreferenceFragment"
|
||||||
|
android:icon="@drawable/ic_daltonizer"
|
||||||
|
android:key="daltonizer_preference"
|
||||||
|
android:persistent="false"
|
||||||
|
android:title="@string/accessibility_display_daltonizer_preference_title"
|
||||||
settings:controller="com.android.settings.accessibility.DaltonizerPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.DaltonizerPreferenceController"/>
|
||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="toggle_inversion_preference"
|
|
||||||
android:title="@string/accessibility_display_inversion_preference_title"
|
|
||||||
android:summary="@string/accessibility_display_inversion_preference_subtitle"
|
|
||||||
android:persistent="false"
|
|
||||||
android:icon="@drawable/ic_color_inversion"
|
android:icon="@drawable/ic_color_inversion"
|
||||||
|
android:key="toggle_inversion_preference"
|
||||||
|
android:persistent="false"
|
||||||
|
android:summary="@string/accessibility_display_inversion_preference_subtitle"
|
||||||
|
android:title="@string/accessibility_display_inversion_preference_title"
|
||||||
settings:controller="com.android.settings.accessibility.ColorInversionPreferenceController"/>
|
settings:controller="com.android.settings.accessibility.ColorInversionPreferenceController"/>
|
||||||
</PreferenceCategory>
|
</PreferenceCategory>
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
@@ -16,25 +16,143 @@
|
|||||||
|
|
||||||
package com.android.settings.accessibility;
|
package com.android.settings.accessibility;
|
||||||
|
|
||||||
|
import android.content.ContentResolver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.res.Resources;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
import android.view.accessibility.AccessibilityManager;
|
||||||
|
|
||||||
|
import androidx.lifecycle.LifecycleObserver;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
|
import com.android.settingslib.widget.RadioButtonPreference;
|
||||||
|
|
||||||
public class DaltonizerPreferenceController extends BasePreferenceController {
|
import com.google.common.primitives.Ints;
|
||||||
|
|
||||||
public DaltonizerPreferenceController(Context context, String preferenceKey) {
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/** Controller class that control accessibility daltonizer settings. */
|
||||||
|
public class DaltonizerPreferenceController extends BasePreferenceController implements
|
||||||
|
LifecycleObserver, RadioButtonPreference.OnClickListener {
|
||||||
|
private static final String TYPE = Settings.Secure.ACCESSIBILITY_DISPLAY_DALTONIZER;
|
||||||
|
|
||||||
|
// pair the preference key and daltonizer value.
|
||||||
|
private final Map<String, Integer> mAccessibilityDaltonizerKeyToValueMap = new HashMap<>();
|
||||||
|
|
||||||
|
// RadioButtonPreference key, each preference represent a daltonizer value.
|
||||||
|
private final ContentResolver mContentResolver;
|
||||||
|
private final Resources mResources;
|
||||||
|
private DaltonizerPreferenceController.OnChangeListener mOnChangeListener;
|
||||||
|
private RadioButtonPreference mPreference;
|
||||||
|
private int mAccessibilityDaltonizerValue;
|
||||||
|
|
||||||
|
public DaltonizerPreferenceController(Context context, Lifecycle lifecycle,
|
||||||
|
String preferenceKey) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
|
|
||||||
|
mContentResolver = context.getContentResolver();
|
||||||
|
mResources = context.getResources();
|
||||||
|
|
||||||
|
if (lifecycle != null) {
|
||||||
|
lifecycle.addObserver(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected static int getSecureAccessibilityDaltonizerValue(ContentResolver resolver,
|
||||||
|
String name) {
|
||||||
|
final String daltonizerStringValue = Settings.Secure.getString(resolver, name);
|
||||||
|
if (daltonizerStringValue == null) {
|
||||||
|
return AccessibilityManager.DALTONIZER_CORRECT_DEUTERANOMALY;
|
||||||
|
}
|
||||||
|
final Integer daltonizerIntValue = Ints.tryParse(daltonizerStringValue);
|
||||||
|
return daltonizerIntValue == null ? AccessibilityManager.DALTONIZER_CORRECT_DEUTERANOMALY
|
||||||
|
: daltonizerIntValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setOnChangeListener(DaltonizerPreferenceController.OnChangeListener listener) {
|
||||||
|
mOnChangeListener = listener;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Map<String, Integer> getDaltonizerValueToKeyMap() {
|
||||||
|
if (mAccessibilityDaltonizerKeyToValueMap.size() == 0) {
|
||||||
|
|
||||||
|
final String[] daltonizerKeys = mResources.getStringArray(
|
||||||
|
R.array.daltonizer_mode_keys);
|
||||||
|
|
||||||
|
final int[] daltonizerValues = mResources.getIntArray(
|
||||||
|
R.array.daltonizer_type_values);
|
||||||
|
|
||||||
|
final int daltonizerValueCount = daltonizerValues.length;
|
||||||
|
for (int i = 0; i < daltonizerValueCount; i++) {
|
||||||
|
mAccessibilityDaltonizerKeyToValueMap.put(daltonizerKeys[i], daltonizerValues[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return mAccessibilityDaltonizerKeyToValueMap;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void putSecureString(String name, String value) {
|
||||||
|
Settings.Secure.putString(mContentResolver, name, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void handlePreferenceChange(String value) {
|
||||||
|
putSecureString(TYPE, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
return AVAILABLE_UNSEARCHABLE;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CharSequence getSummary() {
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
return AccessibilityUtil.getSummary(mContext,
|
super.displayPreference(screen);
|
||||||
Settings.Secure.ACCESSIBILITY_DISPLAY_DALTONIZER_ENABLED);
|
mPreference = (RadioButtonPreference)
|
||||||
|
screen.findPreference(getPreferenceKey());
|
||||||
|
mPreference.setOnClickListener(this);
|
||||||
|
updateState(mPreference);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onRadioButtonClicked(RadioButtonPreference preference) {
|
||||||
|
final int value = getDaltonizerValueToKeyMap().get(mPreferenceKey);
|
||||||
|
handlePreferenceChange(String.valueOf(value));
|
||||||
|
if (mOnChangeListener != null) {
|
||||||
|
mOnChangeListener.onCheckedChanged(mPreference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private int getAccessibilityDaltonizerValue() {
|
||||||
|
final int daltonizerValue = getSecureAccessibilityDaltonizerValue(mContentResolver,
|
||||||
|
TYPE);
|
||||||
|
return daltonizerValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void updatePreferenceCheckedState(int value) {
|
||||||
|
if (mAccessibilityDaltonizerValue == value) {
|
||||||
|
mPreference.setChecked(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateState(Preference preference) {
|
||||||
|
super.updateState(preference);
|
||||||
|
mAccessibilityDaltonizerValue = getAccessibilityDaltonizerValue();
|
||||||
|
|
||||||
|
// reset RadioButton
|
||||||
|
mPreference.setChecked(false);
|
||||||
|
final int preferenceValue = getDaltonizerValueToKeyMap().get(mPreference.getKey());
|
||||||
|
updatePreferenceCheckedState(preferenceValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Listener interface handles checked event. */
|
||||||
|
public interface OnChangeListener {
|
||||||
|
/** A hook that is called when preference checked.*/
|
||||||
|
void onCheckedChanged(Preference preference);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@@ -18,34 +18,56 @@ package com.android.settings.accessibility;
|
|||||||
|
|
||||||
import android.app.settings.SettingsEnums;
|
import android.app.settings.SettingsEnums;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.hardware.display.ColorDisplayManager;
|
import android.content.res.Resources;
|
||||||
import android.os.Bundle;
|
|
||||||
import android.provider.SearchIndexableResource;
|
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.view.accessibility.AccessibilityManager;
|
|
||||||
import android.widget.Switch;
|
import android.widget.Switch;
|
||||||
|
|
||||||
import androidx.preference.ListPreference;
|
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.search.BaseSearchIndexProvider;
|
import com.android.settings.search.BaseSearchIndexProvider;
|
||||||
import com.android.settingslib.search.Indexable;
|
|
||||||
import com.android.settings.widget.SwitchBar;
|
import com.android.settings.widget.SwitchBar;
|
||||||
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
import com.android.settingslib.search.SearchIndexable;
|
import com.android.settingslib.search.SearchIndexable;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@SearchIndexable
|
@SearchIndexable
|
||||||
public class ToggleDaltonizerPreferenceFragment extends ToggleFeaturePreferenceFragment
|
public final class ToggleDaltonizerPreferenceFragment extends ToggleFeaturePreferenceFragment
|
||||||
implements Preference.OnPreferenceChangeListener, SwitchBar.OnSwitchChangeListener {
|
implements DaltonizerPreferenceController.OnChangeListener,
|
||||||
private static final String ENABLED = Settings.Secure.ACCESSIBILITY_DISPLAY_DALTONIZER_ENABLED;
|
SwitchBar.OnSwitchChangeListener {
|
||||||
private static final String TYPE = Settings.Secure.ACCESSIBILITY_DISPLAY_DALTONIZER;
|
|
||||||
private static final int DEFAULT_TYPE = AccessibilityManager.DALTONIZER_CORRECT_DEUTERANOMALY;
|
|
||||||
private static final String KEY_DALTONIZER_FOOTER = "daltonizer_footer";
|
|
||||||
|
|
||||||
private ListPreference mType;
|
private static final String ENABLED = Settings.Secure.ACCESSIBILITY_DISPLAY_DALTONIZER_ENABLED;
|
||||||
|
|
||||||
|
private static final List<AbstractPreferenceController> sControllers = new ArrayList<>();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCheckedChanged(Preference preference) {
|
||||||
|
for (AbstractPreferenceController controller : sControllers) {
|
||||||
|
controller.updateState(preference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onResume() {
|
||||||
|
super.onResume();
|
||||||
|
for (AbstractPreferenceController controller :
|
||||||
|
buildPreferenceControllers(getPrefContext(), getSettingsLifecycle())) {
|
||||||
|
((DaltonizerPreferenceController) controller).setOnChangeListener(this);
|
||||||
|
((DaltonizerPreferenceController) controller).displayPreference(getPreferenceScreen());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onPause() {
|
||||||
|
super.onPause();
|
||||||
|
for (AbstractPreferenceController controller :
|
||||||
|
buildPreferenceControllers(getPrefContext(), getSettingsLifecycle())) {
|
||||||
|
((DaltonizerPreferenceController) controller).setOnChangeListener(null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getMetricsCategory() {
|
public int getMetricsCategory() {
|
||||||
@@ -57,16 +79,6 @@ public class ToggleDaltonizerPreferenceFragment extends ToggleFeaturePreferenceF
|
|||||||
return R.string.help_url_color_correction;
|
return R.string.help_url_color_correction;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
|
||||||
super.onCreate(savedInstanceState);
|
|
||||||
|
|
||||||
mType = (ListPreference) findPreference("type");
|
|
||||||
|
|
||||||
final Preference footer = findPreference(KEY_DALTONIZER_FOOTER);
|
|
||||||
footer.setVisible(!ColorDisplayManager.isColorTransformAccelerated(getActivity()));
|
|
||||||
initPreferences();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected int getPreferenceScreenResId() {
|
protected int getPreferenceScreenResId() {
|
||||||
@@ -75,26 +87,7 @@ public class ToggleDaltonizerPreferenceFragment extends ToggleFeaturePreferenceF
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onPreferenceToggled(String preferenceKey, boolean enabled) {
|
protected void onPreferenceToggled(String preferenceKey, boolean enabled) {
|
||||||
Settings.Secure.putInt(getContentResolver(), ENABLED, enabled ? 1 : 0);
|
Settings.Secure.putInt(getContentResolver(), ENABLED, enabled ? 0 : 1);
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
|
||||||
if (preference == mType) {
|
|
||||||
Settings.Secure.putInt(getContentResolver(), TYPE, Integer.parseInt((String) newValue));
|
|
||||||
preference.setSummary("%s");
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void onInstallSwitchBarToggleSwitch() {
|
|
||||||
super.onInstallSwitchBarToggleSwitch();
|
|
||||||
|
|
||||||
mSwitchBar.setCheckedInternal(
|
|
||||||
Settings.Secure.getInt(getContentResolver(), ENABLED, 0) == 1);
|
|
||||||
mSwitchBar.addOnSwitchChangeListener(this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -110,25 +103,34 @@ public class ToggleDaltonizerPreferenceFragment extends ToggleFeaturePreferenceF
|
|||||||
switchBar.setSwitchBarText(switchBarText, switchBarText);
|
switchBar.setSwitchBarText(switchBarText, switchBarText);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initPreferences() {
|
@Override
|
||||||
final String value = Integer.toString(
|
public void onSwitchChanged(Switch switchView, boolean isChecked) {
|
||||||
Settings.Secure.getInt(getContentResolver(), TYPE, DEFAULT_TYPE));
|
Settings.Secure.putInt(getContentResolver(), ENABLED, isChecked ? 1 : 0);
|
||||||
mType.setValue(value);
|
|
||||||
mType.setOnPreferenceChangeListener(this);
|
|
||||||
final int index = mType.findIndexOfValue(value);
|
|
||||||
if (index < 0) {
|
|
||||||
// We're using a mode controlled by developer preferences.
|
|
||||||
mType.setSummary(getString(R.string.daltonizer_type_overridden,
|
|
||||||
getString(R.string.simulate_color_space)));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onSwitchChanged(Switch switchView, boolean isChecked) {
|
protected void onInstallSwitchBarToggleSwitch() {
|
||||||
onPreferenceToggled(mPreferenceKey, isChecked);
|
super.onInstallSwitchBarToggleSwitch();
|
||||||
|
mSwitchBar.setCheckedInternal(
|
||||||
|
Settings.Secure.getInt(getContentResolver(), ENABLED, 0) == 1);
|
||||||
|
mSwitchBar.addOnSwitchChangeListener(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static List<AbstractPreferenceController> buildPreferenceControllers(Context context,
|
||||||
|
Lifecycle lifecycle) {
|
||||||
|
if (sControllers.size() == 0) {
|
||||||
|
final Resources resources = context.getResources();
|
||||||
|
final String[] daltonizerKeys = resources.getStringArray(
|
||||||
|
R.array.daltonizer_mode_keys);
|
||||||
|
|
||||||
|
for (int i = 0; i < daltonizerKeys.length; i++) {
|
||||||
|
sControllers.add(new DaltonizerPreferenceController(
|
||||||
|
context, lifecycle, daltonizerKeys[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return sControllers;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
||||||
new BaseSearchIndexProvider(R.xml.accessibility_daltonizer_settings);
|
new BaseSearchIndexProvider(R.xml.accessibility_daltonizer_settings);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -18,53 +18,100 @@ package com.android.settings.accessibility;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.atLeastOnce;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.never;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.content.ContentResolver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import androidx.preference.Preference;
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
|
import com.android.settingslib.widget.RadioButtonPreference;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class DaltonizerPreferenceControllerTest {
|
public class DaltonizerPreferenceControllerTest implements
|
||||||
private static final int ON = 1;
|
DaltonizerPreferenceController.OnChangeListener {
|
||||||
private static final int OFF = 0;
|
private static final String PREF_KEY = "daltonizer_mode_protanomaly";
|
||||||
|
private static final String PREF_VALUE = "11";
|
||||||
|
private static final String PREF_FAKE_VALUE = "-1";
|
||||||
|
|
||||||
private Context mContext;
|
|
||||||
private DaltonizerPreferenceController mController;
|
private DaltonizerPreferenceController mController;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private RadioButtonPreference mMockPref;
|
||||||
|
private Context mContext;
|
||||||
|
private ContentResolver mContentResolver;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private PreferenceScreen mScreen;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
|
MockitoAnnotations.initMocks(this);
|
||||||
mContext = RuntimeEnvironment.application;
|
mContext = RuntimeEnvironment.application;
|
||||||
mController = new DaltonizerPreferenceController(mContext, "color_correction");
|
mController = new DaltonizerPreferenceController(mContext, mock(Lifecycle.class), PREF_KEY);
|
||||||
|
mController.setOnChangeListener(this);
|
||||||
|
mContentResolver = mContext.getContentResolver();
|
||||||
|
|
||||||
|
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mMockPref);
|
||||||
|
when(mMockPref.getKey()).thenReturn(PREF_KEY);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCheckedChanged(Preference preference) {
|
||||||
|
mController.updateState(preference);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_shouldReturnAvailableUnsearchable() {
|
public void isAvailable() {
|
||||||
assertThat(mController.getAvailabilityStatus())
|
assertThat(mController.isAvailable()).isTrue();
|
||||||
.isEqualTo(BasePreferenceController.AVAILABLE_UNSEARCHABLE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getSummary_enabledColorCorrection_shouldReturnOnSummary() {
|
public void updateState_notChecked() {
|
||||||
Settings.Secure.putInt(mContext.getContentResolver(),
|
Settings.Secure.putString(mContentResolver,
|
||||||
Settings.Secure.ACCESSIBILITY_DISPLAY_DALTONIZER_ENABLED, ON);
|
Settings.Secure.ACCESSIBILITY_DISPLAY_DALTONIZER, PREF_FAKE_VALUE);
|
||||||
|
|
||||||
assertThat(mController.getSummary())
|
mController.updateState(mMockPref);
|
||||||
.isEqualTo(mContext.getText(R.string.accessibility_feature_state_on));
|
|
||||||
|
// the first checked state is set to false by control
|
||||||
|
verify(mMockPref, atLeastOnce()).setChecked(false);
|
||||||
|
verify(mMockPref, never()).setChecked(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getSummary_disabledColorCorrection_shouldReturnOffSummary() {
|
public void updateState_checked() {
|
||||||
Settings.Secure.putInt(mContext.getContentResolver(),
|
Settings.Secure.putString(mContentResolver,
|
||||||
Settings.Secure.ACCESSIBILITY_DISPLAY_DALTONIZER_ENABLED, OFF);
|
Settings.Secure.ACCESSIBILITY_DISPLAY_DALTONIZER, PREF_VALUE);
|
||||||
|
|
||||||
assertThat(mController.getSummary())
|
mController.updateState(mMockPref);
|
||||||
.isEqualTo(mContext.getText(R.string.accessibility_feature_state_off));
|
|
||||||
|
// the first checked state is set to false by control
|
||||||
|
verify(mMockPref, atLeastOnce()).setChecked(false);
|
||||||
|
verify(mMockPref, atLeastOnce()).setChecked(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onRadioButtonClick_shouldReturnDaltonizerValue() {
|
||||||
|
mController.onRadioButtonClicked(mMockPref);
|
||||||
|
final String accessibilityDaltonizerValue = Settings.Secure.getString(mContentResolver,
|
||||||
|
Settings.Secure.ACCESSIBILITY_DISPLAY_DALTONIZER);
|
||||||
|
|
||||||
|
assertThat(accessibilityDaltonizerValue).isEqualTo(PREF_VALUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user