diff options
author | Michael Kolb <kolby@google.com> | 2013-05-17 09:09:21 -0700 |
---|---|---|
committer | Michael Kolb <kolby@google.com> | 2013-05-17 15:13:41 -0700 |
commit | 01fa94509b880bf80d3c852544c26cda6e882539 (patch) | |
tree | 702da0e628e88474b4b66b3236e01b0f4fa7ee6e /src/com/android/gallery3d/filtershow/category | |
parent | ce54df0c34bd0d8472e2c1fea4da1e0a9d8fd657 (diff) | |
download | android_packages_apps_Snap-01fa94509b880bf80d3c852544c26cda6e882539.tar.gz android_packages_apps_Snap-01fa94509b880bf80d3c852544c26cda6e882539.tar.bz2 android_packages_apps_Snap-01fa94509b880bf80d3c852544c26cda6e882539.zip |
Highlight selected option in FX and Borders
Bug: 8791729
Change-Id: I8ac2c3deabe7b293df48db9f44f52956443a92a4
Diffstat (limited to 'src/com/android/gallery3d/filtershow/category')
4 files changed, 78 insertions, 12 deletions
diff --git a/src/com/android/gallery3d/filtershow/category/CategoryAdapter.java b/src/com/android/gallery3d/filtershow/category/CategoryAdapter.java index e310b2f33..0a65cd92f 100644 --- a/src/com/android/gallery3d/filtershow/category/CategoryAdapter.java +++ b/src/com/android/gallery3d/filtershow/category/CategoryAdapter.java @@ -21,24 +21,25 @@ import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; -import android.widget.AbsListView; import android.widget.ArrayAdapter; -import android.widget.LinearLayout; import android.widget.ListView; + import com.android.gallery3d.R; import com.android.gallery3d.filtershow.filters.FilterRepresentation; -import com.android.gallery3d.filtershow.filters.FilterTinyPlanetRepresentation; -import com.android.gallery3d.filtershow.filters.ImageFilter; import com.android.gallery3d.filtershow.filters.ImageFilterTinyPlanet; +import com.android.gallery3d.filtershow.imageshow.MasterImage; +import com.android.gallery3d.filtershow.presets.ImagePreset; import com.android.gallery3d.filtershow.ui.FilterIconButton; public class CategoryAdapter extends ArrayAdapter<Action> { private static final String LOGTAG = "CategoryAdapter"; private int mItemHeight = 200; - private ListView mContainer; + private View mContainer; private int mItemWidth = ListView.LayoutParams.MATCH_PARENT; private boolean mUseFilterIconButton = false; + private int mSelectedPosition; + int mCategory; public CategoryAdapter(Context context, int textViewResourceId) { super(context, textViewResourceId); @@ -62,6 +63,22 @@ public class CategoryAdapter extends ArrayAdapter<Action> { action.setAdapter(this); } + public void initializeSelection(int category) { + mCategory = category; + if (category == MainPanel.LOOKS || category == MainPanel.BORDERS) { + ImagePreset preset = MasterImage.getImage().getPreset(); + if (preset != null) { + for (int i = 0; i < getCount(); i++) { + if (preset.historyName().equals(getItem(i).getRepresentation().getName())) { + mSelectedPosition = i; + } + } + } + } else { + mSelectedPosition = -1; + } + } + @Override public View getView(int position, View convertView, ViewGroup parent) { if (mUseFilterIconButton) { @@ -73,27 +90,55 @@ public class CategoryAdapter extends ArrayAdapter<Action> { FilterIconButton view = (FilterIconButton) convertView; Action action = getItem(position); view.setAction(action); - view.setup(action.getName(), null); + view.setup(action.getName(), null, this); view.setLayoutParams( new ListView.LayoutParams(mItemWidth, mItemHeight)); + view.setTag(position); + if (mCategory == MainPanel.LOOKS || mCategory == MainPanel.BORDERS) { + view.setBackground(null); + } return view; } if (convertView == null) { convertView = new CategoryView(getContext()); } CategoryView view = (CategoryView) convertView; - view.setAction(getItem(position)); + view.setAction(getItem(position), this); view.setLayoutParams( new ListView.LayoutParams(mItemWidth, mItemHeight)); + view.setTag(position); return view; } - public void setContainer(ListView container) { - mContainer = container; + public void setSelected(View v) { + int old = mSelectedPosition; + mSelectedPosition = (Integer) v.getTag(); + if (old != -1) { + invalidateView(old); + } + invalidateView(mSelectedPosition); } - public ListView getContainer() { - return mContainer; + public boolean isSelected(View v) { + return (Integer) v.getTag() == mSelectedPosition; + } + + private void invalidateView(int position) { + View child = null; + if (mContainer instanceof ListView) { + ListView lv = (ListView) mContainer; + child = lv.getChildAt(position - lv.getFirstVisiblePosition()); + } else { + CategoryTrack ct = (CategoryTrack) mContainer; + child = ct.getChildAt(position); + } + if (child != null) { + child.invalidate(); + } + } + + public void setContainer(View container) { + mContainer = container; } public void imageLoaded() { diff --git a/src/com/android/gallery3d/filtershow/category/CategoryPanel.java b/src/com/android/gallery3d/filtershow/category/CategoryPanel.java index 9ddfcabe0..abae80f93 100644 --- a/src/com/android/gallery3d/filtershow/category/CategoryPanel.java +++ b/src/com/android/gallery3d/filtershow/category/CategoryPanel.java @@ -50,18 +50,22 @@ public class CategoryPanel extends Fragment { switch (adapter) { case MainPanel.LOOKS: { mAdapter = activity.getCategoryLooksAdapter(); + mAdapter.initializeSelection(MainPanel.LOOKS); break; } case MainPanel.BORDERS: { mAdapter = activity.getCategoryBordersAdapter(); + mAdapter.initializeSelection(MainPanel.BORDERS); break; } case MainPanel.GEOMETRY: { mAdapter = activity.getCategoryGeometryAdapter(); + mAdapter.initializeSelection(MainPanel.GEOMETRY); break; } case MainPanel.FILTERS: { mAdapter = activity.getCategoryFiltersAdapter(); + mAdapter.initializeSelection(MainPanel.FILTERS); break; } } @@ -90,6 +94,7 @@ public class CategoryPanel extends Fragment { CategoryTrack panel = (CategoryTrack) panelView; mAdapter.setUseFilterIconButton(true); panel.setAdapter(mAdapter); + mAdapter.setContainer(panel); } else { ListView panel = (ListView) main.findViewById(R.id.listItems); panel.setAdapter(mAdapter); diff --git a/src/com/android/gallery3d/filtershow/category/CategoryView.java b/src/com/android/gallery3d/filtershow/category/CategoryView.java index c101f983f..84a973b50 100644 --- a/src/com/android/gallery3d/filtershow/category/CategoryView.java +++ b/src/com/android/gallery3d/filtershow/category/CategoryView.java @@ -29,6 +29,7 @@ import android.view.View; import com.android.gallery3d.R; import com.android.gallery3d.filtershow.FilterShowActivity; import com.android.gallery3d.filtershow.filters.FilterRepresentation; +import com.android.gallery3d.filtershow.ui.SelectionRenderer; public class CategoryView extends View implements View.OnClickListener { @@ -40,6 +41,9 @@ public class CategoryView extends View implements View.OnClickListener { private static int sTextSize = 32; private int mTextColor; private int mBackgroundColor; + private Paint mSelectPaint; + CategoryAdapter mAdapter; + private int mSelectionStroke; public static void setTextSize(int size) { sTextSize = size; @@ -55,6 +59,10 @@ public class CategoryView extends View implements View.OnClickListener { Resources res = getResources(); mBackgroundColor = res.getColor(R.color.filtershow_categoryview_background); mTextColor = res.getColor(R.color.filtershow_categoryview_text); + mSelectionStroke = res.getDimensionPixelSize(R.dimen.thumbnail_margin); + mSelectPaint = new Paint(); + mSelectPaint.setStyle(Paint.Style.FILL); + mSelectPaint.setColor(res.getColor(R.color.filtershow_category_selection)); } public void drawText(Canvas canvas, String text) { @@ -71,6 +79,7 @@ public class CategoryView extends View implements View.OnClickListener { canvas.drawText(text, x, y, mPaint); } + @Override public void onDraw(Canvas canvas) { canvas.drawColor(mBackgroundColor); if (mAction != null) { @@ -81,6 +90,10 @@ public class CategoryView extends View implements View.OnClickListener { } else { Bitmap bitmap = mAction.getImage(); canvas.drawBitmap(bitmap, 0, 0, mPaint); + if (mAdapter.isSelected(this)) { + SelectionRenderer.drawSelection(canvas, 0, 0, bitmap.getWidth(), + bitmap.getHeight(), mSelectionStroke, mSelectPaint); + } } mPaint.setColor(mBackgroundColor); mPaint.setStyle(Paint.Style.STROKE); @@ -93,8 +106,9 @@ public class CategoryView extends View implements View.OnClickListener { } } - public void setAction(Action action) { + public void setAction(Action action, CategoryAdapter adapter) { mAction = action; + mAdapter = adapter; invalidate(); } @@ -106,5 +120,6 @@ public class CategoryView extends View implements View.OnClickListener { public void onClick(View view) { FilterShowActivity activity = (FilterShowActivity) getContext(); activity.showRepresentation(mAction.getRepresentation()); + mAdapter.setSelected(this); } } diff --git a/src/com/android/gallery3d/filtershow/category/MainPanel.java b/src/com/android/gallery3d/filtershow/category/MainPanel.java index 7cadbc323..9a64ffbf3 100644 --- a/src/com/android/gallery3d/filtershow/category/MainPanel.java +++ b/src/com/android/gallery3d/filtershow/category/MainPanel.java @@ -24,6 +24,7 @@ import android.view.View; import android.view.ViewGroup; import android.widget.ImageButton; import android.widget.LinearLayout; + import com.android.gallery3d.R; import com.android.gallery3d.filtershow.FilterShowActivity; import com.android.gallery3d.filtershow.state.StatePanel; |