35# include <FL/Fl_Cairo.H>
40# define Fl_Object Fl_Widget
130 static int e_is_click;
142 static int compose_state;
191 static unsigned char options_[OPTION_LAST];
192 static unsigned char options_read_;
199 static bool option(Fl_Option opt);
204 static void option(Fl_Option opt,
bool val);
217 static void **awake_data_;
218 static int awake_ring_size_;
219 static int awake_ring_head_;
220 static int awake_ring_tail_;
221 static const char* scheme_;
224 static int e_original_keysym;
225 static int scrollbar_size_;
238 static int arg(
int argc,
char **argv,
int& i);
240 static void args(
int argc,
char **argv);
248 static void display(
const char*);
267 static int scheme(
const char*);
269 static const char*
scheme() {
return scheme_;}
275 static int reload_scheme();
277 static void scheme_bg (
Fl_Image *i ) { scheme_bg_ = i; }
278 static int scrollbar_size();
279 static void scrollbar_size(
int W);
283 static double wait(
double time);
287 static Fl_Widget* readqueue();
373 static void redraw();
410 static void (*
error)(
const char*, ...);
427 static void (*
fatal)(
const char*, ...);
490 static int event() {
return e_number;}
661 static int event_key(
int key);
667 static int get_key(
int key);
691 static int compose(
int &del);
692 static void compose_reset();
693 static int event_inside(
int,
int,
int,
int);
694 static int event_inside(
const Fl_Widget*);
730 static void copy(
const char* stuff,
int len,
int destination = 0);
765 static void selection(
Fl_Widget &owner,
const char*,
int len);
791 static void screen_xywh(
int &X,
int &Y,
int &W,
int &H,
int mx,
int my);
792 static void screen_xywh(
int &X,
int &Y,
int &W,
int &H,
int n);
793 static void screen_xywh(
int &X,
int &Y,
int &W,
int &H,
int mx,
int my,
int mw,
int mh);
794 static void screen_dpi(
float &h,
float &v,
int n=0);
809 static void set_color(
Fl_Color i,
unsigned c);
810 static unsigned get_color(
Fl_Color i);
817 static void free_color(
Fl_Color i,
int overlay = 0);
820 static const char* get_font(
Fl_Font);
833 static const char* get_font_name(
Fl_Font,
int* attributes = 0);
845 static int get_font_sizes(
Fl_Font,
int*& sizep);
846 static void set_font(
Fl_Font,
const char*);
866 static Fl_Font set_fonts(
const char* = 0);
989 static void unlock();
990 static void awake(
void* message = 0);
999 static void* thread_message();
1032 static void delete_widget(
Fl_Widget *w);
1033 static void do_widget_deletion();
1034 static void watch_widget_pointer(
Fl_Widget *&w);
1035 static void release_widget_pointer(
Fl_Widget *&w);
1036 static void clear_widget_pointer(
Fl_Widget const *w);
1044 static cairo_surface_t * cairo_create_surface ( Window xid,
int W,
int H );
1047 static cairo_t * cairo_make_current( cairo_t *cc );
1063 static cairo_t *
cairo_cc() {
return fl_cairo_context; }
1164 FL_ANTIALIAS_DEFAULT,
1169void fl_set_antialias (
int v );
This file contains type definitions and general enumerations.
#define FL_BUTTON2
Mouse button 2 is pushed.
Definition Enumerations.H:437
#define FL_Button
A mouse button; use Fl_Button + n for mouse button n.
Definition Enumerations.H:341
#define FL_CTRL
One of the ctrl keys is down.
Definition Enumerations.H:428
int Fl_Font
A font number is an index into the internal font table.
Definition Enumerations.H:707
unsigned Fl_Align
FLTK type for alignment control.
Definition Enumerations.H:658
#define FL_ALT
One of the alt keys is down.
Definition Enumerations.H:429
#define FL_COMMAND
An alias for FL_CTRL on WIN32 and X11, or FL_META on MacOS X.
Definition Enumerations.H:449
unsigned int Fl_Color
an FLTK color value
Definition Enumerations.H:764
#define FL_BUTTON3
Mouse button 3 is pushed.
Definition Enumerations.H:438
#define FL_SHIFT
One of the shift keys is down.
Definition Enumerations.H:426
Fl_Labeltype
The labeltype() method sets the type of the label.
Definition Enumerations.H:601
Fl_Boxtype
Definition Enumerations.H:472
#define FL_BUTTON1
Mouse button 1 is pushed.
Definition Enumerations.H:436
Fl_Image is the base class used for caching and drawing all kinds of images in FLTK.
Definition Fl_Image.H:51
This widget produces an actual window.
Definition Fl_Window.H:58
static int args(int argc, char **argv, int &i, Fl_Args_Handler cb=0)
Parse command line switches using the cb argument handler.
Definition Fl_arg.cxx:290
static int arg(int argc, char **argv, int &i)
Parse a single switch from argv, starting at word i.
Definition Fl_arg.cxx:140
static void remove_fd(int, int when)
Removes a file descriptor handler.
static const char * scheme()
See void scheme(const char *name)
Definition Fl.H:269
static void own_colormap()
Makes FLTK use its own colormap.
Definition Fl_own_colormap.cxx:60
static int box_dx(Fl_Boxtype)
Returns the X offset for the given boxtype.
Definition fl_boxtype.cxx:334
static int gl_visual(int, int *alist=0)
This does the same thing as Fl::visual(int) but also requires OpenGL drawing to work.
Definition gl_start.cxx:112
static int has_idle(Fl_Idle_Handler cb, void *data=0)
Returns true if the specified idle callback is currently installed.
Definition Fl_add_idle.cxx:89
static void background(uchar, uchar, uchar)
Changes fl_color(FL_BACKGROUND_COLOR) to the given color, and changes the gray ramp from 32 to 56 to ...
Definition Fl_get_system_colors.cxx:56
static void remove_fd(int)
Removes a file descriptor handler.
static void remove_idle(Fl_Idle_Handler cb, void *data=0)
Removes the specified idle callback, if it is installed.
Definition Fl_add_idle.cxx:101
@ OPTION_ARROW_FOCUS
When switched on, moving the text cursor beyond the start or end of a text in a text widget will chan...
Definition Fl.H:161
@ OPTION_LAST
For internal use only.
Definition Fl.H:187
@ OPTION_DND_TEXT
If text drag-and-drop is enabled, the user can select and drag text from any text widget.
Definition Fl.H:180
@ OPTION_VISIBLE_FOCUS
If visible focus is switched on, FLTK will draw a dotted rectangle inside the widget that will receiv...
Definition Fl.H:176
@ OPTION_SHOW_TOOLTIPS
If tooltips are enabled, hovering the mouse over a widget with a tooltip text will open a little tool...
Definition Fl.H:184
static void damage(int d)
If true then flush() will do something.
Definition Fl.H:147
static void add_idle(Fl_Idle_Handler cb, void *data=0)
Adds a callback function that is called every time by Fl::wait() and also makes it act as though the ...
Definition Fl_add_idle.cxx:69
static void dnd_text_ops(int v)
Gets or sets whether drag and drop text operations are supported.
Definition Fl.H:975
static void(* idle)()
The currently executing idle callback function: DO NOT USE THIS DIRECTLY!
Definition Fl.H:213
static Fl_Box_Draw_F * get_boxtype(Fl_Boxtype)
Gets the current box drawing function for the specified box type.
Definition fl_boxtype.cxx:386
static const char *const help
Usage string displayed if Fl::args() detects an invalid argument.
Definition Fl.H:245
static void release()
Releases the current grabbed window, equals grab(0).
Definition Fl.H:952
static int visual(int)
Selects a visual so that your graphics are drawn correctly.
Definition Fl_visual.cxx:106
static void set_boxtype(Fl_Boxtype, Fl_Box_Draw_F *, uchar, uchar, uchar, uchar)
Sets the function to call to draw a specific boxtype.
Definition fl_boxtype.cxx:390
static void set_idle(Fl_Old_Idle_Handler cb)
Sets an idle callback.
Definition Fl.H:946
static void add_fd(int fd, int when, Fl_FD_Handler cb, void *=0)
Adds file descriptor fd to listen to.
static void display(const char *)
Sets the X display to use for all windows.
Definition Fl_display.cxx:41
static int get_awake_handler_(Fl_Awake_Handler &, void *&)
Gets the last stored awake handler for use in awake().
Definition Fl_lock.cxx:107
static void background2(uchar, uchar, uchar)
Changes the alternative background color.
Definition Fl_get_system_colors.cxx:87
static int box_dw(Fl_Boxtype)
Returns the width offset for the given boxtype.
Definition fl_boxtype.cxx:365
static int box_dy(Fl_Boxtype)
Returns the Y offset for the given boxtype.
Definition fl_boxtype.cxx:359
static int dnd_text_ops()
Gets or sets whether drag and drop text operations are supported.
Definition Fl.H:982
static void grab(Fl_Window &win)
See grab(Fl_Window*)
Definition Fl.H:948
static bool option(Fl_Option opt)
FLTK library options management.
Definition Fl.cxx:1980
static int damage()
If true then flush() will do something.
Definition Fl.H:372
static void set_labeltype(Fl_Labeltype, Fl_Labeltype from)
Sets the functions to call to draw and measure a specific labeltype.
static void add_fd(int fd, Fl_FD_Handler cb, void *=0)
See void add_fd(int fd, int when, Fl_FD_Handler cb, void* = 0)
static int draw_box_active()
Determines if the current draw box is active or inactive.
Definition fl_boxtype.cxx:63
static double version()
Returns the compiled-in value of the FL_VERSION constant.
Definition Fl.cxx:139
static void visible_focus(int v)
Gets or sets the visible keyboard focus on buttons and other non-text widgets.
Definition Fl.H:960
static int visible_focus()
Gets or sets the visible keyboard focus on buttons and other non-text widgets.
Definition Fl.H:966
static void get_system_colors()
Read the user preference colors from the system and use them to call Fl::foreground(),...
Definition Fl_get_system_colors.cxx:231
static int box_dh(Fl_Boxtype)
Returns the height offset for the given boxtype.
Definition fl_boxtype.cxx:371
static void foreground(uchar, uchar, uchar)
Changes fl_color(FL_FOREGROUND_COLOR).
Definition Fl_get_system_colors.cxx:75
static int add_awake_handler_(Fl_Awake_Handler, void *)
Adds an awake handler for use in awake().
Definition Fl_lock.cxx:84
unsigned int Fl_Shortcut
24-bit Unicode character + 8-bit indicator for keyboard flags
Definition fl_types.h:55
unsigned char uchar
unsigned char
Definition fl_types.h:39
header for Unicode and UTF8 chracter handling
void(* Fl_Timeout_Handler)(void *data)
Signature of some timeout callback functions passed as parameters.
Definition Fl.H:79
int(* Fl_Event_Handler)(int event)
Signature of add_handler functions passed as parameters.
Definition Fl.H:94
void(* Fl_Old_Idle_Handler)()
Signature of set_idle callback functions passed as parameters.
Definition Fl.H:88
void(* Fl_Awake_Handler)(void *data)
Signature of some wakeup callback functions passed as parameters.
Definition Fl.H:82
int(* Fl_Event_Dispatch)(int event, Fl_Window *w)
Signature of event_dispatch functions passed as parameters.
Definition Fl.H:107
void Fl_Label_Draw_F(const Fl_Label *label, int x, int y, int w, int h, Fl_Align align)
Signature of some label drawing functions passed as parameters.
Definition Fl.H:70
int(* Fl_Args_Handler)(int argc, char **argv, int &i)
Signature of args functions passed as parameters.
Definition Fl.H:103
void(* Fl_FD_Handler)(int fd, void *data)
Signature of add_fd functions passed as parameters.
Definition Fl.H:91
void Fl_Label_Measure_F(const Fl_Label *label, int &width, int &height)
Signature of some label measurement functions passed as parameters.
Definition Fl.H:73
void(* Fl_Abort_Handler)(const char *format,...)
Signature of set_abort functions passed as parameters.
Definition Fl.H:97
void Fl_Box_Draw_F(int x, int y, int w, int h, Fl_Color color)
Signature of some box drawing functions passed as parameters.
Definition Fl.H:76
void(* Fl_Atclose_Handler)(Fl_Window *window, void *data)
Signature of set_atclose functions passed as parameters.
Definition Fl.H:100
void(* Fl_Idle_Handler)(void *data)
Signature of add_idle callback functions passed as parameters.
Definition Fl.H:85
static void paste(Fl_Widget &receiver, int source)
Pastes the data from the selection buffer (source is 0) or the clipboard (source is 1) into receiver.
static Fl_Widget * selection_owner()
back-compatibility only: Gets the widget owning the current selection
Definition Fl.H:763
static int dnd()
Initiate a Drag And Drop operation.
Definition fl_dnd_win32.cxx:526
static void copy(const char *stuff, int len, int destination=0)
Copies the data pointed to by stuff to the selection buffer (destination is 0) or the clipboard (dest...
static void event_clicks(int i)
Manually sets the number returned by Fl::event_clicks().
Definition Fl.H:553
static void event_is_click(int i)
Clears the value returned by Fl::event_is_click().
Definition Fl.H:568
static int event_y()
Returns the mouse position of the event relative to the Fl_Window it was passed to.
Definition Fl.H:500
static int event_key()
Gets which key on the keyboard was last pushed.
Definition Fl.H:613
static int event_alt()
Returns non-zero if the Alt key is pressed.
Definition Fl.H:914
static int event_state(int i)
See int event_state()
Definition Fl.H:601
static Fl_Widget * focus()
Gets the current Fl::focus() widget.
Definition Fl.H:709
static int event_length()
Returns the length of the text in Fl::event_text().
Definition Fl.H:689
static int event_dy()
Returns the current vertical mouse scrolling associated with the FL_MOUSEWHEEL event.
Definition Fl.H:524
static int event_x_root()
Returns the mouse position on the screen of the event.
Definition Fl.H:507
static Fl_Widget * pushed()
Gets the widget that is being pushed.
Definition Fl.H:706
static int event_button1()
Returns non-zero if mouse button 1 is currently held down.
Definition Fl.H:928
static int event_button3()
Returns non-zero if button 3 is currently held down.
Definition Fl.H:938
static int event_command()
Returns non-zero if the FL_COMMAND key is pressed, either FL_CTRL or on OSX FL_META.
Definition Fl.H:912
static void get_mouse(int &, int &)
Return where the mouse is on the screen by doing a round-trip query to the server.
static int event_button()
Gets which particular mouse button caused the current event.
Definition Fl.H:575
static int event_x()
Returns the mouse position of the event relative to the Fl_Window it was passed to.
Definition Fl.H:495
static int event_y_root()
Returns the mouse position on the screen of the event.
Definition Fl.H:514
static void set_mouse(int x, int y)
Set the pointer position in screen relative coordinates.
static int event_shift()
Returns non-zero if the Shift key is pressed.
Definition Fl.H:908
static int event()
Returns the last event that was processed.
Definition Fl.H:490
static int event_ctrl()
Returns non-zero if the Control key is pressed.
Definition Fl.H:910
static Fl_Widget * belowmouse()
Gets the widget that is below the mouse.
Definition Fl.H:702
static int event_button2()
Returns non-zero if button 2 is currently held down.
Definition Fl.H:933
static int event_dx()
Returns the current horizontal mouse scrolling associated with the FL_MOUSEWHEEL event.
Definition Fl.H:519
static int event_original_key()
Returns the keycode of the last key event, regardless of the NumLock state.
Definition Fl.H:622
static int event_is_click()
Returns non-zero if the mouse has not moved far enough and not enough time has passed since the last ...
Definition Fl.H:561
static const char * event_text()
Returns the text associated with the current event, including FL_PASTE or FL_DND_RELEASE events.
Definition Fl.H:682
static int event_buttons()
Returns the mouse buttons state bits; if non-zero, then at least one button is pressed now.
Definition Fl.H:923
static int event_state()
This is a bitfield of what shift states were on and what mouse buttons were held down during the most...
Definition Fl.H:599
static int event_clicks()
Returns non zero if we had a double click event.
Definition Fl.H:545
static int h()
Returns the height of the screen work area in pixels.
static int x()
Returns the origin of the current screen work area, where 0 indicates the left side of the screen.
static int w()
Returns the width of the screen work area in pixels.
static void screen_xywh(int &X, int &Y, int &W, int &H)
Gets the bounding box of a screen that contains the mouse pointer.
Definition Fl.H:788
static int y()
Returns the origin of the current screen work area, where 0 indicates the top edge of the screen.
static int screen_count()
Gets the number of available screens.
Definition screen_xywh.cxx:192
static Fl_Window * first_window()
Returns the first top-level window in the list of shown() windows.
Definition Fl.cxx:697
static Fl_Window * next_window(const Fl_Window *)
Returns the next top-level window in the list of shown() windows.
Definition Fl.cxx:707
static void(* atclose)(Fl_Window *, void *)
Back compatibility: default window callback handler.
Definition Fl.H:897
static Fl_Window * modal()
Returns the top-most modal() window currently shown.
Definition Fl.H:446
static void set_abort(Fl_Abort_Handler f)
For back compatibility, sets the void Fl::fatal handler callback.
Definition Fl.H:896
static Fl_Window * grab()
Returns the window that currently receives all events.
Definition Fl.H:452
static void default_atclose(Fl_Window *, void *)
Default callback for window widgets.
Definition Fl_Window.cxx:163
static void set_atclose(Fl_Atclose_Handler f)
For back compatibility, sets the Fl::atclose handler callback.
Definition Fl.H:902
static cairo_t * cairo_cc()
when FLTK_HAVE_CAIRO is defined and cairo_autolink_context() is true, any current window dc is linked...
Definition Fl.H:1063
static void(* error)(const char *,...)
FLTK calls Fl::error() to output a normal error message.
Definition Fl.H:410
static void(* fatal)(const char *,...)
FLTK calls Fl::fatal() to output a fatal error message.
Definition Fl.H:427
static void(* warning)(const char *,...)
FLTK calls Fl::warning() to output a warning message.
Definition Fl.H:395
This struct stores all information for a text or mixed graphics label.
Definition Fl_Widget.H:75