X-Git-Url: https://git.cinelerra-gg.org/git/?p=goodguy%2Fcinelerra.git;a=blobdiff_plain;f=cinelerra-5.1%2Fcinelerra%2Fawindowgui.h;h=b52add9b2059f84f668084644b7456ecd3c52410;hp=41dd0491a4204db18f5874377ab0f01bbdc7c49c;hb=ddfda6a8cc59bda4dc734973c1c5fecaa31ea487;hpb=e41864cf7931bfb86f68c5d35d4578dfe161d386 diff --git a/cinelerra-5.1/cinelerra/awindowgui.h b/cinelerra-5.1/cinelerra/awindowgui.h index 41dd0491..b52add9b 100644 --- a/cinelerra-5.1/cinelerra/awindowgui.h +++ b/cinelerra-5.1/cinelerra/awindowgui.h @@ -44,13 +44,31 @@ #include "mwindow.inc" #include "mutex.inc" #include "pluginserver.inc" +#include "preferences.inc" #include "proxypopup.inc" #include "renderengine.inc" #include "samples.inc" #include "vicon.h" -#define SELECT_USED 0 -#define SELECT_UNUSED 1 +#define SELECT_ALL 0 +#define SELECT_USED 1 +#define SELECT_UNUSED 2 +#define SELECT_NONE 3 + +// in percent view_h +#define VIEW_POPUP_BAR_H 15 + +#define ASSET_VIEW_NONE 0 +#define ASSET_VIEW_ICON 1 +#define ASSET_VIEW_MEDIA 2 +#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 { @@ -80,7 +98,12 @@ public: void reset(); static void draw_hue_bar(VFrame *frame, double t); static void draw_wave(VFrame *frame, double *dp, int len, - int base_color, int line_color); + int base_color, int line_color, int x, int y, int w, int h); + static void draw_wave(VFrame *frame, double *dp, int len, + int base_color, int line_color, int x=0, int y=0) { + draw_wave(frame, dp, len, base_color, line_color, + x,y,frame->get_w(),frame->get_h()); + } void open_render_engine(EDL *edl, int is_audio); void close_render_engine(); void render_video(int64_t pos, VFrame *vfrm); @@ -108,6 +131,9 @@ public: int in_use; int persistent; time_t comments_time; + int comments_ffmt; + double comments_rate; + const char *comments_type; double sort_key; PluginServer *plugin; Label *label; @@ -139,6 +165,7 @@ public: AssetPicon *picon; VFrame *temp; int64_t length; + int broken; VFrame *frame(); int64_t set_seq_no(int64_t no); @@ -152,6 +179,43 @@ public: ~AssetVIcon(); }; +class AssetViewPopup : public ViewPopup +{ +public: + AssetViewPopup(VIconThread *vt, int draw_mode, + 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(); + int keypress_event(); + + void draw_vframe(VFrame *frame); + + int bar_h; + int draw_mode; + int dragging; +}; + +class AssetVIconThread : public VIconThread +{ +public: + AssetVIconThread(AWindowGUI *gui, Preferences *preferences); + ~AssetVIconThread(); + + void set_view_popup(AssetVIcon *v, int draw_mode); + void set_view_popup(AssetVIcon *v); + ViewPopup *new_view_window(ViewPopup *popup); + void stop_vicon_drawing(int wait=0); + + AWindowGUI *gui; + int draw_mode; + int vicon_cmodel; +}; + + class AWindowRemovePlugin; class AWindowRemovePluginGUI : public BC_Window { @@ -204,7 +268,7 @@ public: int drag_stop(); // Collect items into the drag vectors of MainSession void collect_assets(int proxy=0); - EDL *collect_proxy(Indexable *indexable); + EDL *collect_proxy(Asset *asset); void create_persistent_folder(ArrayList *output, int do_audio, int do_video, @@ -220,10 +284,11 @@ 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(int wait=0); void update_picon(Indexable *indexable); int cycle_assetlist_format(); + void hide_tip_info(); VFrame *get_picon(const char *name, const char *plugin_icons); VFrame *get_picon(const char *name); @@ -297,15 +362,17 @@ public: AddTools *add_tools; // Temporary for reading picons from files VFrame *temp_picon; - VIconThread *vicon_thread; + AssetVIconThread *vicon_thread; AssetVIconAudio *vicon_audio; int64_t plugin_visibility; AWindowRemovePlugin *remove_plugin; AVIconDrawing *avicon_drawing; - int avicon_w, avicon_h, vicon_drawing; + int avicon_w, avicon_h; + int vicon_drawing, play_off; int allow_iconlisting; + int tip_info; // Create custom atoms to be used for async messages between windows int create_custom_xatoms(); @@ -338,15 +405,17 @@ public: int drag_stop_event(); int button_press_event(); int column_resize_event(); - int focus_in_event(); - int focus_out_event(); int cursor_enter_event(); int cursor_leave_event(); + int focus_out_event(); void update_vicon_area(); int mouse_over_event(int no); + void show_tip_info(const char *info, int no); + void hide_tip_info(); MWindow *mwindow; AWindowGUI *gui; + int info_tip; }; class AWindowDivider : public BC_SubWindow @@ -515,16 +584,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; };