summaryrefslogtreecommitdiffstats
path: root/src/com/android/gallery3d/filtershow/EditorPlaceHolder.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/com/android/gallery3d/filtershow/EditorPlaceHolder.java')
-rw-r--r--src/com/android/gallery3d/filtershow/EditorPlaceHolder.java78
1 files changed, 78 insertions, 0 deletions
diff --git a/src/com/android/gallery3d/filtershow/EditorPlaceHolder.java b/src/com/android/gallery3d/filtershow/EditorPlaceHolder.java
new file mode 100644
index 000000000..1b6c5ea58
--- /dev/null
+++ b/src/com/android/gallery3d/filtershow/EditorPlaceHolder.java
@@ -0,0 +1,78 @@
+package com.android.gallery3d.filtershow;
+
+import android.content.Context;
+import android.util.Log;
+import android.view.View;
+import android.widget.FrameLayout;
+
+import com.android.gallery3d.filtershow.cache.ImageLoader;
+import com.android.gallery3d.filtershow.editors.Editor;
+import com.android.gallery3d.filtershow.imageshow.ImageShow;
+
+import java.lang.reflect.InvocationTargetException;
+import java.util.HashMap;
+import java.util.Vector;
+
+public class EditorPlaceHolder {
+ private static final String LOGTAG = "PanelController";
+
+ private FilterShowActivity mActivity = null;
+ private FrameLayout mContainer = null;
+ private HashMap<Integer, Editor> mEditors = new HashMap<Integer, Editor>();
+ private Vector<ImageShow> mOldViews = new Vector<ImageShow>();
+ private ImageLoader mImageLoader = null;
+
+ public EditorPlaceHolder(FilterShowActivity activity) {
+ mActivity = activity;
+ }
+
+ public void setContainer(FrameLayout container) {
+ mContainer = container;
+ }
+
+ public void addEditor(Editor c) {
+ mEditors.put(c.getID(), c);
+ }
+
+ public boolean contains(int type) {
+ if (mEditors.get(type) != null) {
+ return true;
+ }
+ return false;
+ }
+
+ public Editor showEditor(int type) {
+ Editor editor = mEditors.get(type);
+ if (editor == null) {
+ return null;
+ }
+
+ try {
+ editor.createEditor(mActivity, mContainer);
+ editor.setImageLoader(mImageLoader);
+ mContainer.setVisibility(View.VISIBLE);
+ mContainer.removeAllViews();
+ mContainer.addView(editor.getTopLevelView());
+ hideOldViews();
+ editor.setVisibility(View.VISIBLE);
+ return editor;
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ return null;
+ }
+
+ public void setOldViews(Vector<ImageShow> views) {
+ mOldViews = views;
+ }
+
+ public void hideOldViews() {
+ for (View view : mOldViews) {
+ view.setVisibility(View.GONE);
+ }
+ }
+
+ public void setImageLoader(ImageLoader imageLoader) {
+ mImageLoader = imageLoader;
+ }
+}