applied Duncan Gibson's documentation patch (WP3).
Docs look good, compiles okay. git-svn-id: file:///fltk/svn/fltk/branches/branch-1.3@6264 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
This commit is contained in:
parent
5da1c0f71f
commit
e20eeb6541
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Button header file for the Fast Light Tool Kit (FLTK).
|
// Button header file for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2005 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -40,6 +40,40 @@
|
|||||||
|
|
||||||
extern FL_EXPORT int fl_old_shortcut(const char*);
|
extern FL_EXPORT int fl_old_shortcut(const char*);
|
||||||
|
|
||||||
|
/**
|
||||||
|
\class Fl_Button
|
||||||
|
\brief Buttons generate callbacks when they are clicked by the user.
|
||||||
|
|
||||||
|
You control exactly when and how by changing the values for type() and
|
||||||
|
when(). Buttons can also generate callbacks in response to \c FL_SHORTCUT
|
||||||
|
events. The button can either have an explicit shortcut(int s) value or a
|
||||||
|
letter shortcut can be indicated in the label() with an '\&' character
|
||||||
|
before it. For the label shortcut it does not matter if \e Alt is held
|
||||||
|
down, but if you have an input field in the same window, the user will have
|
||||||
|
to hold down the \e Alt key so that the input field does not eat the event
|
||||||
|
first as an \c FL_KEYBOARD event.
|
||||||
|
|
||||||
|
\todo Refactor the doxygen comments for Fl_Button type() documentation.
|
||||||
|
|
||||||
|
For an Fl_Button object, the type() call returns one of:
|
||||||
|
\li \c FL_NORMAL_BUTTON (0): value() remains unchanged after button press.
|
||||||
|
\li \c FL_TOGGLE_BUTTON: value() is inverted after button press.
|
||||||
|
\li \c FL_RADIO_BUTTON: value() is set to 1 after button press, and all other
|
||||||
|
buttons in the current group with <tt>type() == FL_RADIO_BUTTON</tt>
|
||||||
|
are set to zero.
|
||||||
|
|
||||||
|
\todo Refactor the doxygen comments for Fl_Button when() documentation.
|
||||||
|
|
||||||
|
For an Fl_Button object, the following when() values are useful, the default
|
||||||
|
being \c FL_WHEN_RELEASE:
|
||||||
|
\li \c 0: The callback is not done, instead changed() is turned on.
|
||||||
|
\li \c FL_WHEN_RELEASE: The callback is done after the user successfully
|
||||||
|
clicks the button, or when a shortcut is typed.
|
||||||
|
\li \c FL_WHEN_CHANGED: The callback is done each time the value() changes
|
||||||
|
(when the user pushes and releases the button, and as the mouse is
|
||||||
|
dragged around in and out of the button).
|
||||||
|
*/
|
||||||
|
|
||||||
class FL_EXPORT Fl_Button : public Fl_Widget {
|
class FL_EXPORT Fl_Button : public Fl_Widget {
|
||||||
|
|
||||||
int shortcut_;
|
int shortcut_;
|
||||||
@ -54,20 +88,77 @@ protected:
|
|||||||
public:
|
public:
|
||||||
|
|
||||||
virtual int handle(int);
|
virtual int handle(int);
|
||||||
Fl_Button(int,int,int,int,const char * = 0);
|
|
||||||
int value(int);
|
Fl_Button(int X, int Y, int W, int H, const char *L = 0);
|
||||||
|
|
||||||
|
int value(int v);
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the current value of the button (0 or 1).
|
||||||
|
*/
|
||||||
char value() const {return value_;}
|
char value() const {return value_;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Same as \c value(1).
|
||||||
|
\see value(int v)
|
||||||
|
*/
|
||||||
int set() {return value(1);}
|
int set() {return value(1);}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Same as \c value(0).
|
||||||
|
\see value(int v)
|
||||||
|
*/
|
||||||
int clear() {return value(0);}
|
int clear() {return value(0);}
|
||||||
|
|
||||||
void setonly(); // this should only be called on FL_RADIO_BUTTONs
|
void setonly(); // this should only be called on FL_RADIO_BUTTONs
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the current shortcut key for the button.
|
||||||
|
\retval int
|
||||||
|
*/
|
||||||
int shortcut() const {return shortcut_;}
|
int shortcut() const {return shortcut_;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Sets the shortcut key to \c s.
|
||||||
|
Setting this overrides the use of '\&' in the label().
|
||||||
|
The value is a bitwise OR of a key and a set of shift flags, for example:
|
||||||
|
<tt>FL_ALT | 'a'</tt>, or
|
||||||
|
<tt>FL_ALT | (FL_F + 10)</tt>, or just
|
||||||
|
<tt>'a'</tt>.
|
||||||
|
A value of 0 disables the shortcut.
|
||||||
|
|
||||||
|
The key can be any value returned by Fl::event_key(), but will usually be
|
||||||
|
an ASCII letter. Use a lower-case letter unless you require the shift key
|
||||||
|
to be held down.
|
||||||
|
|
||||||
|
The shift flags can be any set of values accepted by Fl::event_state().
|
||||||
|
If the bit is on, that shift key must be pushed. Meta, Alt, Ctrl, and
|
||||||
|
Shift must be off if they are not in the shift flags (zero for the other
|
||||||
|
bits indicates a "don't care" setting).
|
||||||
|
\param[in] s bitwise OR of key and shift flags
|
||||||
|
*/
|
||||||
void shortcut(int s) {shortcut_ = s;}
|
void shortcut(int s) {shortcut_ = s;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the current down box type, which is drawn when value() is non-zero.
|
||||||
|
\retval Fl_Boxtype
|
||||||
|
*/
|
||||||
Fl_Boxtype down_box() const {return (Fl_Boxtype)down_box_;}
|
Fl_Boxtype down_box() const {return (Fl_Boxtype)down_box_;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Sets the down box type. The default value of 0 causes FLTK to figure out
|
||||||
|
the correct matching down version of box().
|
||||||
|
\param[in] b down box type
|
||||||
|
*/
|
||||||
void down_box(Fl_Boxtype b) {down_box_ = b;}
|
void down_box(Fl_Boxtype b) {down_box_ = b;}
|
||||||
|
|
||||||
// back compatibility:
|
/// (for backwards compatibility)
|
||||||
void shortcut(const char *s) {shortcut(fl_old_shortcut(s));}
|
void shortcut(const char *s) {shortcut(fl_old_shortcut(s));}
|
||||||
|
|
||||||
|
/// (for backwards compatibility)
|
||||||
Fl_Color down_color() const {return selection_color();}
|
Fl_Color down_color() const {return selection_color();}
|
||||||
|
|
||||||
|
/// (for backwards compatibility)
|
||||||
void down_color(unsigned c) {selection_color(c);}
|
void down_color(unsigned c) {selection_color(c);}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Forms chart header file for the Fast Light Tool Kit (FLTK).
|
// Forms chart header file for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2005 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -52,6 +52,28 @@ struct FL_CHART_ENTRY {
|
|||||||
char str[FL_CHART_LABEL_MAX+1];
|
char str[FL_CHART_LABEL_MAX+1];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
\class Fl_Chart
|
||||||
|
\brief Fl_Chart displays simple charts.
|
||||||
|
It is provided for Forms compatibility.
|
||||||
|
|
||||||
|
\image html charts.gif
|
||||||
|
|
||||||
|
\todo Refactor Fl_Chart::type() information.
|
||||||
|
|
||||||
|
The type of an Fl_Chart object can be set using type(uchar t) to:
|
||||||
|
\li \c FL_BAR_CHART: Each sample value is drawn as a vertical bar.
|
||||||
|
\li \c FL_FILLED_CHART: The chart is filled from the bottom of the graph
|
||||||
|
to the sample values.
|
||||||
|
\li \c FL_HORBAR_CHART: Each sample value is drawn as a horizontal bar.
|
||||||
|
\li \c FL_LINE_CHART: The chart is drawn as a polyline with vertices at
|
||||||
|
each sample value.
|
||||||
|
\li \c FL_PIE_CHART: A pie chart is drawn with each sample value being
|
||||||
|
drawn as a proportionate slice in the circle.
|
||||||
|
\li \c FL_SPECIALPIE_CHART: Like \c FL_PIE_CHART, but the first slice is
|
||||||
|
separated from the pie.
|
||||||
|
\li \c FL_SPIKE_CHART: Each sample value is drawn as a vertical line.
|
||||||
|
*/
|
||||||
class FL_EXPORT Fl_Chart : public Fl_Widget {
|
class FL_EXPORT Fl_Chart : public Fl_Widget {
|
||||||
int numb;
|
int numb;
|
||||||
int maxnumb;
|
int maxnumb;
|
||||||
@ -65,25 +87,57 @@ class FL_EXPORT Fl_Chart : public Fl_Widget {
|
|||||||
protected:
|
protected:
|
||||||
void draw();
|
void draw();
|
||||||
public:
|
public:
|
||||||
Fl_Chart(int,int,int,int,const char * = 0);
|
Fl_Chart(int X, int Y, int W, int H, const char *L = 0);
|
||||||
|
|
||||||
~Fl_Chart();
|
~Fl_Chart();
|
||||||
|
|
||||||
void clear();
|
void clear();
|
||||||
void add(double, const char * =0, unsigned=0);
|
|
||||||
void insert(int, double, const char * =0, unsigned=0);
|
void add(double val, const char *str = 0, unsigned col = 0);
|
||||||
void replace(int, double, const char * =0, unsigned=0);
|
|
||||||
|
void insert(int ind, double val, const char *str = 0, unsigned col = 0);
|
||||||
|
|
||||||
|
void replace(int ind, double val, const char *str = 0, unsigned col = 0);
|
||||||
|
|
||||||
|
/**
|
||||||
|
Gets the lower and upper bounds of the chart values.
|
||||||
|
\param[out] a, b are set to lower, upper
|
||||||
|
*/
|
||||||
void bounds(double *a,double *b) const {*a = min; *b = max;}
|
void bounds(double *a,double *b) const {*a = min; *b = max;}
|
||||||
|
|
||||||
void bounds(double a,double b);
|
void bounds(double a,double b);
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the number of data values in the chart.
|
||||||
|
*/
|
||||||
int size() const {return numb;}
|
int size() const {return numb;}
|
||||||
|
|
||||||
void size(int W, int H) { Fl_Widget::size(W, H); }
|
void size(int W, int H) { Fl_Widget::size(W, H); }
|
||||||
|
|
||||||
|
/**
|
||||||
|
Get the maximum number of data values for a chart.
|
||||||
|
*/
|
||||||
int maxsize() const {return maxnumb;}
|
int maxsize() const {return maxnumb;}
|
||||||
void maxsize(int);
|
|
||||||
|
void maxsize(int m);
|
||||||
|
|
||||||
Fl_Font textfont() const {return textfont_;}
|
Fl_Font textfont() const {return textfont_;}
|
||||||
void textfont(Fl_Font s) {textfont_ = s;}
|
void textfont(Fl_Font s) {textfont_ = s;}
|
||||||
Fl_Fontsize textsize() const {return textsize_;}
|
Fl_Fontsize textsize() const {return textsize_;}
|
||||||
void textsize(Fl_Fontsize s) {textsize_ = s;}
|
void textsize(Fl_Fontsize s) {textsize_ = s;}
|
||||||
Fl_Color textcolor() const {return (Fl_Color)textcolor_;}
|
Fl_Color textcolor() const {return (Fl_Color)textcolor_;}
|
||||||
void textcolor(unsigned n) {textcolor_ = n;}
|
void textcolor(unsigned n) {textcolor_ = n;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Get whether the chart will automatically adjust the bounds of the chart.
|
||||||
|
\returns non-zero if auto-sizing is enabled and zero if disabled.
|
||||||
|
*/
|
||||||
uchar autosize() const {return autosize_;}
|
uchar autosize() const {return autosize_;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Set whether the chart will automatically adjust the bounds of the chart.
|
||||||
|
\param n non-zero to enable automatic resizing, zero to disable.
|
||||||
|
*/
|
||||||
void autosize(uchar n) {autosize_ = n;}
|
void autosize(uchar n) {autosize_ = n;}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Check button header file for the Fast Light Tool Kit (FLTK).
|
// Check button header file for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2005 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -30,9 +30,24 @@
|
|||||||
|
|
||||||
#include "Fl_Light_Button.H"
|
#include "Fl_Light_Button.H"
|
||||||
|
|
||||||
|
/**
|
||||||
|
\class Fl_Check_Button
|
||||||
|
\brief A button with an "checkmark" to show its status.
|
||||||
|
|
||||||
|
\image html Fl_Check_Button.gif
|
||||||
|
|
||||||
|
Buttons generate callbacks when they are clicked by the user. You control
|
||||||
|
exactly when and how by changing the values for type() and when().
|
||||||
|
|
||||||
|
The Fl_Check_Button subclass displays its "ON" state by showing a "checkmark"
|
||||||
|
rather than drawing itself pushed in.
|
||||||
|
|
||||||
|
\todo Refactor Fl_Check_Button doxygen comments (add color() info etc?)
|
||||||
|
\todo Generate Fl_Check_Button.gif with visible checkmark.
|
||||||
|
*/
|
||||||
class FL_EXPORT Fl_Check_Button : public Fl_Light_Button {
|
class FL_EXPORT Fl_Check_Button : public Fl_Light_Button {
|
||||||
public:
|
public:
|
||||||
Fl_Check_Button(int x,int y,int w,int h,const char *l = 0);
|
Fl_Check_Button(int X, int Y, int W, int H, const char *L = 0);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Choice header file for the Fast Light Tool Kit (FLTK).
|
// Choice header file for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2005 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -30,15 +30,72 @@
|
|||||||
|
|
||||||
#include "Fl_Menu_.H"
|
#include "Fl_Menu_.H"
|
||||||
|
|
||||||
|
/**
|
||||||
|
\class Fl_Choice
|
||||||
|
\brief A button that is used to pop up a menu.
|
||||||
|
|
||||||
|
This is a button that, when pushed, pops up a menu (or hierarchy of menus)
|
||||||
|
defined by an array of Fl_Menu_Item objects.
|
||||||
|
Motif calls this an OptionButton.
|
||||||
|
|
||||||
|
The only difference between this and a Fl_Menu_Button is that the name of
|
||||||
|
the most recent chosen menu item is displayed inside the box, while the
|
||||||
|
label is displayed outside the box. However, since the use of this is most
|
||||||
|
often to control a single variable rather than do individual callbacks,
|
||||||
|
some of the Fl_Menu_Button methods are redescribed here in those terms.
|
||||||
|
|
||||||
|
When the user picks an item off the menu the value() is set to that item
|
||||||
|
and then the item's callback is done with the menu_button as the
|
||||||
|
\c Fl_Widget* argument. If the item does not have a callback the
|
||||||
|
menu_button's callback is done instead.
|
||||||
|
|
||||||
|
All three mouse buttons pop up the menu. The Forms behavior of the first
|
||||||
|
two buttons to increment/decrement the choice is not implemented. This
|
||||||
|
could be added with a subclass, however.
|
||||||
|
|
||||||
|
The menu will also pop up in response to shortcuts indicated by putting
|
||||||
|
a '\&' character in the label(). See Fl_Button::shortcut(int s) for a
|
||||||
|
description of this.
|
||||||
|
|
||||||
|
Typing the shortcut() of any of the items will do exactly the same as when
|
||||||
|
you pick the item with the mouse. The '\&' character in item names are
|
||||||
|
only looked at when the menu is popped up, however.
|
||||||
|
|
||||||
|
\image html choice.gif
|
||||||
|
|
||||||
|
\todo Refactor the doxygen comments for Fl_Choice changed() documentation.
|
||||||
|
|
||||||
|
\li <tt>int Fl_Widget::changed() const</tt>
|
||||||
|
This value is true the user picks a different value. <em>It is turned
|
||||||
|
off by value() and just before doing a callback (the callback can turn
|
||||||
|
it back on if desired).</em>
|
||||||
|
\li <tt>void Fl_Widget::set_changed()</tt>
|
||||||
|
This method sets the changed() flag.
|
||||||
|
\li <tt>void Fl_Widget::clear_changed()</tt>
|
||||||
|
This method clears the changed() flag.
|
||||||
|
\li <tt>Fl_Boxtype Fl_Choice::down_box() const</tt>
|
||||||
|
Gets the current down box, which is used when the menu is popped up.
|
||||||
|
The default down box type is \c FL_DOWN_BOX.
|
||||||
|
\li <tt>void Fl_Choice::down_box(Fl_Boxtype b)</tt>
|
||||||
|
Sets the current down box type to \p b.
|
||||||
|
*/
|
||||||
class FL_EXPORT Fl_Choice : public Fl_Menu_ {
|
class FL_EXPORT Fl_Choice : public Fl_Menu_ {
|
||||||
protected:
|
protected:
|
||||||
void draw();
|
void draw();
|
||||||
public:
|
public:
|
||||||
int handle(int);
|
int handle(int);
|
||||||
Fl_Choice(int,int,int,int,const char * = 0);
|
|
||||||
int value(const Fl_Menu_Item*);
|
Fl_Choice(int X, int Y, int W, int H, const char *L = 0);
|
||||||
int value(int i);
|
|
||||||
|
/**
|
||||||
|
Gets the index of the last item chosen by the user.
|
||||||
|
The index is zero initially.
|
||||||
|
*/
|
||||||
int value() const {return Fl_Menu_::value();}
|
int value() const {return Fl_Menu_::value();}
|
||||||
|
|
||||||
|
int value(int v);
|
||||||
|
|
||||||
|
int value(const Fl_Menu_Item* v);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
104
FL/Fl_Clock.H
104
FL/Fl_Clock.H
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Clock header file for the Fast Light Tool Kit (FLTK).
|
// Clock header file for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2005 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -42,16 +42,16 @@
|
|||||||
#define FL_ANALOG_CLOCK FL_SQUARE_CLOCK
|
#define FL_ANALOG_CLOCK FL_SQUARE_CLOCK
|
||||||
#define FL_DIGITAL_CLOCK FL_SQUARE_CLOCK // nyi
|
#define FL_DIGITAL_CLOCK FL_SQUARE_CLOCK // nyi
|
||||||
|
|
||||||
// a Fl_Clock_Output can be used to display a program-supplied time:
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This widget can be used to display a program-supplied time.
|
\class Fl_Clock_Output
|
||||||
* The time shown on the clock is not updated.
|
\brief This widget can be used to display a program-supplied time.
|
||||||
* To display the current time, use Fl_Clock</A> instead.
|
|
||||||
*
|
The time shown on the clock is not updated. To display the current time,
|
||||||
* <table align=CENTER border=5 cellpadding=5 ><TR><TD> \image html clock.gif </TD>
|
use Fl_Clock instead.
|
||||||
*
|
|
||||||
* <TD> \image html round_clock.gif </TD> </TR> </table>
|
\image html clock.gif
|
||||||
|
|
||||||
|
\image html round_clock.gif
|
||||||
*/
|
*/
|
||||||
class FL_EXPORT Fl_Clock_Output : public Fl_Widget {
|
class FL_EXPORT Fl_Clock_Output : public Fl_Widget {
|
||||||
int hour_, minute_, second_;
|
int hour_, minute_, second_;
|
||||||
@ -62,56 +62,34 @@ protected:
|
|||||||
void draw();
|
void draw();
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/**
|
Fl_Clock_Output(int X, int Y, int W, int H, const char *L = 0);
|
||||||
* Creates a new Fl_Clock_Output widget.
|
|
||||||
* Create an Fl_Clock_Output widget using the given position,
|
|
||||||
* size, and label string. The default boxtype is FL_NO_BOX.
|
|
||||||
*
|
|
||||||
* \param[in] x, y, w, h position and size of the widget
|
|
||||||
* \param[in] label widget label, default is no label
|
|
||||||
*/
|
|
||||||
Fl_Clock_Output(int x,int y,int w,int h, const char *l = 0);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the displayed time.
|
|
||||||
* Set the time in seconds since the UNIX epoch (January 1, 1970).
|
|
||||||
* \see value()
|
|
||||||
*/
|
|
||||||
void value(ulong v); // set to this Unix time
|
void value(ulong v); // set to this Unix time
|
||||||
|
|
||||||
/**
|
void value(int H, int m, int s);
|
||||||
* Set the displayed time.
|
|
||||||
* Set the time in hours, minutes, and seconds.
|
|
||||||
* \param[in] hour, minute, second displayed time
|
|
||||||
* \see hour(), minute(), second()
|
|
||||||
*/
|
|
||||||
void value(int hour, int minute, int second);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the displayed time.
|
Returns the displayed time.
|
||||||
* Returns the time in seconds since the UNIX epoch (January 1, 1970).
|
Returns the time in seconds since the UNIX epoch (January 1, 1970).
|
||||||
* \see value(ulong)
|
\see value(ulong)
|
||||||
*/
|
*/
|
||||||
ulong value() const {return value_;}
|
ulong value() const {return value_;}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the displayed time.
|
Returns the displayed hour (0 to 23).
|
||||||
* Returns the displayed hour (0 to 23).
|
\see value(), minute(), second()
|
||||||
* \see value(), minute(), second()
|
|
||||||
*/
|
*/
|
||||||
int hour() const {return hour_;}
|
int hour() const {return hour_;}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the displayed time.
|
Returns the displayed minute (0 to 59).
|
||||||
* Returns the displayed minute (0 to 59).
|
\see value(), hour(), second()
|
||||||
* \see value(), hour(), second()
|
|
||||||
*/
|
*/
|
||||||
int minute() const {return minute_;}
|
int minute() const {return minute_;}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the displayed time.
|
Returns the displayed second (0 to 60, 60=leap second).
|
||||||
* Returns the displayed second (0 to 60, 60=leap second).
|
\see value(), hour(), minute()
|
||||||
* \see value(), hour(), minute()
|
|
||||||
*/
|
*/
|
||||||
int second() const {return second_;}
|
int second() const {return second_;}
|
||||||
};
|
};
|
||||||
@ -119,43 +97,25 @@ public:
|
|||||||
// a Fl_Clock displays the current time always by using a timeout:
|
// a Fl_Clock displays the current time always by using a timeout:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This widget provides a round analog clock display.
|
\class Fl_Clock
|
||||||
* Fl_Clock is provided for Forms compatibility.
|
\brief This widget provides a round analog clock display.
|
||||||
* It installs a 1-second timeout callback using Fl::add_timeout().
|
|
||||||
*
|
Fl_Clock is provided for Forms compatibility.
|
||||||
* <table align=CENTER border=5 cellpadding=5 ><TR><TD>\image html clock.gif </TD>
|
It installs a 1-second timeout callback using Fl::add_timeout().
|
||||||
*
|
|
||||||
* <TD> \image html round_clock.gif </TD></TR></table>
|
\image html clock.gif
|
||||||
|
|
||||||
|
\image html round_clock.gif
|
||||||
*/
|
*/
|
||||||
class FL_EXPORT Fl_Clock : public Fl_Clock_Output {
|
class FL_EXPORT Fl_Clock : public Fl_Clock_Output {
|
||||||
public:
|
public:
|
||||||
int handle(int);
|
int handle(int);
|
||||||
void update();
|
void update();
|
||||||
|
|
||||||
/**
|
Fl_Clock(int X, int Y, int W, int H, const char *L = 0);
|
||||||
* Creates a new Fl_Clock widget.
|
|
||||||
* Create an Fl_Clock widget using the given position,
|
|
||||||
* size, and label string. The default boxtype is FL_NO_BOX.
|
|
||||||
*
|
|
||||||
* \param[in] x, y, w, h position and size of the widget
|
|
||||||
* \param[in] label widget label, default is no label
|
|
||||||
*/
|
|
||||||
Fl_Clock(int x,int y,int w,int h, const char *l = 0);
|
|
||||||
|
|
||||||
/**
|
Fl_Clock(uchar t, int X, int Y, int W, int H, const char *L);
|
||||||
* Creates a new Fl_Clock widget.
|
|
||||||
* Create an Fl_Clock widget using the given position,
|
|
||||||
* size, and label string.
|
|
||||||
*
|
|
||||||
* \param[in] t boxtype
|
|
||||||
* \param[in] x, y, w, h position and size of the widget
|
|
||||||
* \param[in] label widget label, default is no label
|
|
||||||
*/
|
|
||||||
Fl_Clock(uchar t,int x,int y,int w,int h, const char *l);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The destructor removes the clock.
|
|
||||||
*/
|
|
||||||
~Fl_Clock();
|
~Fl_Clock();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Color chooser header file for the Fast Light Tool Kit (FLTK).
|
// Color chooser header file for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2005 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -66,6 +66,19 @@ public:
|
|||||||
Flcc_Value_Input(int X, int Y, int W, int H) : Fl_Value_Input(X,Y,W,H) {}
|
Flcc_Value_Input(int X, int Y, int W, int H) : Fl_Value_Input(X,Y,W,H) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
\class Fl_Color_Chooser
|
||||||
|
\brief The Fl_Color_Chooser widget provides a standard RGB color chooser.
|
||||||
|
|
||||||
|
You can place any number of these into a panel of your own design. This
|
||||||
|
widget contains the hue box, value slider, and rgb input fields from the
|
||||||
|
above diagram (it does not have the color chips or the Cancel or OK buttons).
|
||||||
|
The callback is done every time the user changes the rgb value. It is not
|
||||||
|
done if they move the hue control in a way that produces the \e same rgb
|
||||||
|
value, such as when saturation or value is zero.
|
||||||
|
|
||||||
|
\image html fl_color_chooser.jpg
|
||||||
|
*/
|
||||||
class FL_EXPORT Fl_Color_Chooser : public Fl_Group {
|
class FL_EXPORT Fl_Color_Chooser : public Fl_Group {
|
||||||
Flcc_HueBox huebox;
|
Flcc_HueBox huebox;
|
||||||
Flcc_ValueBox valuebox;
|
Flcc_ValueBox valuebox;
|
||||||
@ -81,17 +94,54 @@ class FL_EXPORT Fl_Color_Chooser : public Fl_Group {
|
|||||||
static void mode_cb(Fl_Widget*, void*);
|
static void mode_cb(Fl_Widget*, void*);
|
||||||
public:
|
public:
|
||||||
int mode() {return choice.value();}
|
int mode() {return choice.value();}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the current hue.
|
||||||
|
0 <= hue < 6. Zero is red, one is yellow, two is green, etc.
|
||||||
|
<em>This value is convienent for the internal calculations - some other
|
||||||
|
systems consider hue to run from zero to one, or from 0 to 360.</em>
|
||||||
|
*/
|
||||||
double hue() const {return hue_;}
|
double hue() const {return hue_;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the saturation.
|
||||||
|
0 <= saturation <= 1.
|
||||||
|
*/
|
||||||
double saturation() const {return saturation_;}
|
double saturation() const {return saturation_;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the value/brightness.
|
||||||
|
0 <= value <= 1.
|
||||||
|
*/
|
||||||
double value() const {return value_;}
|
double value() const {return value_;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the current red value.
|
||||||
|
0 <= r <= 1.
|
||||||
|
*/
|
||||||
double r() const {return r_;}
|
double r() const {return r_;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the current green value.
|
||||||
|
0 <= g <= 1.
|
||||||
|
*/
|
||||||
double g() const {return g_;}
|
double g() const {return g_;}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the current blue value.
|
||||||
|
0 <= b <= 1.
|
||||||
|
*/
|
||||||
double b() const {return b_;}
|
double b() const {return b_;}
|
||||||
int hsv(double,double,double);
|
|
||||||
int rgb(double,double,double);
|
int hsv(double H, double S, double V);
|
||||||
static void hsv2rgb(double, double, double,double&,double&,double&);
|
|
||||||
static void rgb2hsv(double, double, double,double&,double&,double&);
|
int rgb(double R, double G, double B);
|
||||||
Fl_Color_Chooser(int,int,int,int,const char* = 0);
|
|
||||||
|
static void hsv2rgb(double H, double S, double V, double& R, double& G, double& B);
|
||||||
|
|
||||||
|
static void rgb2hsv(double R, double G, double B, double& H, double& S, double& V);
|
||||||
|
|
||||||
|
Fl_Color_Chooser(int X, int Y, int W, int H, const char *L = 0);
|
||||||
};
|
};
|
||||||
|
|
||||||
FL_EXPORT int fl_color_chooser(const char* name, double& r, double& g, double& b);
|
FL_EXPORT int fl_color_chooser(const char* name, double& r, double& g, double& b);
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Counter header file for the Fast Light Tool Kit (FLTK).
|
// Counter header file for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2005 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -38,6 +38,19 @@
|
|||||||
#define FL_NORMAL_COUNTER 0
|
#define FL_NORMAL_COUNTER 0
|
||||||
#define FL_SIMPLE_COUNTER 1
|
#define FL_SIMPLE_COUNTER 1
|
||||||
|
|
||||||
|
/**
|
||||||
|
\class Fl_Counter
|
||||||
|
\brief Fl_Counter widget for Forms compatibility.
|
||||||
|
|
||||||
|
The Fl_Counter widget is provided for forms compatibility.
|
||||||
|
It controls a single floating point value.
|
||||||
|
|
||||||
|
\todo Refactor the doxygen comments for Fl_Counter type() documentation.
|
||||||
|
|
||||||
|
The type of an Fl_Counter object can be set using type(uchar t) to:
|
||||||
|
\li \c FL_NORMAL_COUNTER: Displays a counter with 4 arrow buttons.
|
||||||
|
\li \c FL_SIMPLE_COUNTER: Displays a counter with only 2 arrow buttons.
|
||||||
|
*/
|
||||||
class FL_EXPORT Fl_Counter : public Fl_Valuator {
|
class FL_EXPORT Fl_Counter : public Fl_Valuator {
|
||||||
|
|
||||||
Fl_Font textfont_;
|
Fl_Font textfont_;
|
||||||
@ -56,9 +69,17 @@ protected:
|
|||||||
public:
|
public:
|
||||||
|
|
||||||
int handle(int);
|
int handle(int);
|
||||||
Fl_Counter(int,int,int,int,const char * = 0);
|
|
||||||
|
Fl_Counter(int X, int Y, int W, int H, const char* L = 0);
|
||||||
~Fl_Counter();
|
~Fl_Counter();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Set the increment for the double-arrow buttons.
|
||||||
|
The default value is 1.0.
|
||||||
|
\param[in] a increment value
|
||||||
|
*/
|
||||||
void lstep(double a) {lstep_ = a;}
|
void lstep(double a) {lstep_ = a;}
|
||||||
|
|
||||||
void step(double a,double b) {Fl_Valuator::step(a); lstep_ = b;}
|
void step(double a,double b) {Fl_Valuator::step(a); lstep_ = b;}
|
||||||
void step(double a) {Fl_Valuator::step(a);}
|
void step(double a) {Fl_Valuator::step(a);}
|
||||||
Fl_Font textfont() const {return textfont_;}
|
Fl_Font textfont() const {return textfont_;}
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Button widget for the Fast Light Tool Kit (FLTK).
|
// Button widget for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2006 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -34,6 +34,12 @@
|
|||||||
// them are implemented by setting the type() value and testing it
|
// them are implemented by setting the type() value and testing it
|
||||||
// here. This includes Fl_Radio_Button and Fl_Toggle_Button
|
// here. This includes Fl_Radio_Button and Fl_Toggle_Button
|
||||||
|
|
||||||
|
/**
|
||||||
|
Sets the current value of the button.
|
||||||
|
A non-zero value sets the button to 1 (ON), and zero sets it to 0 (OFF).
|
||||||
|
\param[in] v button value.
|
||||||
|
\see set(), clear()
|
||||||
|
*/
|
||||||
int Fl_Button::value(int v) {
|
int Fl_Button::value(int v) {
|
||||||
v = v ? 1 : 0;
|
v = v ? 1 : 0;
|
||||||
oldval = v;
|
oldval = v;
|
||||||
@ -48,6 +54,10 @@ int Fl_Button::value(int v) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Turns on this button and turns off all other radio buttons in the group
|
||||||
|
(calling \c value(1) or \c set() does not do this).
|
||||||
|
*/
|
||||||
void Fl_Button::setonly() { // set this radio button on, turn others off
|
void Fl_Button::setonly() { // set this radio button on, turn others off
|
||||||
value(1);
|
value(1);
|
||||||
Fl_Group* g = (Fl_Group*)parent();
|
Fl_Group* g = (Fl_Group*)parent();
|
||||||
@ -159,8 +169,13 @@ int Fl_Button::handle(int event) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Fl_Button::Fl_Button(int X, int Y, int W, int H, const char *l)
|
/**
|
||||||
: Fl_Widget(X,Y,W,H,l) {
|
The constructor creates the button using the given position, size and label.
|
||||||
|
\param[in] X, Y, W, H position and size of the widget
|
||||||
|
\param[in] L widget label, default is no label
|
||||||
|
*/
|
||||||
|
Fl_Button::Fl_Button(int X, int Y, int W, int H, const char *L)
|
||||||
|
: Fl_Widget(X,Y,W,H,L) {
|
||||||
box(FL_UP_BOX);
|
box(FL_UP_BOX);
|
||||||
down_box(FL_NO_BOX);
|
down_box(FL_NO_BOX);
|
||||||
value_ = oldval = 0;
|
value_ = oldval = 0;
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Forms-compatible chart widget for the Fast Light Tool Kit (FLTK).
|
// Forms-compatible chart widget for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2005 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -285,8 +285,14 @@ void Fl_Chart::draw() {
|
|||||||
#define FL_CHART_LCOL FL_LCOL
|
#define FL_CHART_LCOL FL_LCOL
|
||||||
#define FL_CHART_ALIGN FL_ALIGN_BOTTOM
|
#define FL_CHART_ALIGN FL_ALIGN_BOTTOM
|
||||||
|
|
||||||
Fl_Chart::Fl_Chart(int X, int Y, int W, int H,const char *l) :
|
/**
|
||||||
Fl_Widget(X,Y,W,H,l) {
|
Create a new Fl_Chart widget using the given position, size and label string.
|
||||||
|
The default boxstyle is \c FL_NO_BOX.
|
||||||
|
\param[in] X, Y, W, H position and size of the widget
|
||||||
|
\param[in] L widget label, default is no label
|
||||||
|
*/
|
||||||
|
Fl_Chart::Fl_Chart(int X, int Y, int W, int H,const char *L) :
|
||||||
|
Fl_Widget(X,Y,W,H,L) {
|
||||||
box(FL_BORDER_BOX);
|
box(FL_BORDER_BOX);
|
||||||
align(FL_ALIGN_BOTTOM);
|
align(FL_ALIGN_BOTTOM);
|
||||||
numb = 0;
|
numb = 0;
|
||||||
@ -300,15 +306,28 @@ Fl_Widget(X,Y,W,H,l) {
|
|||||||
entries = (FL_CHART_ENTRY *)calloc(sizeof(FL_CHART_ENTRY), FL_CHART_MAX + 1);
|
entries = (FL_CHART_ENTRY *)calloc(sizeof(FL_CHART_ENTRY), FL_CHART_MAX + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Destroys the Fl_Chart widget and all of its data.
|
||||||
|
*/
|
||||||
Fl_Chart::~Fl_Chart() {
|
Fl_Chart::~Fl_Chart() {
|
||||||
free(entries);
|
free(entries);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Removes all values from the chart.
|
||||||
|
*/
|
||||||
void Fl_Chart::clear() {
|
void Fl_Chart::clear() {
|
||||||
numb = 0;
|
numb = 0;
|
||||||
redraw();
|
redraw();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Add the data value \p val with optional label \p str and color \p col
|
||||||
|
to the chart.
|
||||||
|
\param[in] val data value
|
||||||
|
\param[in] str optional data label
|
||||||
|
\param[in] col optional data color
|
||||||
|
*/
|
||||||
void Fl_Chart::add(double val, const char *str, unsigned col) {
|
void Fl_Chart::add(double val, const char *str, unsigned col) {
|
||||||
/* Allocate more entries if required */
|
/* Allocate more entries if required */
|
||||||
if (numb >= sizenumb) {
|
if (numb >= sizenumb) {
|
||||||
@ -331,6 +350,14 @@ void Fl_Chart::add(double val, const char *str, unsigned col) {
|
|||||||
redraw();
|
redraw();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Inserts a data value \p val at the given position \p ind.
|
||||||
|
Position 1 is the first data value.
|
||||||
|
\param[in] ind insertion position
|
||||||
|
\param[in] val data value
|
||||||
|
\param[in] str optional data label
|
||||||
|
\param[in] col optional data color
|
||||||
|
*/
|
||||||
void Fl_Chart::insert(int ind, double val, const char *str, unsigned col) {
|
void Fl_Chart::insert(int ind, double val, const char *str, unsigned col) {
|
||||||
int i;
|
int i;
|
||||||
if (ind < 1 || ind > numb+1) return;
|
if (ind < 1 || ind > numb+1) return;
|
||||||
@ -353,6 +380,14 @@ void Fl_Chart::insert(int ind, double val, const char *str, unsigned col) {
|
|||||||
redraw();
|
redraw();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Replace a data value \p val at the given position \p ind.
|
||||||
|
Position 1 is the first data value.
|
||||||
|
\param[in] ind insertion position
|
||||||
|
\param[in] val data value
|
||||||
|
\param[in] str optional data label
|
||||||
|
\param[in] col optional data color
|
||||||
|
*/
|
||||||
void Fl_Chart::replace(int ind,double val, const char *str, unsigned col) {
|
void Fl_Chart::replace(int ind,double val, const char *str, unsigned col) {
|
||||||
if (ind < 1 || ind > numb) return;
|
if (ind < 1 || ind > numb) return;
|
||||||
entries[ind-1].val = float(val);
|
entries[ind-1].val = float(val);
|
||||||
@ -365,12 +400,22 @@ void Fl_Chart::replace(int ind,double val, const char *str, unsigned col) {
|
|||||||
redraw();
|
redraw();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Fl_Chart::bounds(double mymin, double mymax) {
|
/**
|
||||||
this->min = mymin;
|
Sets the lower and upper bounds of the chart values.
|
||||||
this->max = mymax;
|
\param[in] a, b are used to set lower, upper
|
||||||
|
*/
|
||||||
|
void Fl_Chart::bounds(double a, double b) {
|
||||||
|
this->min = a;
|
||||||
|
this->max = b;
|
||||||
redraw();
|
redraw();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Set the maximum number of data values for a chart.
|
||||||
|
If you do not call this method then the chart will be allowed to grow
|
||||||
|
to any size depending on available memory.
|
||||||
|
\param[in] m maximum number of data values allowed.
|
||||||
|
*/
|
||||||
void Fl_Chart::maxsize(int m) {
|
void Fl_Chart::maxsize(int m) {
|
||||||
int i;
|
int i;
|
||||||
/* Fill in the new number */
|
/* Fill in the new number */
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Check button widget for the Fast Light Tool Kit (FLTK).
|
// Check button widget for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2005 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -28,12 +28,19 @@
|
|||||||
#include <FL/Fl.H>
|
#include <FL/Fl.H>
|
||||||
#include <FL/Fl_Check_Button.H>
|
#include <FL/Fl_Check_Button.H>
|
||||||
|
|
||||||
|
// TODO Correct incorrect Fl_Check_Button comments.
|
||||||
// A subclass of Fl_Button that always draws as a diamond box. This
|
// A subclass of Fl_Button that always draws as a diamond box. This
|
||||||
// diamond is smaller than the widget size and can be surchecked by
|
// diamond is smaller than the widget size and can be surchecked by
|
||||||
// another box type, for compatibility with Forms.
|
// another box type, for compatibility with Forms.
|
||||||
|
|
||||||
Fl_Check_Button::Fl_Check_Button(int X, int Y, int W, int H, const char *l)
|
/**
|
||||||
: Fl_Light_Button(X, Y, W, H, l) {
|
Creates a new Fl_Check_Button widget using the given position, size and
|
||||||
|
label string.
|
||||||
|
\param[in] X, Y, W, H position and size of the widget
|
||||||
|
\param[in] L widget label, default is no label
|
||||||
|
*/
|
||||||
|
Fl_Check_Button::Fl_Check_Button(int X, int Y, int W, int H, const char *L)
|
||||||
|
: Fl_Light_Button(X, Y, W, H, L) {
|
||||||
box(FL_NO_BOX);
|
box(FL_NO_BOX);
|
||||||
down_box(FL_DOWN_BOX);
|
down_box(FL_DOWN_BOX);
|
||||||
selection_color(FL_FOREGROUND_COLOR);
|
selection_color(FL_FOREGROUND_COLOR);
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Choice widget for the Fast Light Tool Kit (FLTK).
|
// Choice widget for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2006 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -112,8 +112,18 @@ void Fl_Choice::draw() {
|
|||||||
draw_label();
|
draw_label();
|
||||||
}
|
}
|
||||||
|
|
||||||
Fl_Choice::Fl_Choice(int X, int Y, int W, int H, const char *l)
|
/**
|
||||||
: Fl_Menu_(X,Y,W,H,l) {
|
Create a new Fl_Choice widget using the given position, size and label string.
|
||||||
|
The default boxtype is \c FL_UP_BOX.
|
||||||
|
|
||||||
|
The constructor sets menu() to NULL.
|
||||||
|
See Fl_Menu_ for the methods to set or change the menu.
|
||||||
|
|
||||||
|
\param[in] X, Y, W, H position and size of the widget
|
||||||
|
\param[in] L widget label, default is no label
|
||||||
|
*/
|
||||||
|
Fl_Choice::Fl_Choice(int X, int Y, int W, int H, const char *L)
|
||||||
|
: Fl_Menu_(X,Y,W,H,L) {
|
||||||
align(FL_ALIGN_LEFT);
|
align(FL_ALIGN_LEFT);
|
||||||
when(FL_WHEN_RELEASE);
|
when(FL_WHEN_RELEASE);
|
||||||
textfont(FL_HELVETICA);
|
textfont(FL_HELVETICA);
|
||||||
@ -121,12 +131,24 @@ Fl_Choice::Fl_Choice(int X, int Y, int W, int H, const char *l)
|
|||||||
down_box(FL_BORDER_BOX);
|
down_box(FL_BORDER_BOX);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Sets the currently selected value using a pointer to menu item.
|
||||||
|
Changing the selected value causes a redraw().
|
||||||
|
\param[in] v pointer to menu item in the menu item array.
|
||||||
|
\returns non-zero if the new value is different to the old one.
|
||||||
|
*/
|
||||||
int Fl_Choice::value(const Fl_Menu_Item *v) {
|
int Fl_Choice::value(const Fl_Menu_Item *v) {
|
||||||
if (!Fl_Menu_::value(v)) return 0;
|
if (!Fl_Menu_::value(v)) return 0;
|
||||||
redraw();
|
redraw();
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Sets the currently selected value using the index into the menu item array.
|
||||||
|
Changing the selected value causes a redraw().
|
||||||
|
\param[in] v index of value in the menu item array.
|
||||||
|
\returns non-zero if the new value is different to the old one.
|
||||||
|
*/
|
||||||
int Fl_Choice::value(int v) {
|
int Fl_Choice::value(int v) {
|
||||||
if (v == -1) return value((const Fl_Menu_Item *)0);
|
if (v == -1) return value((const Fl_Menu_Item *)0);
|
||||||
if (v < 0 || v >= (size() - 1)) return 0;
|
if (v < 0 || v >= (size() - 1)) return 0;
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Clock widget for the Fast Light Tool Kit (FLTK).
|
// Clock widget for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2006 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -112,6 +112,12 @@ void Fl_Clock_Output::draw() {
|
|||||||
draw_label();
|
draw_label();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Set the displayed time.
|
||||||
|
Set the time in hours, minutes, and seconds.
|
||||||
|
\param[in] H, m, s displayed time
|
||||||
|
\see hour(), minute(), second()
|
||||||
|
*/
|
||||||
void Fl_Clock_Output::value(int H, int m, int s) {
|
void Fl_Clock_Output::value(int H, int m, int s) {
|
||||||
if (H!=hour_ || m!=minute_ || s!=second_) {
|
if (H!=hour_ || m!=minute_ || s!=second_) {
|
||||||
hour_ = H; minute_ = m; second_ = s;
|
hour_ = H; minute_ = m; second_ = s;
|
||||||
@ -120,6 +126,12 @@ void Fl_Clock_Output::value(int H, int m, int s) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Set the displayed time.
|
||||||
|
Set the time in seconds since the UNIX epoch (January 1, 1970).
|
||||||
|
\param[in] v seconds since epoch
|
||||||
|
\see value()
|
||||||
|
*/
|
||||||
void Fl_Clock_Output::value(ulong v) {
|
void Fl_Clock_Output::value(ulong v) {
|
||||||
value_ = v;
|
value_ = v;
|
||||||
struct tm *timeofday;
|
struct tm *timeofday;
|
||||||
@ -129,8 +141,14 @@ void Fl_Clock_Output::value(ulong v) {
|
|||||||
value(timeofday->tm_hour, timeofday->tm_min, timeofday->tm_sec);
|
value(timeofday->tm_hour, timeofday->tm_min, timeofday->tm_sec);
|
||||||
}
|
}
|
||||||
|
|
||||||
Fl_Clock_Output::Fl_Clock_Output(int X, int Y, int W, int H, const char *l)
|
/**
|
||||||
: Fl_Widget(X, Y, W, H, l) {
|
Create a new Fl_Clock_Output widget with the given position, size and label.
|
||||||
|
The default boxtype is \c FL_NO_BOX.
|
||||||
|
\param[in] X, Y, W, H position and size of the widget
|
||||||
|
\param[in] L widget label, default is no label
|
||||||
|
*/
|
||||||
|
Fl_Clock_Output::Fl_Clock_Output(int X, int Y, int W, int H, const char *L)
|
||||||
|
: Fl_Widget(X, Y, W, H, L) {
|
||||||
box(FL_UP_BOX);
|
box(FL_UP_BOX);
|
||||||
selection_color(fl_gray_ramp(5));
|
selection_color(fl_gray_ramp(5));
|
||||||
align(FL_ALIGN_BOTTOM);
|
align(FL_ALIGN_BOTTOM);
|
||||||
@ -142,11 +160,24 @@ Fl_Clock_Output::Fl_Clock_Output(int X, int Y, int W, int H, const char *l)
|
|||||||
|
|
||||||
////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
Fl_Clock::Fl_Clock(int X, int Y, int W, int H, const char *l)
|
/**
|
||||||
: Fl_Clock_Output(X, Y, W, H, l) {}
|
Create an Fl_Clock widget using the given position, size, and label string.
|
||||||
|
The default boxtype is \c FL_NO_BOX.
|
||||||
|
\param[in] X, Y, W, H position and size of the widget
|
||||||
|
\param[in] L widget label, default is no label
|
||||||
|
*/
|
||||||
|
Fl_Clock::Fl_Clock(int X, int Y, int W, int H, const char *L)
|
||||||
|
: Fl_Clock_Output(X, Y, W, H, L) {}
|
||||||
|
|
||||||
Fl_Clock::Fl_Clock(uchar t, int X, int Y, int W, int H, const char *l)
|
/**
|
||||||
: Fl_Clock_Output(X, Y, W, H, l) {
|
Create an Fl_Clock widget using the given boxtype, position, size, and
|
||||||
|
label string.
|
||||||
|
\param[in] t boxtype
|
||||||
|
\param[in] X, Y, W, H position and size of the widget
|
||||||
|
\param[in] L widget label, default is no label
|
||||||
|
*/
|
||||||
|
Fl_Clock::Fl_Clock(uchar t, int X, int Y, int W, int H, const char *L)
|
||||||
|
: Fl_Clock_Output(X, Y, W, H, L) {
|
||||||
type(t);
|
type(t);
|
||||||
box(t==FL_ROUND_CLOCK ? FL_NO_BOX : FL_UP_BOX);
|
box(t==FL_ROUND_CLOCK ? FL_NO_BOX : FL_UP_BOX);
|
||||||
}
|
}
|
||||||
@ -168,6 +199,9 @@ int Fl_Clock::handle(int event) {
|
|||||||
return Fl_Clock_Output::handle(event);
|
return Fl_Clock_Output::handle(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
The destructor removes the clock.
|
||||||
|
*/
|
||||||
Fl_Clock::~Fl_Clock() {
|
Fl_Clock::~Fl_Clock() {
|
||||||
Fl::remove_timeout(tick, this);
|
Fl::remove_timeout(tick, this);
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Color chooser for the Fast Light Tool Kit (FLTK).
|
// Color chooser for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2005 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -47,6 +47,11 @@
|
|||||||
// you get this by defining this:
|
// you get this by defining this:
|
||||||
#define UPDATE_HUE_BOX 1
|
#define UPDATE_HUE_BOX 1
|
||||||
|
|
||||||
|
/**
|
||||||
|
This \e static method converts HSV colors to RGB colorspace.
|
||||||
|
\param[in] H, S, V color components
|
||||||
|
\param[out] R, G, B color components
|
||||||
|
*/
|
||||||
void Fl_Color_Chooser::hsv2rgb(
|
void Fl_Color_Chooser::hsv2rgb(
|
||||||
double H, double S, double V, double& R, double& G, double& B) {
|
double H, double S, double V, double& R, double& G, double& B) {
|
||||||
if (S < 5.0e-6) {
|
if (S < 5.0e-6) {
|
||||||
@ -68,6 +73,11 @@ void Fl_Color_Chooser::hsv2rgb(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
This \e static method converts RGB colors to HSV colorspace.
|
||||||
|
\param[in] R, G, B color components
|
||||||
|
\param[out] H, S, V color components
|
||||||
|
*/
|
||||||
void Fl_Color_Chooser::rgb2hsv(
|
void Fl_Color_Chooser::rgb2hsv(
|
||||||
double R, double G, double B, double& H, double& S, double& V) {
|
double R, double G, double B, double& H, double& S, double& V) {
|
||||||
double maxv = R > G ? R : G; if (B > maxv) maxv = B;
|
double maxv = R > G ? R : G; if (B > maxv) maxv = B;
|
||||||
@ -119,6 +129,12 @@ void Fl_Color_Chooser::set_valuators() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Sets the current rgb color values.
|
||||||
|
Does not do the callback. Does not clamp (but out of range values will
|
||||||
|
produce psychedelic effects in the hue selector).
|
||||||
|
\param[in] R, G, B color components.
|
||||||
|
*/
|
||||||
int Fl_Color_Chooser::rgb(double R, double G, double B) {
|
int Fl_Color_Chooser::rgb(double R, double G, double B) {
|
||||||
if (R == r_ && G == g_ && B == b_) return 0;
|
if (R == r_ && G == g_ && B == b_) return 0;
|
||||||
r_ = R; g_ = G; b_ = B;
|
r_ = R; g_ = G; b_ = B;
|
||||||
@ -140,6 +156,12 @@ int Fl_Color_Chooser::rgb(double R, double G, double B) {
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Set the hsv values.
|
||||||
|
The passed values are clamped (or for hue, modulus 6 is used) to get
|
||||||
|
legal values. Does not do the callback.
|
||||||
|
\param[in] H, S, V color components.
|
||||||
|
*/
|
||||||
int Fl_Color_Chooser::hsv(double H, double S, double V) {
|
int Fl_Color_Chooser::hsv(double H, double S, double V) {
|
||||||
H = fmod(H,6.0); if (H < 0.0) H += 6.0;
|
H = fmod(H,6.0); if (H < 0.0) H += 6.0;
|
||||||
if (S < 0.0) S = 0.0; else if (S > 1.0) S = 1.0;
|
if (S < 0.0) S = 0.0; else if (S > 1.0) S = 1.0;
|
||||||
@ -413,6 +435,13 @@ void Fl_Color_Chooser::mode_cb(Fl_Widget* o, void*) {
|
|||||||
|
|
||||||
////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
/**
|
||||||
|
Creates a new Fl_Color_Chooser widget using the given position, size, and
|
||||||
|
label string.
|
||||||
|
The recommended dimensions are 200x95. The color is initialized to black.
|
||||||
|
\param[in] X, Y, W, H position and size of the widget
|
||||||
|
\param[in] L widget label, default is no label
|
||||||
|
*/
|
||||||
Fl_Color_Chooser::Fl_Color_Chooser(int X, int Y, int W, int H, const char* L)
|
Fl_Color_Chooser::Fl_Color_Chooser(int X, int Y, int W, int H, const char* L)
|
||||||
: Fl_Group(0,0,195,115,L),
|
: Fl_Group(0,0,195,115,L),
|
||||||
huebox(0,0,115,115),
|
huebox(0,0,115,115),
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//
|
//
|
||||||
// Counter widget for the Fast Light Tool Kit (FLTK).
|
// Counter widget for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
// Copyright 1998-2005 by Bill Spitzak and others.
|
// Copyright 1998-2008 by Bill Spitzak and others.
|
||||||
//
|
//
|
||||||
// This library is free software; you can redistribute it and/or
|
// This library is free software; you can redistribute it and/or
|
||||||
// modify it under the terms of the GNU Library General Public
|
// modify it under the terms of the GNU Library General Public
|
||||||
@ -174,12 +174,21 @@ int Fl_Counter::handle(int event) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Destroys the valuator.
|
||||||
|
*/
|
||||||
Fl_Counter::~Fl_Counter() {
|
Fl_Counter::~Fl_Counter() {
|
||||||
Fl::remove_timeout(repeat_callback, this);
|
Fl::remove_timeout(repeat_callback, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
Fl_Counter::Fl_Counter(int X, int Y, int W, int H, const char* l)
|
/**
|
||||||
: Fl_Valuator(X, Y, W, H, l) {
|
Creates a new Fl_Counter widget using the given position, size, and label
|
||||||
|
string. The default type is FL_NORMAL_COUNTER.
|
||||||
|
\param[in] X, Y, W, H position and size of the widget
|
||||||
|
\param[in] L widget label, default is no label
|
||||||
|
*/
|
||||||
|
Fl_Counter::Fl_Counter(int X, int Y, int W, int H, const char* L)
|
||||||
|
: Fl_Valuator(X, Y, W, H, L) {
|
||||||
box(FL_UP_BOX);
|
box(FL_UP_BOX);
|
||||||
selection_color(FL_INACTIVE_COLOR); // was FL_BLUE
|
selection_color(FL_INACTIVE_COLOR); // was FL_BLUE
|
||||||
align(FL_ALIGN_BOTTOM);
|
align(FL_ALIGN_BOTTOM);
|
||||||
|
Loading…
Reference in New Issue
Block a user