am 32e016b5: Reloads status messages for injected items

* commit '32e016b5fae1f4caf673ff1f062869dce0e94757':
  Reloads status messages for injected items
This commit is contained in:
Lifu Tang
2013-08-22 18:26:49 -07:00
committed by Android Git Automerger
2 changed files with 73 additions and 22 deletions

View File

@@ -18,7 +18,11 @@ package com.android.settings.location;
import android.app.ActionBar;
import android.app.Activity;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.location.SettingInjectorService;
import android.os.Bundle;
import android.preference.Preference;
import android.preference.PreferenceActivity;
@@ -53,8 +57,9 @@ public class LocationSettings extends LocationSettingsBase
private Switch mSwitch;
private boolean mValidListener;
private Preference mLocationMode;
private BatteryStatsHelper mStatsHelper;
/** Receives UPDATE_INTENT */
private BroadcastReceiver mReceiver;
public LocationSettings() {
mValidListener = false;
@@ -89,6 +94,11 @@ public class LocationSettings extends LocationSettingsBase
@Override
public void onPause() {
try {
getActivity().unregisterReceiver(mReceiver);
} catch (RuntimeException e) {
// Ignore exceptions caused by race condition
}
super.onPause();
mValidListener = false;
mSwitch.setOnCheckedChangeListener(null);
@@ -156,7 +166,18 @@ public class LocationSettings extends LocationSettingsBase
PreferenceCategory categoryLocationServices =
(PreferenceCategory) root.findPreference(KEY_LOCATION_SERVICES);
List<Preference> locationServices = SettingsInjector.getInjectedSettings(activity);
final SettingsInjector injector = new SettingsInjector(activity);
List<Preference> locationServices = injector.getInjectedSettings();
mReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
injector.reloadStatusMessages();
}
};
activity.registerReceiver(
mReceiver, new IntentFilter(SettingInjectorService.UPDATE_INTENT));
if (locationServices.size() > 0) {
addPreferencesSorted(locationServices, categoryLocationServices);
} else {

View File

@@ -79,6 +79,13 @@ class SettingsInjector {
*/
public static final String ATTRIBUTES_NAME = "injected-location-setting";
private Context mContext;
private StatusLoader mLoader = null;
public SettingsInjector(Context context) {
mContext = context;
}
/**
* Returns a list with one {@link InjectedSetting} object for each {@link android.app.Service}
* that responds to {@link #RECEIVER_INTENT} and provides the expected setting metadata.
@@ -87,8 +94,8 @@ class SettingsInjector {
*
* TODO: unit test
*/
public static List<InjectedSetting> getSettings(Context context) {
PackageManager pm = context.getPackageManager();
private List<InjectedSetting> getSettings() {
PackageManager pm = mContext.getPackageManager();
Intent receiverIntent = new Intent(RECEIVER_INTENT);
List<ResolveInfo> resolveInfos =
@@ -189,8 +196,7 @@ class SettingsInjector {
}
}
private static final class StatusLoader {
private final Context mContext;
private final class StatusLoader {
private final Intent mIntent;
private final StatusLoader mPrev;
@@ -199,12 +205,29 @@ class SettingsInjector {
/**
* Creates a loader and chains with the previous loader.
*/
public StatusLoader(Context context, Intent intent, StatusLoader prev) {
mContext = context;
public StatusLoader(Intent intent, StatusLoader prev) {
mIntent = intent;
mPrev = prev;
}
/**
* Clears the loaded flag for the whole chain.
*/
private void setNotLoaded() {
mLoaded = false;
if (mPrev != null) {
mPrev.setNotLoaded();
}
}
/**
* Reloads the whole chain.
*/
public void reload() {
setNotLoaded();
loadIfNotLoaded();
}
/**
* If the current message hasn't been loaded, loads the status messages
* and set time out for the next message.
@@ -238,34 +261,41 @@ class SettingsInjector {
* TODO: extract InjectedLocationSettingGetter that returns an iterable over
* InjectedSetting objects, so that this class can focus on UI
*/
public static List<Preference> getInjectedSettings(Context context) {
Iterable<InjectedSetting> settings = getSettings(context);
public List<Preference> getInjectedSettings() {
Iterable<InjectedSetting> settings = getSettings();
ArrayList<Preference> prefs = new ArrayList<Preference>();
StatusLoader loader = null;
mLoader = null;
for (InjectedSetting setting : settings) {
Preference pref = addServiceSetting(context, prefs, setting);
Intent intent = createUpdatingIntent(context, pref, setting, loader);
loader = new StatusLoader(context, intent, loader);
Preference pref = addServiceSetting(prefs, setting);
Intent intent = createUpdatingIntent(pref, setting, mLoader);
mLoader = new StatusLoader(intent, mLoader);
}
// Start a thread to load each list item status.
if (loader != null) {
loader.loadIfNotLoaded();
if (mLoader != null) {
mLoader.loadIfNotLoaded();
}
return prefs;
}
/**
* Reloads the status messages for all the preference items.
*/
public void reloadStatusMessages() {
if (mLoader != null) {
mLoader.reload();
}
}
/**
* Adds an injected setting to the root with status "Loading...".
*/
private static Preference addServiceSetting(
Context context, List<Preference> prefs, InjectedSetting info) {
Preference pref = new Preference(context);
private Preference addServiceSetting(List<Preference> prefs, InjectedSetting info) {
Preference pref = new Preference(mContext);
pref.setTitle(info.title);
pref.setSummary(R.string.location_loading_injected_setting);
PackageManager pm = context.getPackageManager();
PackageManager pm = mContext.getPackageManager();
Drawable icon = pm.getDrawable(info.packageName, info.iconId, null);
pref.setIcon(icon);
@@ -281,7 +311,7 @@ class SettingsInjector {
* Creates an Intent to ask the receiver for the current status for the setting, and display it
* when it replies.
*/
private static Intent createUpdatingIntent(Context context,
private static Intent createUpdatingIntent(
final Preference pref, final InjectedSetting info, final StatusLoader prev) {
final Intent receiverIntent = info.getServiceIntent();
Handler handler = new Handler() {