projects
/
goodguy
/
history.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
version update
[goodguy/history.git]
/
cinelerra-5.1
/
guicast
/
bcwindowbase.h
diff --git
a/cinelerra-5.1/guicast/bcwindowbase.h
b/cinelerra-5.1/guicast/bcwindowbase.h
index 5532ae49a5454803f0061c5527232e76a9460ab8..5d17e5ee3064362c2cc23e73d3b11c91b1f2e1ad 100644
(file)
--- a/
cinelerra-5.1/guicast/bcwindowbase.h
+++ b/
cinelerra-5.1/guicast/bcwindowbase.h
@@
-129,7
+129,7
@@
public:
class BC_WindowBase : public trace_info
{
public:
class BC_WindowBase : public trace_info
{
public:
- BC_WindowBase(
int opts=0
);
+ BC_WindowBase();
virtual ~BC_WindowBase();
friend class BC_Bar;
virtual ~BC_WindowBase();
friend class BC_Bar;
@@
-194,6
+194,7
@@
public:
virtual int drag_motion_event() { return 0; };
virtual int drag_stop_event() { return 0; };
virtual int uses_text() { return 0; };
virtual int drag_motion_event() { return 0; };
virtual int drag_stop_event() { return 0; };
virtual int uses_text() { return 0; };
+ virtual int selection_clear_event() { return 0; }
// Only if opengl is enabled
virtual int expose_event() { return 0; };
virtual int grab_event(XEvent *event) { return 0; };
// Only if opengl is enabled
virtual int expose_event() { return 0; };
virtual int grab_event(XEvent *event) { return 0; };
@@
-223,7
+224,6
@@
public:
int get_deleting();
int get_deleting();
-
//============================= OpenGL functions ===============================
// OpenGL functions must be called from inside a BC_Synchronous command.
// Create openGL context and bind it to the current window.
//============================= OpenGL functions ===============================
// OpenGL functions must be called from inside a BC_Synchronous command.
// Create openGL context and bind it to the current window.
@@
-268,6
+268,7
@@
public:
virtual int keyboard_listener(BC_WindowBase *wp) { return 0; }
void add_keyboard_listener(int(BC_WindowBase::*handler)(BC_WindowBase *));
void del_keyboard_listener(int(BC_WindowBase::*handler)(BC_WindowBase *));
virtual int keyboard_listener(BC_WindowBase *wp) { return 0; }
void add_keyboard_listener(int(BC_WindowBase::*handler)(BC_WindowBase *));
void del_keyboard_listener(int(BC_WindowBase::*handler)(BC_WindowBase *));
+ int resend_event(BC_WindowBase *window);
// Dimensions
virtual int get_w() { return w; }
virtual int get_h() { return h; }
// Dimensions
virtual int get_w() { return w; }
virtual int get_h() { return h; }
@@
-281,13
+282,13
@@
public:
int get_screen_x(int lock_display, int screen);
int get_screen_y(int lock_display, int screen);
// Get current position
int get_screen_x(int lock_display, int screen);
int get_screen_y(int lock_display, int screen);
// Get current position
- void get_abs_cursor
_xy
(int &abs_x, int &abs_y, int lock_window=0);
+ void get_abs_cursor(int &abs_x, int &abs_y, int lock_window=0);
int get_abs_cursor_x(int lock_window=0);
int get_abs_cursor_y(int lock_window=0);
int get_abs_cursor_x(int lock_window=0);
int get_abs_cursor_y(int lock_window=0);
- void get_pop_cursor
_xy
(int &px, int &py, int lock_window=0);
+ void get_pop_cursor(int &px, int &py, int lock_window=0);
int get_pop_cursor_x(int lock_window=0);
int get_pop_cursor_y(int lock_window=0);
int get_pop_cursor_x(int lock_window=0);
int get_pop_cursor_y(int lock_window=0);
- void get_relative_cursor
_xy
(int &x, int &y, int lock_window=0);
+ void get_relative_cursor(int &x, int &y, int lock_window=0);
int get_relative_cursor_x(int lock_window=0);
int get_relative_cursor_y(int lock_window=0);
void get_root_coordinates(int x, int y, int *abs_x, int *abs_y);
int get_relative_cursor_x(int lock_window=0);
int get_relative_cursor_y(int lock_window=0);
void get_root_coordinates(int x, int y, int *abs_x, int *abs_y);
@@
-449,9
+450,8
@@
public:
void set_background(VFrame *bitmap);
// Change the window title.
void put_title(const char *text);
void set_background(VFrame *bitmap);
// Change the window title.
void put_title(const char *text);
- void set_title(const char *text);
+ void set_title(const char *text
, int utf8=1
);
const char *get_title();
const char *get_title();
- void set_utf8title(const char *text);
// Change the window title. The title is translated internally.
void start_video();
void stop_video();
// Change the window title. The title is translated internally.
void start_video();
void stop_video();
@@
-461,6
+461,7
@@
public:
// Reroute toplevel events
int grab(BC_WindowBase *window);
int ungrab(BC_WindowBase *window);
// Reroute toplevel events
int grab(BC_WindowBase *window);
int ungrab(BC_WindowBase *window);
+ int grab_event_count();
// Grab button events
int grab_buttons();
void ungrab_buttons();
// Grab button events
int grab_buttons();
void ungrab_buttons();
@@
-528,6
+529,9
@@
public:
void restore_vm();
#endif
void restore_vm();
#endif
+ Atom to_clipboard(const char *data, long len, int clipboard_num);
+ long from_clipboard(char *data, long maxlen, int clipboard_num);
+ long clipboard_len(int clipboard_num);
int test_keypress;
char keys_return[KEYPRESSLEN];
int test_keypress;
char keys_return[KEYPRESSLEN];
@@
-596,6
+600,8
@@
private:
void put_event(XEvent *event);
// remove events queued for win
void dequeue_events(Window win);
void put_event(XEvent *event);
// remove events queued for win
void dequeue_events(Window win);
+// clear selection
+ int do_selection_clear(Atom selection);
// Recursive event dispatchers
int dispatch_resize_event(int w, int h);
// Recursive event dispatchers
int dispatch_resize_event(int w, int h);
@@
-616,6
+622,7
@@
private:
int dispatch_drag_motion();
int dispatch_drag_stop();
int dispatch_expose_event();
int dispatch_drag_motion();
int dispatch_drag_stop();
int dispatch_expose_event();
+ int dispatch_selection_clear();
// Get the port ID for a color model or return -1 for failure
int grab_port_id(int color_model);
// Get the port ID for a color model or return -1 for failure
int grab_port_id(int color_model);
@@
-651,6
+658,8
@@
private:
BC_PopupMenu* active_popup_menu;
// pointer to the active subwindow
BC_WindowBase* active_subwindow;
BC_PopupMenu* active_popup_menu;
// pointer to the active subwindow
BC_WindowBase* active_subwindow;
+// pointer to the window to which to put the current event
+ BC_WindowBase* resend_event_window;
// thread id of display locker
pthread_t display_lock_owner;
// thread id of display locker
pthread_t display_lock_owner;
@@
-668,6
+677,8
@@
private:
int video_on;
// Event handler completion
int done, done_set, window_running;
int video_on;
// Event handler completion
int done, done_set, window_running;
+// Enter/Leave notify state
+ int cursor_entered;
// Return value of event handler
int return_value;
// Motion event compression
// Return value of event handler
int return_value;
// Motion event compression
@@
-730,24
+741,21
@@
private:
// Popup window for tooltip
BC_Popup *tooltip_popup;
// If this subwindow has already shown a tooltip since the last EnterNotify
// Popup window for tooltip
BC_Popup *tooltip_popup;
// If this subwindow has already shown a tooltip since the last EnterNotify
- int options;
int flash_enabled;
// Font sets
int flash_enabled;
// Font sets
-
XFontSet smallfontset, mediumfontset, largefontset, bigfontset, curr_
fontset;
-
+
XFontSet smallfontset, mediumfontset, largefontset, bigfontset, clock
fontset;
+ XFontSet curr_fontset;
// Fonts
int current_font;
// Fonts
int current_font;
- XFontStruct *smallfont, *mediumfont, *largefont, *bigfont;
-
+ XFontStruct *smallfont, *mediumfont, *largefont, *bigfont, *clockfont;
// Must be void so users don't need to include the wrong libpng version.
// Must be void so users don't need to include the wrong libpng version.
- void *smallfont_xft, *mediumfont_xft, *largefont_xft, *bigfont_xft;
-
+ void *smallfont_xft, *mediumfont_xft, *largefont_xft, *bigfont_xft
, *clockfont_xft
;
+ void *bold_smallfont_xft, *bold_mediumfont_xft, *bold_largefont_xft;
int line_width;
int line_dashes;
int line_width;
int line_dashes;
- void *bold_largefont_xft, *bold_mediumfont_xft, *bold_smallfont_xft;
int64_t current_color;
// Coordinate of drag start
int drag_x, drag_y;
int64_t current_color;
// Coordinate of drag start
int drag_x, drag_y;
@@
-764,6
+772,8
@@
private:
Window rootwin;
// windows previous events happened in
Window event_win, drag_win;
Window rootwin;
// windows previous events happened in
Window event_win, drag_win;
+// selection clear
+ Atom event_selection;
Visual *vis;
Colormap cmap;
// Name of display
Visual *vis;
Colormap cmap;
// Name of display