Refactor SmsListPreference into AppListPreference.
This generalizes the pattern of needing to offer a selection among a list of candidate applications. Also move some reusable logic around querying PackageManager for icons into AppListPreference, and remove some unnecessary update logic: the preference will update itself when onPreferenceChange returns true, and we can set the summary to '%s' to automatically use the entry as the summary without having to reset it each time. Change-Id: I007b9ed58359302f93b367a4b86354e93613bf3e
This commit is contained in:
@@ -21,13 +21,13 @@
|
|||||||
android:layout_height="?android:attr/listPreferredItemHeight"
|
android:layout_height="?android:attr/listPreferredItemHeight"
|
||||||
android:padding="6dip">
|
android:padding="6dip">
|
||||||
<ImageView
|
<ImageView
|
||||||
android:id="@+id/sms_image"
|
android:id="@+id/app_image"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:padding="6dip"
|
android:padding="6dip"
|
||||||
/>
|
/>
|
||||||
<CheckedTextView
|
<CheckedTextView
|
||||||
android:id="@+id/sms_text"
|
android:id="@+id/app_label"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:minHeight="?android:attr/listPreferredItemHeight"
|
android:minHeight="?android:attr/listPreferredItemHeight"
|
@@ -23,9 +23,10 @@
|
|||||||
android:persistent="false"
|
android:persistent="false"
|
||||||
android:disableDependentsState="true" />
|
android:disableDependentsState="true" />
|
||||||
|
|
||||||
<com.android.settings.SmsListPreference
|
<com.android.settings.AppListPreference
|
||||||
android:key="sms_application"
|
android:key="sms_application"
|
||||||
android:title="@string/sms_application_title"
|
android:title="@string/sms_application_title"
|
||||||
|
android:summary="%s"
|
||||||
android:persistent="false" />
|
android:persistent="false" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
|
@@ -19,6 +19,9 @@ package com.android.settings;
|
|||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.app.AlertDialog.Builder;
|
import android.app.AlertDialog.Builder;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.pm.ApplicationInfo;
|
||||||
|
import android.content.pm.PackageManager;
|
||||||
|
import android.content.pm.PackageManager.NameNotFoundException;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
import android.preference.ListPreference;
|
import android.preference.ListPreference;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
@@ -31,56 +34,85 @@ import android.widget.ImageView;
|
|||||||
import android.widget.ListAdapter;
|
import android.widget.ListAdapter;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Extends ListPreference to allow us to show the icons for the available SMS applications. We do
|
* Extends ListPreference to allow us to show the icons for a given list of applications. We do this
|
||||||
* this because the names of SMS applications are very similar and the user may not be able to
|
* because the names of applications are very similar and the user may not be able to determine what
|
||||||
* determine what app they are selecting without an icon.
|
* app they are selecting without an icon.
|
||||||
*/
|
*/
|
||||||
public class SmsListPreference extends ListPreference {
|
public class AppListPreference extends ListPreference {
|
||||||
private Drawable[] mEntryDrawables;
|
private Drawable[] mEntryDrawables;
|
||||||
|
|
||||||
public class SmsArrayAdapter extends ArrayAdapter<CharSequence> {
|
public class AppArrayAdapter extends ArrayAdapter<CharSequence> {
|
||||||
private Drawable[] mImageDrawables = null;
|
private Drawable[] mImageDrawables = null;
|
||||||
private int mSelectedIndex = 0;
|
private int mSelectedIndex = 0;
|
||||||
|
|
||||||
public SmsArrayAdapter(Context context, int textViewResourceId,
|
public AppArrayAdapter(Context context, int textViewResourceId,
|
||||||
CharSequence[] objects, Drawable[] imageDrawables, int selectedIndex) {
|
CharSequence[] objects, Drawable[] imageDrawables, int selectedIndex) {
|
||||||
super(context, textViewResourceId, objects);
|
super(context, textViewResourceId, objects);
|
||||||
mSelectedIndex = selectedIndex;
|
mSelectedIndex = selectedIndex;
|
||||||
mImageDrawables = imageDrawables;
|
mImageDrawables = imageDrawables;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public View getView(int position, View convertView, ViewGroup parent) {
|
public View getView(int position, View convertView, ViewGroup parent) {
|
||||||
LayoutInflater inflater = ((Activity)getContext()).getLayoutInflater();
|
LayoutInflater inflater = ((Activity)getContext()).getLayoutInflater();
|
||||||
View view = inflater.inflate(R.layout.sms_preference_item, parent, false);
|
View view = inflater.inflate(R.layout.app_preference_item, parent, false);
|
||||||
CheckedTextView checkedTextView = (CheckedTextView)view.findViewById(R.id.sms_text);
|
CheckedTextView checkedTextView = (CheckedTextView)view.findViewById(R.id.app_label);
|
||||||
checkedTextView.setText(getItem(position));
|
checkedTextView.setText(getItem(position));
|
||||||
if (position == mSelectedIndex) {
|
if (position == mSelectedIndex) {
|
||||||
checkedTextView.setChecked(true);
|
checkedTextView.setChecked(true);
|
||||||
}
|
}
|
||||||
ImageView imageView = (ImageView)view.findViewById(R.id.sms_image);
|
ImageView imageView = (ImageView)view.findViewById(R.id.app_image);
|
||||||
imageView.setImageDrawable(mImageDrawables[position]);
|
imageView.setImageDrawable(mImageDrawables[position]);
|
||||||
return view;
|
return view;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public SmsListPreference(Context context, AttributeSet attrs) {
|
public AppListPreference(Context context, AttributeSet attrs) {
|
||||||
super(context, attrs);
|
super(context, attrs);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setEntryDrawables(Drawable[] entries) {
|
public void setPackageNames(String[] packageNames, String defaultPackageName) {
|
||||||
mEntryDrawables = entries;
|
// Look up all package names in PackageManager. Skip ones we can't find.
|
||||||
}
|
int foundPackages = 0;
|
||||||
|
PackageManager pm = getContext().getPackageManager();
|
||||||
|
ApplicationInfo[] appInfos = new ApplicationInfo[packageNames.length];
|
||||||
|
for (int i = 0; i < packageNames.length; i++) {
|
||||||
|
try {
|
||||||
|
appInfos[i] = pm.getApplicationInfo(packageNames[i], 0);
|
||||||
|
foundPackages++;
|
||||||
|
} catch (NameNotFoundException e) {
|
||||||
|
// Leave appInfos[i] uninitialized; it will be skipped in the list.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public Drawable[] getEntryDrawables() {
|
// Show the label and icon for each application package.
|
||||||
return mEntryDrawables;
|
CharSequence[] applicationNames = new CharSequence[foundPackages];
|
||||||
|
mEntryDrawables = new Drawable[foundPackages];
|
||||||
|
int index = 0;
|
||||||
|
int selectedIndex = -1;
|
||||||
|
for (ApplicationInfo appInfo : appInfos) {
|
||||||
|
if (appInfo != null) {
|
||||||
|
applicationNames[index] = appInfo.loadLabel(pm);
|
||||||
|
mEntryDrawables[index] = appInfo.loadIcon(pm);
|
||||||
|
if (appInfo.packageName.contentEquals(defaultPackageName)) {
|
||||||
|
selectedIndex = index;
|
||||||
|
}
|
||||||
|
index++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
setEntries(applicationNames);
|
||||||
|
setEntryValues(packageNames);
|
||||||
|
if (selectedIndex != -1) {
|
||||||
|
setValueIndex(selectedIndex);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onPrepareDialogBuilder(Builder builder) {
|
protected void onPrepareDialogBuilder(Builder builder) {
|
||||||
int selectedIndex = findIndexOfValue(getValue());
|
int selectedIndex = findIndexOfValue(getValue());
|
||||||
ListAdapter adapter = new SmsArrayAdapter(getContext(),
|
ListAdapter adapter = new AppArrayAdapter(getContext(),
|
||||||
R.layout.sms_preference_item, getEntries(), mEntryDrawables, selectedIndex);
|
R.layout.app_preference_item, getEntries(), mEntryDrawables, selectedIndex);
|
||||||
builder.setAdapter(adapter, this);
|
builder.setAdapter(adapter, this);
|
||||||
super.onPrepareDialogBuilder(builder);
|
super.onPrepareDialogBuilder(builder);
|
||||||
}
|
}
|
||||||
}
|
}
|
@@ -26,9 +26,7 @@ import android.content.Context;
|
|||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.pm.PackageManager.NameNotFoundException;
|
|
||||||
import android.content.res.Resources;
|
import android.content.res.Resources;
|
||||||
import android.graphics.drawable.Drawable;
|
|
||||||
import android.net.ConnectivityManager;
|
import android.net.ConnectivityManager;
|
||||||
import android.net.NetworkInfo;
|
import android.net.NetworkInfo;
|
||||||
import android.nfc.NfcAdapter;
|
import android.nfc.NfcAdapter;
|
||||||
@@ -85,7 +83,7 @@ public class WirelessSettings extends RestrictedSettingsFragment
|
|||||||
private static final int MANAGE_MOBILE_PLAN_DIALOG_ID = 1;
|
private static final int MANAGE_MOBILE_PLAN_DIALOG_ID = 1;
|
||||||
private static final String SAVED_MANAGE_MOBILE_PLAN_MSG = "mManageMobilePlanMessage";
|
private static final String SAVED_MANAGE_MOBILE_PLAN_MSG = "mManageMobilePlanMessage";
|
||||||
|
|
||||||
private SmsListPreference mSmsApplicationPreference;
|
private AppListPreference mSmsApplicationPreference;
|
||||||
|
|
||||||
public WirelessSettings() {
|
public WirelessSettings() {
|
||||||
super(null);
|
super(null);
|
||||||
@@ -174,23 +172,6 @@ public class WirelessSettings extends RestrictedSettingsFragment
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateSmsApplicationSetting() {
|
|
||||||
log("updateSmsApplicationSetting:");
|
|
||||||
ComponentName appName = SmsApplication.getDefaultSmsApplication(getActivity(), true);
|
|
||||||
if (appName != null) {
|
|
||||||
String packageName = appName.getPackageName();
|
|
||||||
|
|
||||||
CharSequence[] values = mSmsApplicationPreference.getEntryValues();
|
|
||||||
for (int i = 0; i < values.length; i++) {
|
|
||||||
if (packageName.contentEquals(values[i])) {
|
|
||||||
mSmsApplicationPreference.setValueIndex(i);
|
|
||||||
mSmsApplicationPreference.setSummary(mSmsApplicationPreference.getEntries()[i]);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void initSmsApplicationSetting() {
|
private void initSmsApplicationSetting() {
|
||||||
log("initSmsApplicationSetting:");
|
log("initSmsApplicationSetting:");
|
||||||
Collection<SmsApplicationData> smsApplications =
|
Collection<SmsApplicationData> smsApplications =
|
||||||
@@ -198,25 +179,18 @@ public class WirelessSettings extends RestrictedSettingsFragment
|
|||||||
|
|
||||||
// If the list is empty the dialog will be empty, but we will not crash.
|
// If the list is empty the dialog will be empty, but we will not crash.
|
||||||
int count = smsApplications.size();
|
int count = smsApplications.size();
|
||||||
CharSequence[] entries = new CharSequence[count];
|
String[] packageNames = new String[count];
|
||||||
CharSequence[] entryValues = new CharSequence[count];
|
|
||||||
Drawable[] entryImages = new Drawable[count];
|
|
||||||
|
|
||||||
int i = 0;
|
int i = 0;
|
||||||
for (SmsApplicationData smsApplicationData : smsApplications) {
|
for (SmsApplicationData smsApplicationData : smsApplications) {
|
||||||
entries[i] = smsApplicationData.mApplicationName;
|
packageNames[i] = smsApplicationData.mPackageName;
|
||||||
entryValues[i] = smsApplicationData.mPackageName;
|
|
||||||
try {
|
|
||||||
entryImages[i] = mPm.getApplicationIcon(smsApplicationData.mPackageName);
|
|
||||||
} catch (NameNotFoundException e) {
|
|
||||||
entryImages[i] = mPm.getDefaultActivityIcon();
|
|
||||||
}
|
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
mSmsApplicationPreference.setEntries(entries);
|
String defaultPackageName = null;
|
||||||
mSmsApplicationPreference.setEntryValues(entryValues);
|
ComponentName appName = SmsApplication.getDefaultSmsApplication(getActivity(), true);
|
||||||
mSmsApplicationPreference.setEntryDrawables(entryImages);
|
if (appName != null) {
|
||||||
updateSmsApplicationSetting();
|
defaultPackageName = appName.getPackageName();
|
||||||
|
}
|
||||||
|
mSmsApplicationPreference.setPackageNames(packageNames, defaultPackageName);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -284,7 +258,7 @@ public class WirelessSettings extends RestrictedSettingsFragment
|
|||||||
mAirplaneModeEnabler = new AirplaneModeEnabler(activity, mAirplaneModePreference);
|
mAirplaneModeEnabler = new AirplaneModeEnabler(activity, mAirplaneModePreference);
|
||||||
mNfcEnabler = new NfcEnabler(activity, nfc, androidBeam);
|
mNfcEnabler = new NfcEnabler(activity, nfc, androidBeam);
|
||||||
|
|
||||||
mSmsApplicationPreference = (SmsListPreference) findPreference(KEY_SMS_APPLICATION);
|
mSmsApplicationPreference = (AppListPreference) findPreference(KEY_SMS_APPLICATION);
|
||||||
mSmsApplicationPreference.setOnPreferenceChangeListener(this);
|
mSmsApplicationPreference.setOnPreferenceChangeListener(this);
|
||||||
initSmsApplicationSetting();
|
initSmsApplicationSetting();
|
||||||
|
|
||||||
@@ -468,7 +442,6 @@ public class WirelessSettings extends RestrictedSettingsFragment
|
|||||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||||
if (preference == mSmsApplicationPreference && newValue != null) {
|
if (preference == mSmsApplicationPreference && newValue != null) {
|
||||||
SmsApplication.setDefaultApplication(newValue.toString(), getActivity());
|
SmsApplication.setDefaultApplication(newValue.toString(), getActivity());
|
||||||
updateSmsApplicationSetting();
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
Reference in New Issue
Block a user