X-Git-Url: https://git.cinelerra-gg.org/git/?a=blobdiff_plain;f=cinelerra-5.1%2Fguicast%2Fvicon.h;h=8688d4c433bedd15d4dc618ac210a49c0890a9d9;hb=f5725c7e12def18fec49a295dad688652edaa4b3;hp=bab38462b643b284aed7059b0e642e2e6bf510aa;hpb=2292a9b260b7c5f0ee85280823ef760910ace931;p=goodguy%2Fcinelerra.git diff --git a/cinelerra-5.1/guicast/vicon.h b/cinelerra-5.1/guicast/vicon.h index bab38462..8688d4c4 100644 --- a/cinelerra-5.1/guicast/vicon.h +++ b/cinelerra-5.1/guicast/vicon.h @@ -9,16 +9,16 @@ #include "vicon.inc" #include "vframe.h" -typedef void VIconDrawVFrame(BC_WindowBase *wdw, VFrame *frame); - class ViewPopup : public BC_Popup { public: VIconThread *vt; - int keypress_event(); - int button_press_event(); - int cursor_motion_event(); + virtual int keypress_event(); + virtual int button_press_event() { return 0; } + virtual int button_release_event() { return 0; } + virtual int cursor_motion_event() { return 0; } + virtual void draw_vframe(VFrame *frame); - ViewPopup(VIconThread *vt, VFrame *frame, int x, int y, int w, int h); + ViewPopup(VIconThread *vt, int x, int y, int w, int h); ~ViewPopup(); }; @@ -39,7 +39,7 @@ public: class VIcon { public: - int vw, vh, in_use, hidden; + int w, h, in_use, hidden; ArrayList images; int64_t seq_no; double cycle_start, age, frame_rate; @@ -59,8 +59,6 @@ public: virtual void load_audio() {} virtual void start_audio() {} virtual void stop_audio() {} - virtual int popup_button_press(int x, int y) { return 0; } - virtual int popup_cursor_motion(int x, int y) { return 0; } void add_image(VFrame *frm, int ww, int hh, int vcmdl); void draw_vframe(VIconThread *vt, BC_WindowBase *wdw, int x, int y); @@ -78,13 +76,16 @@ public: Timer *timer; Condition *draw_lock; ViewPopup *view_win; - VIcon *viewing, *vicon; - int view_w, view_h; + VIcon *viewing, *vicon, *solo; + int vw, vh, view_w, view_h; int draw_x0, draw_y0; int draw_x1, draw_y1; int img_dirty, win_dirty; double refresh_rate; + int64_t now; + int64_t draw_flash; int64_t stop_age; + int64_t seq_no; ArrayListt_heap; VIcon *low_vicon(); @@ -93,26 +94,30 @@ public: void run(); void flash(); int draw(VIcon *vicon); - int update_view(); + int update_view(int do_audio); void draw_images(); void start_drawing(); void stop_drawing(); + void stop_viewing(); void reset_images(); void remove_vicon(int i); int keypress_event(int key); + int cursor_inside(int x, int y); void set_drawing_area(int x0, int y0, int x1, int y1); - void set_view_popup(VIcon *vicon, VIconDrawVFrame *draw_vfrm=0); + void set_view_popup(VIcon *vicon); + int zoom_scale(int dir); void close_view_popup(); void hide_vicons(int v=1); - ViewPopup *new_view_window(VFrame *frame); + int show_vicon(VIcon *next); + virtual ViewPopup *new_view_window(ViewPopup *vpopup); virtual bool visible(VIcon *vicon, int x, int y); virtual void drawing_started() {} virtual void drawing_stopped() {} - static VIconDrawVFrame draw_vframe; - VIconDrawVFrame *draw_vfrm; - VIconThread(BC_WindowBase *wdw, int vw=4*VICON_WIDTH, int vh=4*VICON_HEIGHT); + VIconThread(BC_WindowBase *wdw, + int vw=VICON_WIDTH, int vh=VICON_HEIGHT, + int view_w=4*VICON_WIDTH, int view_h=4*VICON_HEIGHT); ~VIconThread(); };