refresh frame fix, dblclk proxy viewer fix, vicon refresh fix for awdw resize, fix...
[goodguy/history.git] / cinelerra-5.1 / guicast / bctextbox.h
index a4d94e68958a32814b7c9300712e1ebdf0e9ef14..425768bfde593671d8c843de32a0ba865b295599 100644 (file)
@@ -23,6 +23,8 @@
 #define BCTEXTBOX_H
 
 #include "bclistbox.h"
+#include "bcmenuitem.h"
+#include "bcpopupmenu.h"
 #include "bcsubwindow.h"
 #include "bctumble.h"
 #include "fonts.h"
 
 
 class BC_TextBoxSuggestions;
-class BC_ScrollTextBoxYScroll;
 
+class BC_ScrollTextBoxXScroll;
+class BC_ScrollTextBoxYScroll;
+class BC_ScrollTextBoxText;
+class BC_TextMenu;
 
 class BC_TextBox : public BC_SubWindow
 {
@@ -69,6 +74,7 @@ public:
 
 
        friend class BC_TextBoxSuggestions;
+       friend class BC_ScrollTextBox;
 
 
 // Whenever the contents of the text change
@@ -97,6 +103,7 @@ public:
        int button_release_event();
        int repeat_event(int64_t repeat_id);
        int keypress_event();
+       int selection_clear_event();
        int activate();
        int deactivate();
        const char* get_text();
@@ -106,9 +113,19 @@ public:
 // Set top left of text view
        void set_text_row(int row);
        int get_text_row();
+       int get_text_x();
+       int get_text_y();
+       void set_text_x(int v);
+       void set_text_y(int v);
+       int get_back_color();
+       void set_back_color(int v);
 
        int reposition_window(int x, int y, int w = -1, int rows = -1);
        int uses_text();
+       int cut(int do_update);
+       int copy(int do_update);
+       int paste(int do_update);
+       
        static int calculate_h(BC_WindowBase *gui, int font, int has_border, int rows);
        static int calculate_row_h(int rows, BC_WindowBase *parent_window, int has_border = 1, int font = MEDIUMFONT);
        static int pixels_to_rows(BC_WindowBase *window, int font, int pixels);
@@ -143,10 +160,12 @@ public:
 // column - starting column to replace
        void no_suggestions();
        void set_suggestions(ArrayList<char*> *suggestions, int column);
-       BC_ScrollTextBoxYScroll *yscroll;
 
+       BC_ScrollTextBoxXScroll *xscroll;
+       BC_ScrollTextBoxYScroll *yscroll;
 private:
        int reset_parameters(int rows, int has_border, int font, int size);
+       BC_TextMenu *menu;
        void draw(int flush);
        void draw_border();
        void draw_cursor();
@@ -158,6 +177,7 @@ private:
 // ibeam_left causes the ibeam to move left.
        int is_separator(const char *txt, int i);
        void do_separators(int ibeam_left);
+       int get_x_position(int i, int start=0);
        void get_ibeam_position(int &x, int &y);
        void find_ibeam(int dispatch_event);
        void select_word(int &letter1, int &letter2, int ibeam_letter);
@@ -192,7 +212,7 @@ private:
        int high_color, back_color;
        int background_color;
        int size, tsize, dirty;
-       int wlen, wsize, *positions, plen;
+       int wlen, wsize;
        char temp_string[KEYPRESSLEN];
        int is_utf8;
        int active;
@@ -208,6 +228,7 @@ private:
        ArrayList<BC_ListBoxItem*> *suggestions;
        BC_TextBoxSuggestions *suggestions_popup;
        int suggestion_column;
+       int selection_active;
 };
 
 
@@ -224,14 +245,10 @@ public:
 };
 
 
-
-class BC_ScrollTextBoxText;
-class BC_ScrollTextBoxYScroll;
-
-
 class BC_ScrollTextBox
 {
        BC_ScrollTextBoxText *text;
+       BC_ScrollTextBoxXScroll *xscroll;
        BC_ScrollTextBoxYScroll *yscroll;
        BC_WindowBase *parent_window;
        const char *default_text;
@@ -240,6 +257,7 @@ class BC_ScrollTextBox
        int x, y, w, rows;
 
        friend class BC_ScrollTextBoxText;
+       friend class BC_ScrollTextBoxXScroll;
        friend class BC_ScrollTextBoxYScroll;
 public:
        BC_ScrollTextBox(BC_WindowBase *parent_window,
@@ -260,13 +278,15 @@ public:
        void update(const char *text);
        void update(const wchar_t *wtext);
        void reposition_window(int x, int y, int w, int rows);
+       void update_scrollbars();
 // accessors
        int get_x() { return x; }
        int get_y() { return y; }
        int get_w() { return w; }
 // Visible rows for resizing
        int get_rows() { return rows; }
-
+       int get_x_pos();
+       void set_x_pos(int x);
 // forward functions
        int get_h();
        const char *get_text();
@@ -290,6 +310,15 @@ public:
        int button_release_event() { return gui->button_release_event(); }
 };
 
+class BC_ScrollTextBoxXScroll : public BC_ScrollBar
+{
+public:
+       BC_ScrollTextBoxXScroll(BC_ScrollTextBox *gui);
+       virtual ~BC_ScrollTextBoxXScroll();
+       int handle_event();
+       BC_ScrollTextBox *gui;
+};
+
 class BC_ScrollTextBoxYScroll : public BC_ScrollBar
 {
 public:
@@ -322,6 +351,9 @@ public:
        int get_y();
        int get_w();
        int get_h();
+       int get_show_query();
+       void set_show_query(int v);
+
        void update(const char *text);
        void update_list(ArrayList<BC_ListBoxItem*> *data);
        void reposition_window(int x, int y);
@@ -410,6 +442,7 @@ public:
        void set_precision(int precision);
        void set_increment(float value);
        void set_log_floatincrement(int value);
+       void set_tooltip(const char *text);
 
        friend class BC_TumbleTextBoxText;
        friend class BC_TumbleTextBoxTumble;
@@ -431,7 +464,7 @@ class BC_TumbleTextBoxText : public BC_TextBox
 {
 public:
        BC_TumbleTextBoxText(BC_TumbleTextBox *popup, int64_t default_value, int x, int y);
-       BC_TumbleTextBoxText(BC_TumbleTextBox *popup, float default_value, int x, int y);
+       BC_TumbleTextBoxText(BC_TumbleTextBox *popup, float default_value, int x, int y, int precision);
        virtual ~BC_TumbleTextBoxText();
        int handle_event();
        int button_press_event();
@@ -439,4 +472,40 @@ public:
 };
 
 
+class BC_TextMenu : public BC_PopupMenu
+{
+public:
+       BC_TextMenu(BC_TextBox *textbox);
+       ~BC_TextMenu();
+       
+       void create_objects();
+       
+       BC_TextBox *textbox;
+};
+
+class BC_TextMenuCut : public BC_MenuItem
+{
+public:
+       BC_TextMenuCut(BC_TextMenu *menu);
+       int handle_event();
+       BC_TextMenu *menu;
+};
+
+class BC_TextMenuCopy : public BC_MenuItem
+{
+public:
+       BC_TextMenuCopy(BC_TextMenu *menu);
+       int handle_event();
+       BC_TextMenu *menu;
+};
+
+class BC_TextMenuPaste : public BC_MenuItem
+{
+public:
+       BC_TextMenuPaste(BC_TextMenu *menu);
+       int handle_event();
+       BC_TextMenu *menu;
+};
+
+
 #endif