rework resource wdw preview mode
[goodguy/cinelerra.git] / cinelerra-5.1 / cinelerra / awindowgui.h
index dadc44bc440576d4ec0ab54931968149c02015fb..fc92007026e64f619bb5781b3f09d6eaecbd8b75 100644 (file)
 #define ASSET_VIEW_MEDIA_MAP 3
 #define ASSET_VIEW_FULL 4
 
+#define AVICON_FULL_PLAY   0
+#define AVICON_MOUSE_OVER  1
+#define AVICON_SRC_TARGET  2
+#define AVICON_NO_PLAY     3
+#define AVICON_PLAY_MODES  4
+
 class AWindowFolderItem : public BC_ListBoxItem
 {
 public:
@@ -176,6 +182,7 @@ public:
                        int x, int y, int w, int h);
        ~AssetViewPopup();
 
+       int reposition_window(int x, int y, int w, int h);
        int button_press_event();
        int button_release_event();
        int cursor_motion_event();
@@ -194,8 +201,9 @@ public:
        AssetVIconThread(AWindowGUI *gui, Preferences *preferences);
        ~AssetVIconThread();
 
-       void set_view_popup(AssetVIcon *v, int draw_mode=-1);
-       ViewPopup *new_view_window();
+       void set_view_popup(AssetVIcon *v, int draw_mode);
+       void set_view_popup(AssetVIcon *v);
+       ViewPopup *new_view_window(ViewPopup *popup);
        void drawing_started();
        void drawing_stopped();
        void close_view_popup();
@@ -275,8 +283,8 @@ public:
        bool protected_pixmap(BC_Pixmap *pixmap);
        int save_defaults(BC_Hash *defaults);
        int load_defaults(BC_Hash *defaults);
-       void start_vicon_drawing();
-       void stop_vicon_drawing();
+       int start_vicon_drawing();
+       int stop_vicon_drawing();
        void close_view_popup();
        void update_picon(Indexable *indexable);
        int cycle_assetlist_format();
@@ -361,7 +369,7 @@ public:
 
        AVIconDrawing *avicon_drawing;
        int avicon_w, avicon_h;
-       int vicon_drawing;
+       int vicon_drawing, play_off;
        int allow_iconlisting;
 
 // Create custom atoms to be used for async messages between windows
@@ -395,7 +403,8 @@ public:
        int drag_stop_event();
        int button_press_event();
        int column_resize_event();
-       int focus_in_event();
+       int cursor_enter_event();
+       int cursor_leave_event();
        int focus_out_event();
        void update_vicon_area();
        int mouse_over_event(int no);
@@ -570,16 +579,28 @@ public:
        int idx;
 };
 
-class AVIconDrawing : public BC_Toggle
+class AVIconDrawingItem : public BC_MenuItem
 {
 public:
-       AWindowGUI *agui;
-
+       AVIconDrawingItem(AVIconDrawing *avicon, const char *text, int id);
        int handle_event();
-       static void calculate_geometry(AWindowGUI *agui, VFrame **images, int *ww, int *hh);
 
-       AVIconDrawing(AWindowGUI *agui, int x, int y, VFrame **images);
+       AVIconDrawing *avicon;
+       int id;
+};
+
+class AVIconDrawing : public BC_PopupMenu
+{
+public:
+       AVIconDrawing(AWindowGUI *agui, int x, int y, int w, const char *text);
        ~AVIconDrawing();
+
+       static const char *avicon_names[];
+       void create_objects();
+       int button_press_event();
+       int draw_face(int dx, int color);
+
+       AWindowGUI *agui;
 };