FLTK 1.4.0
|
Common dialog functions for file selection, message output, and more. More...
Files | |
file | fl_ask.cxx |
Utility functions for common dialogs. | |
Classes | |
class | Fl_Color_Chooser |
The Fl_Color_Chooser widget provides a standard RGB color chooser. More... | |
class | Fl_File_Chooser |
The Fl_File_Chooser widget displays a standard file selection dialog that supports various selection modes. More... | |
Functions | |
void | fl_alert (const char *fmt,...) |
Shows an alert message dialog box. More... | |
int | fl_ask (const char *fmt,...) |
Shows a dialog displaying the fmt message, this dialog features 2 yes/no buttons. More... | |
void | fl_beep (int type) |
Emits a system beep. More... | |
int | fl_choice (const char *fmt, const char *b0, const char *b1, const char *b2,...) |
Shows a dialog displaying the printf style fmt message. More... | |
int | fl_choice_n (const char *fmt, const char *b0, const char *b1, const char *b2,...) |
Shows a dialog displaying the printf style fmt message. More... | |
int | fl_color_chooser (const char *name, double &r, double &g, double &b, int cmode) |
Pops up a window to let the user pick an arbitrary RGB color. More... | |
int | fl_color_chooser (const char *name, uchar &r, uchar &g, uchar &b, int cmode) |
Pops up a window to let the user pick an arbitrary RGB color. More... | |
char * | fl_dir_chooser (const char *message, const char *fname, int relative) |
Shows a file chooser dialog and gets a directory. More... | |
char * | fl_file_chooser (const char *message, const char *pat, const char *fname, int relative) |
Shows a file chooser dialog and gets a filename. More... | |
void | fl_file_chooser_callback (void(*cb)(const char *)) |
Set the file chooser callback. More... | |
void | fl_file_chooser_ok_label (const char *l) |
Set the "OK" button label. More... | |
const char * | fl_input (const char *fmt, const char *defstr,...) |
Shows an input dialog displaying the fmt message with variable arguments. More... | |
const char * | fl_input (int maxchar, const char *fmt, const char *defstr,...) |
Shows an input dialog displaying the fmt message with variable arguments. More... | |
void | fl_message (const char *fmt,...) |
Shows an information message dialog box. More... | |
int | fl_message_hotspot () |
Gets whether or not to move the message box used in many common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password() to follow the mouse pointer. More... | |
void | fl_message_hotspot (int enable) |
Sets whether or not to move the message box used in many common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password() to follow the mouse pointer. More... | |
Fl_Widget * | fl_message_icon () |
Gets the Fl_Box icon container of the current default dialog used in many common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password(). More... | |
void | fl_message_icon_label (const char *str) |
Sets the icon label of the dialog window used in many common dialogs. More... | |
void | fl_message_position (const int x, const int y, const int center) |
Sets the preferred position for the message box used in many common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password(). More... | |
void | fl_message_position (Fl_Widget *widget) |
Sets the preferred position for the message box used in many common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password(). More... | |
int | fl_message_position (int *x, int *y) |
Gets the preferred position for the message box used in many common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password(). More... | |
void | fl_message_title (const char *title) |
Sets the title of the dialog window used in many common dialogs. More... | |
void | fl_message_title_default (const char *title) |
Sets the default title of the dialog window used in many common dialogs. More... | |
const char * | fl_password (const char *fmt, const char *defstr,...) |
Shows an input dialog displaying the fmt message with variable arguments. More... | |
const char * | fl_password (int maxchar, const char *fmt, const char *defstr,...) |
Shows an input dialog displaying the fmt message with variable arguments. More... | |
Variables | |
static void(* | Fl::error )(const char *,...) = Fl_System_Driver::error |
FLTK calls Fl::error() to output a normal error message. More... | |
static void(* | Fl::fatal )(const char *,...) = Fl_System_Driver::fatal |
FLTK calls Fl::fatal() to output a fatal error message. More... | |
const char * | fl_cancel = "Cancel" |
string pointer used in common dialogs, you can change it to another language | |
const char * | fl_close = "Close" |
string pointer used in common dialogs, you can change it to another language | |
Fl_Font | fl_message_font_ = FL_HELVETICA |
Fl_Fontsize | fl_message_size_ = -1 |
const char * | fl_no = "No" |
string pointer used in common dialogs, you can change it to another language | |
const char * | fl_ok = "OK" |
string pointer used in common dialogs, you can change it to another language | |
const char * | fl_yes = "Yes" |
string pointer used in common dialogs, you can change it to another language | |
static void(* | Fl::warning )(const char *,...) = Fl_System_Driver::warning |
FLTK calls Fl::warning() to output a warning message. More... | |
Common dialog functions for file selection, message output, and more.
void fl_alert | ( | const char * | fmt, |
... | |||
) |
Shows an alert message dialog box.
[in] | fmt | can be used as an sprintf-like format and variables for the message text |
int fl_ask | ( | const char * | fmt, |
... | |||
) |
Shows a dialog displaying the fmt
message, this dialog features 2 yes/no buttons.
[in] | fmt | can be used as an sprintf-like format and variables for the message text |
0 | if the no button is selected |
1 | if yes is selected |
void fl_beep | ( | int | type | ) |
Emits a system beep.
This function is platform specific. Depending on the input type
a different sound may be played or the system speaker may beep with a different volume.
On X the system speaker is used which may not work at all on newer systems that don't have a speaker. Since 1.4.0 FL_BEEP_DEFAULT
and other types honor the system or user settings whereas FL_BEEP_ERROR
uses 100% volume. This may be changed in a future version.
On Wayland an ASCII BEL
(0x07) is output to stderr.
On Windows the MessageBeep()
function is used to play different sounds depending on the type
argument.
On macOS the system beep function NSBeep()
is used for FL_BEEP_DEFAULT
and FL_BEEP_ERROR
. Other types are ignored.
On other platforms the behavior is undefined and may change in the future.
[in] | type | The beep type from the Fl_Beep enumeration (optional) |
int fl_choice | ( | const char * | fmt, |
const char * | b0, | ||
const char * | b1, | ||
const char * | b2, | ||
... | |||
) |
Shows a dialog displaying the printf style fmt
message.
This dialog features up to 3 customizable choice buttons which are specified in order of right-to-left in the dialog, e.g.
Three choices with printf() style formatting:
Three choice example:
Two choice example:
One choice example:
[in] | fmt | can be used as an sprintf-like format and variables for the message text |
[in] | b0 | text label for right button 0 |
[in] | b1 | text label for middle button 1 (can be 0) |
[in] | b2 | text label for left button 2 (can be 0) |
0 | if the button with b0 text is pushed or the user pressed the Escape key or clicked the window close button |
1 | if the button with b1 text is pushed or the user pressed the Return key |
2 | if the button with b2 text is pushed |
int fl_choice_n | ( | const char * | fmt, |
const char * | b0, | ||
const char * | b1, | ||
const char * | b2, | ||
... | |||
) |
Shows a dialog displaying the printf style fmt
message.
This function is like fl_choice() but returns -1
if the dialog window was closed by pressing the Escape
key or the window close button rather than pushing one of the dialog buttons.
[in] | fmt | can be used as an sprintf-like format and variables for the message text |
[in] | b0 | text label for right button 0 |
[in] | b1 | text label for middle button 1 (can be 0) |
[in] | b2 | text label for left button 2 (can be 0) |
-3 | reserved, FLTK 1.3 only: another dialog is still open (not possible in 1.4) |
-2 | if the dialog was closed by pushing the window close button |
-1 | if the dialog was closed by hitting Escape |
0 | if the button with b0 text is pushed |
1 | if the button with b1 text is pushed |
2 | if the button with b2 text is pushed |
|
related |
Pops up a window to let the user pick an arbitrary RGB color.
[in] | name | Title label for the window |
[in,out] | r,g,b | Color components in the range 0.0 to 1.0. |
[in] | cmode | Optional mode for color chooser. See mode(int). Default -1 if none (rgb mode). |
1 | if user confirms the selection |
0 | if user cancels the dialog |
Pops up a window to let the user pick an arbitrary RGB color.
[in] | name | Title label for the window |
[in,out] | r,g,b | Color components in the range 0 to 255. |
[in] | cmode | Optional mode for color chooser. See mode(int). Default -1 if none (rgb mode). |
1 | if user confirms the selection |
0 | if user cancels the dialog |
|
related |
Shows a file chooser dialog and gets a directory.
[in] | message | title bar text |
[in] | fname | initial/default directory name |
[in] | relative | 0 for absolute path return, relative otherwise |
|
related |
Shows a file chooser dialog and gets a filename.
[in] | message | text in title bar |
[in] | pat | filename pattern filter |
[in] | fname | initial/default filename selection |
[in] | relative | 0 for absolute path name, relative path name otherwise |
|
related |
Set the file chooser callback.
|
related |
Set the "OK" button label.
const char * fl_input | ( | const char * | fmt, |
const char * | defstr, | ||
... | |||
) |
Shows an input dialog displaying the fmt
message with variable arguments.
Returns the string in an internally allocated buffer that may be changed later. You must copy the string immediately after return from this method - at least before the next execution of the event loop.
[in] | fmt | can be used as an sprintf-like format and variables for the message text |
[in] | defstr | defines the default returned string if no text is entered |
NULL | if Cancel was pushed or the window was closed by the user |
const char * fl_input | ( | int | maxchar, |
const char * | fmt, | ||
const char * | defstr, | ||
... | |||
) |
Shows an input dialog displaying the fmt
message with variable arguments.
This is the same as const char *fl_input(const char *fmt, const char *defstr, ...) except that it has an additional parameter to limit the number of characters the user can input.
Returns the string in an internally allocated buffer that may be changed later. You must copy the string immediately after return from this method - at least before the next execution of the event loop.
[in] | maxchar | maximum number of characters the user can input (UTF-8 aware) |
[in] | fmt | can be used as an sprintf-like format and variables for the message text |
[in] | defstr | defines the default returned string if no text is entered |
NULL | if Cancel was pushed or the window was closed by the user |
void fl_message | ( | const char * | fmt, |
... | |||
) |
Shows an information message dialog box.
[in] | fmt | can be used as an sprintf-like format and variables for the message text |
int fl_message_hotspot | ( | void | ) |
Gets whether or not to move the message box used in many common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password() to follow the mouse pointer.
This is a permanent setting. It remains active and affects the window position unless overridden by an explicit positioning request by means of one of the fl_message_position() variants.
void fl_message_hotspot | ( | int | enable | ) |
Sets whether or not to move the message box used in many common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password() to follow the mouse pointer.
The default is enabled, so that the default button is the hotspot and appears at the mouse position.
[in] | enable | non-zero enables hotspot behavior, 0 disables hotspot |
Fl_Widget * fl_message_icon | ( | ) |
Gets the Fl_Box icon container of the current default dialog used in many common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password().
The return value cannot be Null. The object pointed to is an Fl_Box widget. The returned pointer (Fl_Widget *) can be safely cast to an Fl_Box* pointer.
Supported icon attributes:
The icon size can not be changed. If you set an image() you should scale it to the available size, i.e. w()
and h()
of the icon box.
void fl_message_icon_label | ( | const char * | str | ) |
Sets the icon label of the dialog window used in many common dialogs.
This icon label will be used in the next call of one of the common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password().
The label str
is stored internally as a reference, it must be in scope until the dialog function (e.g. fl_choice) is called.
It applies only to the next call of one of the common dialogs and will be reset after that call so the next dialog will use its default label unless set again.
[in] | str | icon label |
void fl_message_position | ( | const int | x, |
const int | y, | ||
const int | center | ||
) |
Sets the preferred position for the message box used in many common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password().
The position set with this method overrides the hotspot setting, i.e. setting a position has higher priority than the hotspot mode set by fl_message_hotspot(int).
The preferred position set by any of the fl_message_position() variants affects only the next call of one of the common dialogs. The preferred position is reset to 0 (unset) as soon as the dialog is shown.
If the optional argument center
is non-zero (true) the message box will be centered at the given coordinates rather than using the X/Y position as the window position (top left corner).
[in] | x | Preferred X position |
[in] | y | Preferred Y position |
[in] | center | 1 = centered, 0 = absolute |
void fl_message_position | ( | Fl_Widget * | widget | ) |
Sets the preferred position for the message box used in many common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password().
The message box will be centered over the given widget or window extensions.
Everything else is like fl_message_position(int, int, int) with argument 'center' set to 1.
[in] | widget | Widget or window to position the message box over. |
int fl_message_position | ( | int * | x, |
int * | y | ||
) |
Gets the preferred position for the message box used in many common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password().
The position set with this method overrides the hotspot setting, i.e. setting a position has higher priority than the hotspot mode set by fl_message_hotspot(int).
The preferred position set by any of the fl_message_position() variants affects only the next call of one of the common dialogs. The preferred position is reset to 0 (unset) as soon as the dialog is shown.
[out] | x | Preferred X position, returns -1 if not set |
[out] | y | Preferred Y position, returns -1 if not set |
0 | position is not set (hotspot may be enabled or not) |
1 | position is set (window position) |
2 | position is set (message box centered) |
void fl_message_title | ( | const char * | title | ) |
Sets the title of the dialog window used in many common dialogs.
This window title
will be used in the next call of one of the common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password().
The title
string is copied internally, so that you can use a local variable or free the string immediately after this call. It applies only to the next call of one of the common dialogs and will be reset to an empty title (the default for all dialogs) after that call.
[in] | title | window label, string copied internally |
void fl_message_title_default | ( | const char * | title | ) |
Sets the default title of the dialog window used in many common dialogs.
This window title
will be used in all subsequent calls of one of the common dialogs like fl_message(), fl_alert(), fl_ask(), fl_choice(), fl_input(), fl_password(), unless a specific title has been set with fl_message_title(const char *title).
The default is no title. You can override the default title for a single dialog with fl_message_title(const char *title).
The title
string is copied internally, so that you can use a local variable or free the string immediately after this call.
[in] | title | default window label, string copied internally |
const char * fl_password | ( | const char * | fmt, |
const char * | defstr, | ||
... | |||
) |
Shows an input dialog displaying the fmt
message with variable arguments.
Like fl_input() except the input text is not shown, '*' or similar replacement characters are displayed instead.
[in] | fmt | can be used as an sprintf-like format and variables for the message text |
[in] | defstr | defines the default returned string if no text is entered |
NULL | if Cancel was pushed or the window was closed by the user |
const char * fl_password | ( | int | maxchar, |
const char * | fmt, | ||
const char * | defstr, | ||
... | |||
) |
Shows an input dialog displaying the fmt
message with variable arguments.
Like fl_input() except the input text is not shown, '*' or similar replacement characters are displayed instead.
[in] | maxchar | input lenght limit in chars, 0 = no limit |
[in] | fmt | can be used as an sprintf-like format and variables for the message text |
[in] | defstr | defines the default returned string if no text is entered |
NULL | if Cancel was pushed or the window was closed by the user |
|
static |
FLTK calls Fl::error() to output a normal error message.
The default version on Windows displays the error message in a MessageBox window.
The default version on all other platforms prints the error message to stderr.
You can override the behavior by setting the function pointer to your own routine.
Fl::error() means there is a recoverable error such as the inability to read an image file. The default implementation returns after displaying the message.
|
static |
FLTK calls Fl::fatal() to output a fatal error message.
The default version on Windows displays the error message in a MessageBox window.
The default version on all other platforms prints the error message to stderr.
You can override the behavior by setting the function pointer to your own routine.
Fl::fatal() must not return, as FLTK is in an unusable state, however your version may be able to use longjmp or an exception to continue, as long as it does not call FLTK again. The default implementation exits with status 1 after displaying the message.
|
static |
FLTK calls Fl::warning() to output a warning message.
The default version on Windows returns without printing a warning message, because Windows programs normally don't have stderr (a console window) enabled.
The default version on all other platforms prints the warning message to stderr.
You can override the behavior by setting the function pointer to your own routine.
Fl::warning() means that there was a recoverable problem, the display may be messed up, but the user can probably keep working - all X protocol errors call this, for example. The default implementation returns after displaying the message.