diff options
author | Jason Monk <jmonk@google.com> | 2015-04-13 20:58:05 -0400 |
---|---|---|
committer | Jason Monk <jmonk@google.com> | 2015-04-14 10:24:46 -0400 |
commit | 73a2496d316cb9a8dc0020c245bc61f766b7f7c2 (patch) | |
tree | 3cd53006c87becb5c9a3aec6da4a5c6d63672658 /src/com/android/settings/AppListPreference.java | |
parent | 6ef272300416b89c1ab4710614eea3d80d8d0f33 (diff) | |
download | packages_apps_Settings-73a2496d316cb9a8dc0020c245bc61f766b7f7c2.zip packages_apps_Settings-73a2496d316cb9a8dc0020c245bc61f766b7f7c2.tar.gz packages_apps_Settings-73a2496d316cb9a8dc0020c245bc61f766b7f7c2.tar.bz2 |
Move default app preferences to one screen
- Move emergency and SMS app preferences to default apps
- Fix search on default apps
- Make all default app prefs use AppListPreference
- Some approximate UI work on AppListPreference
Bug: 20210110
Change-Id: Id04086163c7e87c92a03af421a27018fb380b45d
Diffstat (limited to 'src/com/android/settings/AppListPreference.java')
-rw-r--r-- | src/com/android/settings/AppListPreference.java | 71 |
1 files changed, 65 insertions, 6 deletions
diff --git a/src/com/android/settings/AppListPreference.java b/src/com/android/settings/AppListPreference.java index 96897ae..3cc91cd 100644 --- a/src/com/android/settings/AppListPreference.java +++ b/src/com/android/settings/AppListPreference.java @@ -23,15 +23,17 @@ import android.content.pm.ApplicationInfo; import android.content.pm.PackageManager; import android.content.pm.PackageManager.NameNotFoundException; import android.graphics.drawable.Drawable; +import android.os.Parcel; +import android.os.Parcelable; import android.preference.ListPreference; import android.util.AttributeSet; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.ArrayAdapter; -import android.widget.CheckedTextView; import android.widget.ImageView; import android.widget.ListAdapter; +import android.widget.TextView; /** * Extends ListPreference to allow us to show the icons for a given list of applications. We do this @@ -56,10 +58,10 @@ public class AppListPreference extends ListPreference { public View getView(int position, View convertView, ViewGroup parent) { LayoutInflater inflater = ((Activity)getContext()).getLayoutInflater(); View view = inflater.inflate(R.layout.app_preference_item, parent, false); - CheckedTextView checkedTextView = (CheckedTextView)view.findViewById(R.id.app_label); - checkedTextView.setText(getItem(position)); + TextView textView = (TextView) view.findViewById(R.id.app_label); + textView.setText(getItem(position)); if (position == mSelectedIndex) { - checkedTextView.setChecked(true); + view.findViewById(R.id.default_label).setVisibility(View.VISIBLE); } ImageView imageView = (ImageView)view.findViewById(R.id.app_image); imageView.setImageDrawable(mImageDrawables[position]); @@ -76,14 +78,14 @@ public class AppListPreference extends ListPreference { super(context, attrs); } - public void setPackageNames(String[] packageNames, String defaultPackageName) { + public void setPackageNames(CharSequence[] packageNames, CharSequence defaultPackageName) { // 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); + appInfos[i] = pm.getApplicationInfo(packageNames[i].toString(), 0); foundPackages++; } catch (NameNotFoundException e) { // Leave appInfos[i] uninitialized; it will be skipped in the list. @@ -123,4 +125,61 @@ public class AppListPreference extends ListPreference { builder.setAdapter(adapter, this); super.onPrepareDialogBuilder(builder); } + + @Override + protected Parcelable onSaveInstanceState() { + Parcelable superState = super.onSaveInstanceState(); + return new SavedState(getEntryValues(), getValue(), superState); + } + + @Override + protected void onRestoreInstanceState(Parcelable state) { + if (state instanceof SavedState) { + SavedState savedState = (SavedState) state; + setPackageNames(savedState.entryValues, savedState.value); + super.onRestoreInstanceState(savedState.superState); + } else { + super.onRestoreInstanceState(state); + } + } + + private static class SavedState implements Parcelable { + + public final CharSequence[] entryValues; + public final CharSequence value; + public final Parcelable superState; + + public SavedState(CharSequence[] entryValues, CharSequence value, Parcelable superState) { + this.entryValues = entryValues; + this.value = value; + this.superState = superState; + } + + @Override + public int describeContents() { + return 0; + } + + @Override + public void writeToParcel(Parcel dest, int flags) { + dest.writeCharSequenceArray(entryValues); + dest.writeCharSequence(value); + dest.writeParcelable(superState, flags); + } + + public static Creator<SavedState> CREATOR = new Creator<SavedState>() { + @Override + public SavedState createFromParcel(Parcel source) { + CharSequence[] entryValues = source.readCharSequenceArray(); + CharSequence value = source.readCharSequence(); + Parcelable superState = source.readParcelable(getClass().getClassLoader()); + return new SavedState(entryValues, value, superState); + } + + @Override + public SavedState[] newArray(int size) { + return new SavedState[size]; + } + }; + } } |