Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 204dcfdb authored by AL HO's avatar AL HO Committed by Android (Google) Code Review
Browse files

Merge "Update Accessbility vibration settings." into pi-dev

parents 9e629edb 92216ae1
Loading
Loading
Loading
Loading
+3 −0
Original line number Diff line number Diff line
@@ -4635,6 +4635,9 @@
        <item quantity="other">Very long delay (<xliff:g id="click_delay_label" example="200">%1$d</xliff:g> ms)</item>
    </plurals>
    <!-- Summary for vibration settings preference when notification vibration and haptic feedback intensity are set. [CHAR LIMIT=32] -->
    <string name="accessibility_vibration_summary">Ring <xliff:g id="summary_ring" example="Medium">%1$s</xliff:g>, touch <xliff:g id="summary_touch" example="High">%2$s</xliff:g></string>
    <!-- Summary for vibration settings preference when ring & notification are set to off-->
    <string name="accessibility_vibration_summary_off">Ring &amp; notification set to off</string>
+27 −4
Original line number Diff line number Diff line
@@ -33,6 +33,7 @@ import android.os.UserHandle;
import android.os.Vibrator;
import android.provider.SearchIndexableResource;
import android.provider.Settings;
import android.support.annotation.VisibleForTesting;
import android.support.v14.preference.SwitchPreference;
import android.support.v4.content.ContextCompat;
import android.support.v7.preference.ListPreference;
@@ -747,12 +748,34 @@ public class AccessibilitySettings extends SettingsPreferenceFragment implements
        pref.setSummary(entries[index]);
    }

    private void updateVibrationSummary(Preference pref) {
        Vibrator vibrator = getContext().getSystemService(Vibrator.class);
        final int intensity = Settings.System.getInt(getContext().getContentResolver(),
    @VisibleForTesting(otherwise = VisibleForTesting.PRIVATE)
    void updateVibrationSummary(Preference pref) {
        final Context context = getContext();
        final Vibrator vibrator = context.getSystemService(Vibrator.class);

        final int ringIntensity = Settings.System.getInt(context.getContentResolver(),
                Settings.System.NOTIFICATION_VIBRATION_INTENSITY,
                vibrator.getDefaultNotificationVibrationIntensity());
        mVibrationPreferenceScreen.setSummary(getVibrationSummary(getContext(), intensity));
        CharSequence ringIntensityString =
                VibrationIntensityPreferenceController.getIntensityString(context, ringIntensity);

        final int touchIntensity = Settings.System.getInt(context.getContentResolver(),
                Settings.System.HAPTIC_FEEDBACK_INTENSITY,
                vibrator.getDefaultHapticFeedbackIntensity());
        CharSequence touchIntensityString =
                VibrationIntensityPreferenceController.getIntensityString(context, touchIntensity);

        if (mVibrationPreferenceScreen == null) {
            mVibrationPreferenceScreen = findPreference(VIBRATION_PREFERENCE_SCREEN);
        }

        if (ringIntensity == touchIntensity) {
            mVibrationPreferenceScreen.setSummary(ringIntensityString);
        } else {
            mVibrationPreferenceScreen.setSummary(
                    getString(R.string.accessibility_vibration_summary,
                            ringIntensityString, touchIntensityString));
        }
    }

    private String getVibrationSummary(Context context, @VibrationIntensity int intensity) {
+7 −4
Original line number Diff line number Diff line
@@ -77,16 +77,19 @@ public abstract class VibrationIntensityPreferenceController extends BasePrefere
    public CharSequence getSummary() {
        final int intensity = Settings.System.getInt(mContext.getContentResolver(),
                mSettingKey, getDefaultIntensity());
        return getIntensityString(mContext, intensity);
   }

    public static CharSequence getIntensityString(Context context, int intensity) {
        switch (intensity) {
            case Vibrator.VIBRATION_INTENSITY_OFF:
                return mContext.getText(R.string.accessibility_vibration_intensity_off);
                return context.getText(R.string.accessibility_vibration_intensity_off);
            case Vibrator.VIBRATION_INTENSITY_LOW:
                return mContext.getText(R.string.accessibility_vibration_intensity_low);
                return context.getText(R.string.accessibility_vibration_intensity_low);
            case Vibrator.VIBRATION_INTENSITY_MEDIUM:
                return mContext.getText(R.string.accessibility_vibration_intensity_medium);
                return context.getText(R.string.accessibility_vibration_intensity_medium);
            case Vibrator.VIBRATION_INTENSITY_HIGH:
                return mContext.getText(R.string.accessibility_vibration_intensity_high);
                return context.getText(R.string.accessibility_vibration_intensity_high);
            default:
                return "";
        }
+40 −2
Original line number Diff line number Diff line
@@ -18,7 +18,16 @@ package com.android.settings.accessibility;

import static com.google.common.truth.Truth.assertThat;

import static org.mockito.Matchers.anyString;
import static org.mockito.Mockito.doReturn;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.when;

import android.content.Context;
import android.os.Bundle;
import android.os.Vibrator;
import android.provider.Settings;
import android.support.v7.preference.Preference;

import com.android.settings.R;
import com.android.settings.testutils.SettingsRobolectricTestRunner;
@@ -26,6 +35,8 @@ import com.android.settings.testutils.XmlTestUtils;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
import org.robolectric.RuntimeEnvironment;

import java.util.ArrayList;
@@ -45,4 +56,31 @@ public class AccessibilitySettingsTest {

        assertThat(keys).containsAllIn(niks);
    }

    @Test
    public void testUpdateVibrationSummary_shouldUpdateSummary() {
        MockitoAnnotations.initMocks(this);
        final Context mContext = RuntimeEnvironment.application;
        final AccessibilitySettings mSettings = spy(new AccessibilitySettings());

        final Preference mVibrationPreferenceScreen = new Preference(mContext);
        doReturn(mVibrationPreferenceScreen).when(mSettings).findPreference(anyString());

        doReturn(mContext).when(mSettings).getContext();

        mVibrationPreferenceScreen.setKey("vibration_preference_screen");

        Settings.System.putInt(mContext.getContentResolver(),
                Settings.System.NOTIFICATION_VIBRATION_INTENSITY,
                Vibrator.VIBRATION_INTENSITY_OFF);

        Settings.System.putInt(mContext.getContentResolver(),
                Settings.System.HAPTIC_FEEDBACK_INTENSITY,
                Vibrator.VIBRATION_INTENSITY_OFF);

        mSettings.updateVibrationSummary(mVibrationPreferenceScreen);
        assertThat(mVibrationPreferenceScreen.getSummary()).isEqualTo(
                VibrationIntensityPreferenceController.getIntensityString(mContext,
                        Vibrator.VIBRATION_INTENSITY_OFF));
    }
}