OSDN Git Service

Fixing bug 2486048 - Disabling Accessibility does not disable Accessibility services...
authorSvetoslav Ganov <svetoslavganov@google.com>
Wed, 10 Mar 2010 03:12:46 +0000 (19:12 -0800)
committerSvetoslav Ganov <svetoslavganov@google.com>
Wed, 10 Mar 2010 04:32:20 +0000 (20:32 -0800)
Change-Id: Ie5d78c1ddb61241db8259a200a3df1950d767cce

src/com/android/settings/AccessibilitySettings.java

index 276a22f..b2debd2 100644 (file)
@@ -105,6 +105,8 @@ public class AccessibilitySettings extends PreferenceActivity {
         if (!accessibilityServices.isEmpty()) {
             if (serviceState == 1) {
                 mToggleCheckBox.setChecked(true);
+            } else {
+                setAccessibilityServicePreferencesState(false);
             }
             mToggleCheckBox.setEnabled(true);
         } else {
@@ -127,6 +129,24 @@ public class AccessibilitySettings extends PreferenceActivity {
         persistEnabledAccessibilityServices();
     }
 
+    /**
+     * Sets the state of the preferences for enabling/disabling
+     * AccessibilityServices.
+     *
+     * @param isEnabled If to enable or disable the preferences.
+     */
+    private void setAccessibilityServicePreferencesState(boolean isEnabled) {
+        if (mAccessibilityServicesCategory == null) {
+            return;
+        }
+
+        int count = mAccessibilityServicesCategory.getPreferenceCount();
+        for (int i = 0; i < count; i++) {
+            Preference pref = mAccessibilityServicesCategory.getPreference(i);
+            pref.setEnabled(isEnabled);
+        }
+    }
+
     @Override
     public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen, Preference preference) {
         final String key = preference.getKey();
@@ -150,6 +170,7 @@ public class AccessibilitySettings extends PreferenceActivity {
         if (preference.isChecked()) {
             Settings.Secure.putInt(getContentResolver(),
                 Settings.Secure.ACCESSIBILITY_ENABLED, 1);
+            setAccessibilityServicePreferencesState(true);
         } else {
             final CheckBoxPreference checkBoxPreference = preference;
             AlertDialog dialog = (new AlertDialog.Builder(this))
@@ -162,6 +183,7 @@ public class AccessibilitySettings extends PreferenceActivity {
                         public void onClick(DialogInterface dialog, int which) {
                             Settings.Secure.putInt(getContentResolver(),
                                 Settings.Secure.ACCESSIBILITY_ENABLED, 0);
+                            setAccessibilityServicePreferencesState(false);
                         }
                 })
                 .setNegativeButton(android.R.string.cancel,