From cd1d8432cf47bffe716bd4ae57bfe2596881d9ef Mon Sep 17 00:00:00 2001 From: Sunny Goyal Date: Thu, 14 Jul 2016 14:17:00 -0700 Subject: Adding icons in Set Wallpaper disambiguation dialog UI Bug: 29319713 Change-Id: If8b689e9b27a3cbd1f5123cc584cda3662f2ee38 --- res/drawable-sw600dp/ic_device.xml | 27 +++++++++++++++ res/drawable/ic_device.xml | 27 +++++++++++++++ res/drawable/ic_home.xml | 27 +++++++++++++++ res/layout/wallpaper_target_dialog_item.xml | 28 ++++++++++++++++ .../wallpaper/livepicker/LiveWallpaperPreview.java | 38 +++++++++++++++++++--- 5 files changed, 142 insertions(+), 5 deletions(-) create mode 100644 res/drawable-sw600dp/ic_device.xml create mode 100644 res/drawable/ic_device.xml create mode 100644 res/drawable/ic_home.xml create mode 100644 res/layout/wallpaper_target_dialog_item.xml diff --git a/res/drawable-sw600dp/ic_device.xml b/res/drawable-sw600dp/ic_device.xml new file mode 100644 index 0000000..9af391c --- /dev/null +++ b/res/drawable-sw600dp/ic_device.xml @@ -0,0 +1,27 @@ + + + + + + diff --git a/res/drawable/ic_device.xml b/res/drawable/ic_device.xml new file mode 100644 index 0000000..82a69cb --- /dev/null +++ b/res/drawable/ic_device.xml @@ -0,0 +1,27 @@ + + + + + + diff --git a/res/drawable/ic_home.xml b/res/drawable/ic_home.xml new file mode 100644 index 0000000..5eb2e92 --- /dev/null +++ b/res/drawable/ic_home.xml @@ -0,0 +1,27 @@ + + + + + + diff --git a/res/layout/wallpaper_target_dialog_item.xml b/res/layout/wallpaper_target_dialog_item.xml new file mode 100644 index 0000000..01831a7 --- /dev/null +++ b/res/layout/wallpaper_target_dialog_item.xml @@ -0,0 +1,28 @@ + + + \ No newline at end of file diff --git a/src/com/android/wallpaper/livepicker/LiveWallpaperPreview.java b/src/com/android/wallpaper/livepicker/LiveWallpaperPreview.java index 927ffc6..b2d8a78 100644 --- a/src/com/android/wallpaper/livepicker/LiveWallpaperPreview.java +++ b/src/com/android/wallpaper/livepicker/LiveWallpaperPreview.java @@ -42,13 +42,16 @@ import android.service.wallpaper.WallpaperSettingsActivity; import android.support.design.widget.BottomSheetBehavior; import android.text.TextUtils; import android.util.Log; +import android.view.ContextThemeWrapper; import android.view.Menu; import android.view.MenuItem; import android.view.MotionEvent; import android.view.View; import android.view.View.OnClickListener; +import android.view.ViewGroup; import android.view.WindowManager.LayoutParams; import android.view.animation.AnimationUtils; +import android.widget.ArrayAdapter; import android.widget.Button; import android.widget.ImageButton; import android.widget.TextView; @@ -258,9 +261,10 @@ public class LiveWallpaperPreview extends Activity { finish(); } else { // Otherwise, prompt to either set on home or both home and lock screen. - new AlertDialog.Builder(this, android.R.style.Theme_Material_Light_Dialog) + Context themedContext = new ContextThemeWrapper(this, android.R.style.Theme_DeviceDefault_Settings); + new AlertDialog.Builder(themedContext) .setTitle(R.string.set_live_wallpaper) - .setItems(R.array.which_wallpaper_options, new DialogInterface.OnClickListener() { + .setAdapter(new WallpaperTargetAdapter(themedContext), new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { try { @@ -271,9 +275,7 @@ public class LiveWallpaperPreview extends Activity { mWallpaperManager.clear(WallpaperManager.FLAG_LOCK); } setResult(RESULT_OK); - } catch (RuntimeException e) { - Log.w(LOG_TAG, "Failure setting wallpaper", e); - } catch (IOException e) { + } catch (RuntimeException|IOException e) { Log.w(LOG_TAG, "Failure setting wallpaper", e); } finish(); @@ -487,4 +489,30 @@ public class LiveWallpaperPreview extends Activity { }); } } + + private static class WallpaperTargetAdapter extends ArrayAdapter { + + public WallpaperTargetAdapter(Context context) { + super(context, R.layout.wallpaper_target_dialog_item, + context.getResources().getTextArray(R.array.which_wallpaper_options)); + } + + @Override + public boolean hasStableIds() { + return true; + } + + @Override + public long getItemId(int position) { + return position; + } + + @Override + public View getView(int position, View convertView, ViewGroup parent) { + TextView tv = (TextView) super.getView(position, convertView, parent); + tv.setCompoundDrawablesRelativeWithIntrinsicBounds( + position == 0 ? R.drawable.ic_home : R.drawable.ic_device, 0, 0, 0); + return tv; + } + } } -- cgit v1.2.3