summaryrefslogtreecommitdiffstats
path: root/src/com/android/launcher3/SettingsActivity.java
diff options
context:
space:
mode:
authorSunny Goyal <sunnygoyal@google.com>2016-05-02 10:54:12 -0700
committerSunny Goyal <sunnygoyal@google.com>2016-05-02 12:00:51 -0700
commit745bad9da1ef2fca2ab7bfeb5ea885a2b50c49c3 (patch)
tree9e65a1a6ee1a500fc5e1dc36e1561338ea69a0ec /src/com/android/launcher3/SettingsActivity.java
parentf8a2ba27078badc61b7122a6781214a4148a686f (diff)
downloadandroid_packages_apps_Trebuchet-745bad9da1ef2fca2ab7bfeb5ea885a2b50c49c3.tar.gz
android_packages_apps_Trebuchet-745bad9da1ef2fca2ab7bfeb5ea885a2b50c49c3.tar.bz2
android_packages_apps_Trebuchet-745bad9da1ef2fca2ab7bfeb5ea885a2b50c49c3.zip
Chaning the behavior of settings activity.
> Making all twoState prefs backed by content provider > Using the stadard intent defined in N for settings > Using SharedPrefsListener instead of LauncherProvider Change-Id: I8272f54aa780bc0436e3d0aa89096a4bd2a9194f
Diffstat (limited to 'src/com/android/launcher3/SettingsActivity.java')
-rw-r--r--src/com/android/launcher3/SettingsActivity.java49
1 files changed, 35 insertions, 14 deletions
diff --git a/src/com/android/launcher3/SettingsActivity.java b/src/com/android/launcher3/SettingsActivity.java
index dab71c862..5d9a54684 100644
--- a/src/com/android/launcher3/SettingsActivity.java
+++ b/src/com/android/launcher3/SettingsActivity.java
@@ -17,11 +17,13 @@
package com.android.launcher3;
import android.app.Activity;
+import android.os.AsyncTask;
import android.os.Bundle;
import android.preference.Preference;
import android.preference.Preference.OnPreferenceChangeListener;
import android.preference.PreferenceFragment;
-import android.preference.SwitchPreference;
+import android.preference.PreferenceScreen;
+import android.preference.TwoStatePreference;
/**
* Settings activity for Launcher. Currently implements the following setting: Allow rotation
@@ -47,19 +49,13 @@ public class SettingsActivity extends Activity {
super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.launcher_preferences);
- SwitchPreference pref = (SwitchPreference) findPreference(
- Utilities.ALLOW_ROTATION_PREFERENCE_KEY);
- pref.setPersistent(false);
-
- Bundle extras = new Bundle();
- extras.putBoolean(LauncherSettings.Settings.EXTRA_DEFAULT_VALUE, false);
- Bundle value = getActivity().getContentResolver().call(
- LauncherSettings.Settings.CONTENT_URI,
- LauncherSettings.Settings.METHOD_GET_BOOLEAN,
- Utilities.ALLOW_ROTATION_PREFERENCE_KEY, extras);
- pref.setChecked(value.getBoolean(LauncherSettings.Settings.EXTRA_VALUE));
-
- pref.setOnPreferenceChangeListener(this);
+ PreferenceScreen screen = getPreferenceScreen();
+ for (int i = screen.getPreferenceCount() - 1; i >= 0; i--) {
+ Preference pref = screen.getPreference(i);
+ if (pref instanceof TwoStatePreference) {
+ setBooleanPrefUsingContentProvider((TwoStatePreference) pref);
+ }
+ }
}
@Override
@@ -72,5 +68,30 @@ public class SettingsActivity extends Activity {
preference.getKey(), extras);
return true;
}
+
+ private void setBooleanPrefUsingContentProvider(final TwoStatePreference pref) {
+ pref.setPersistent(false);
+ pref.setEnabled(false);
+
+ new AsyncTask<Void, Void, Boolean>() {
+ @Override
+ protected Boolean doInBackground(Void... params) {
+ Bundle extras = new Bundle();
+ extras.putBoolean(LauncherSettings.Settings.EXTRA_DEFAULT_VALUE, false);
+ Bundle value = getActivity().getContentResolver().call(
+ LauncherSettings.Settings.CONTENT_URI,
+ LauncherSettings.Settings.METHOD_GET_BOOLEAN,
+ pref.getKey(), extras);
+ return value.getBoolean(LauncherSettings.Settings.EXTRA_VALUE);
+ }
+
+ @Override
+ protected void onPostExecute(Boolean aBoolean) {
+ pref.setChecked(aBoolean);
+ pref.setEnabled(true);
+ pref.setOnPreferenceChangeListener(LauncherSettingsFragment.this);
+ }
+ }.execute();
+ }
}
}