2008-03-08 08:52:38 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: spinctrl.h
|
2008-03-10 11:24:38 -04:00
|
|
|
// Purpose: interface of wxSpinCtrl
|
2008-03-08 08:52:38 -05:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
2010-07-13 09:29:13 -04:00
|
|
|
// Licence: wxWindows licence
|
2008-03-08 08:52:38 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxSpinCtrl
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-10-05 07:24:00 -04:00
|
|
|
wxSpinCtrl combines wxTextCtrl and wxSpinButton in one control.
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
@beginStyleTable
|
2008-04-06 10:43:04 -04:00
|
|
|
@style{wxSP_ARROW_KEYS}
|
2008-09-14 15:50:30 -04:00
|
|
|
The user can use arrow keys to change the value.
|
2008-04-06 10:43:04 -04:00
|
|
|
@style{wxSP_WRAP}
|
2008-09-14 15:50:30 -04:00
|
|
|
The value wraps at the minimum and maximum.
|
|
|
|
@style{wxTE_PROCESS_ENTER}
|
|
|
|
Indicates that the control should generate wxEVT_COMMAND_TEXT_ENTER
|
|
|
|
events. Using this style will prevent the user from using the Enter key
|
|
|
|
for dialog navigation (e.g. activating the default button in the
|
|
|
|
dialog) under MSW.
|
2009-03-22 06:55:55 -04:00
|
|
|
@style{wxALIGN_LEFT}
|
|
|
|
Same as wxTE_LEFT for wxTextCtrl: the text is left aligned.
|
|
|
|
@style{wxALIGN_CENTRE}
|
|
|
|
Same as wxTE_CENTRE for wxTextCtrl: the text is centered.
|
|
|
|
@style{wxALIGN_RIGHT}
|
|
|
|
Same as wxTE_RIGHT for wxTextCtrl: the text is right aligned (this is
|
|
|
|
the default).
|
2008-03-08 08:52:38 -05:00
|
|
|
@endStyleTable
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-10-05 07:24:00 -04:00
|
|
|
|
2009-02-18 12:58:51 -05:00
|
|
|
@beginEventEmissionTable{wxSpinEvent}
|
2008-10-05 07:24:00 -04:00
|
|
|
@event{EVT_SPINCTRL(id, func)}
|
|
|
|
Generated whenever the numeric value of the spinctrl is updated
|
|
|
|
@endEventTable
|
|
|
|
|
|
|
|
You may also use the wxSpinButton event macros, however the corresponding events
|
|
|
|
will not be generated under all platforms. Finally, if the user modifies the
|
|
|
|
text in the edit part of the spin control directly, the EVT_TEXT is generated,
|
|
|
|
like for the wxTextCtrl. When the use enters text into the text area, the text
|
|
|
|
is not validated until the control loses focus (e.g. by using the TAB key).
|
|
|
|
The value is then adjusted to the range and a wxSpinEvent sent then if the value
|
|
|
|
is different from the last value sent.
|
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
@library{wxcore}
|
|
|
|
@category{ctrl}
|
2008-10-13 04:05:18 -04:00
|
|
|
@appearance{spinctrl.png}
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-08-18 07:41:27 -04:00
|
|
|
@see wxSpinButton, wxSpinCtrlDouble, wxControl
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
|
|
|
class wxSpinCtrl : public wxControl
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
2008-05-24 15:37:12 -04:00
|
|
|
Default constructor.
|
|
|
|
*/
|
|
|
|
wxSpinCtrl();
|
2008-10-05 07:24:00 -04:00
|
|
|
|
2008-05-24 15:37:12 -04:00
|
|
|
/**
|
2008-03-08 08:52:38 -05:00
|
|
|
Constructor, creating and showing a spin control.
|
2008-03-20 09:45:17 -04:00
|
|
|
|
2008-03-08 09:43:31 -05:00
|
|
|
@param parent
|
2008-03-09 08:33:59 -04:00
|
|
|
Parent window. Must not be @NULL.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param value
|
2008-05-24 15:37:12 -04:00
|
|
|
Default value (as text).
|
2008-03-08 09:43:31 -05:00
|
|
|
@param id
|
2008-03-09 08:33:59 -04:00
|
|
|
Window identifier. The value wxID_ANY indicates a default value.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param pos
|
2008-10-05 07:24:00 -04:00
|
|
|
Window position.
|
2009-04-21 07:21:36 -04:00
|
|
|
If ::wxDefaultPosition is specified then a default position is chosen.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param size
|
2008-10-05 07:24:00 -04:00
|
|
|
Window size.
|
2009-04-21 07:21:36 -04:00
|
|
|
If ::wxDefaultSize is specified then a default size is chosen.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param style
|
2008-03-09 08:33:59 -04:00
|
|
|
Window style. See wxSpinButton.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param min
|
2008-03-09 08:33:59 -04:00
|
|
|
Minimal value.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param max
|
2008-03-09 08:33:59 -04:00
|
|
|
Maximal value.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param initial
|
2008-03-09 08:33:59 -04:00
|
|
|
Initial value.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param name
|
2008-03-09 08:33:59 -04:00
|
|
|
Window name.
|
2008-03-20 09:45:17 -04:00
|
|
|
|
2008-03-09 08:33:59 -04:00
|
|
|
@see Create()
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
2008-11-13 16:32:53 -05:00
|
|
|
wxSpinCtrl(wxWindow* parent, wxWindowID id = wxID_ANY,
|
2008-03-08 09:43:31 -05:00
|
|
|
const wxString& value = wxEmptyString,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = wxSP_ARROW_KEYS,
|
|
|
|
int min = 0, int max = 100,
|
2008-11-13 16:32:53 -05:00
|
|
|
int initial = 0, const wxString& name = "wxSpinCtrl");
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Creation function called by the spin control constructor.
|
|
|
|
See wxSpinCtrl() for details.
|
|
|
|
*/
|
2008-10-28 11:36:26 -04:00
|
|
|
bool Create(wxWindow* parent, wxWindowID id = wxID_ANY,
|
2008-03-08 08:52:38 -05:00
|
|
|
const wxString& value = wxEmptyString,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
2008-10-28 11:36:26 -04:00
|
|
|
long style = wxSP_ARROW_KEYS, int min = 0, int max = 100,
|
|
|
|
int initial = 0, const wxString& name = "wxSpinCtrl");
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Gets maximal allowable value.
|
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
int GetMax() const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Gets minimal allowable value.
|
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
int GetMin() const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the value of the spin control.
|
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
int GetValue() const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets range of allowable values.
|
|
|
|
*/
|
|
|
|
void SetRange(int minVal, int maxVal);
|
|
|
|
|
|
|
|
/**
|
2008-03-08 09:43:31 -05:00
|
|
|
Select the text in the text part of the control between positions
|
2008-10-05 07:24:00 -04:00
|
|
|
@a from (inclusive) and @a to (exclusive).
|
|
|
|
This is similar to wxTextCtrl::SetSelection().
|
|
|
|
|
2008-03-28 12:19:12 -04:00
|
|
|
@note this is currently only implemented for Windows and generic versions
|
2008-10-05 07:24:00 -04:00
|
|
|
of the control.
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
2008-10-13 07:09:56 -04:00
|
|
|
virtual void SetSelection(long from, long to);
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
2008-05-24 15:37:12 -04:00
|
|
|
Sets the value of the spin control. Use the variant using int instead.
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
2008-09-27 07:21:10 -04:00
|
|
|
virtual void SetValue(const wxString& text);
|
2008-05-24 15:37:12 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the value of the spin control.
|
|
|
|
*/
|
2008-03-08 09:43:31 -05:00
|
|
|
void SetValue(int value);
|
2008-03-08 08:52:38 -05:00
|
|
|
};
|
2008-03-10 11:24:38 -04:00
|
|
|
|
2009-12-19 07:00:16 -05:00
|
|
|
/**
|
|
|
|
@class wxSpinCtrlDouble
|
|
|
|
|
|
|
|
wxSpinCtrlDouble combines wxTextCtrl and wxSpinButton in one control and
|
|
|
|
displays a real number. (wxSpinCtrl displays an integer.)
|
|
|
|
|
|
|
|
@beginStyleTable
|
|
|
|
@style{wxSP_ARROW_KEYS}
|
|
|
|
The user can use arrow keys to change the value.
|
|
|
|
@style{wxSP_WRAP}
|
|
|
|
The value wraps at the minimum and maximum.
|
|
|
|
@endStyleTable
|
|
|
|
|
2010-09-27 07:57:03 -04:00
|
|
|
@beginEventEmissionTable{wxSpinDoubleEvent}
|
|
|
|
@event{EVT_SPINCTRLDOUBLE(id, func)}
|
|
|
|
Generated whenever the numeric value of the spin control is changed,
|
|
|
|
that is, when the up/down spin button is clicked, when ENTER is pressed,
|
|
|
|
or the control loses focus and the new value is different from the last.
|
|
|
|
See wxSpinDoubleEvent.
|
|
|
|
@endEventTable
|
|
|
|
|
2009-12-19 07:00:16 -05:00
|
|
|
@library{wxcore}
|
|
|
|
@category{ctrl}
|
|
|
|
@appearance{spinctrldouble.png}
|
|
|
|
|
|
|
|
@see wxSpinButton, wxSpinCtrl, wxControl
|
|
|
|
*/
|
|
|
|
class wxSpinCtrlDouble : public wxControl
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Default constructor.
|
|
|
|
*/
|
|
|
|
wxSpinCtrlDouble();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Constructor, creating and showing a spin control.
|
|
|
|
|
|
|
|
@param parent
|
|
|
|
Parent window. Must not be @NULL.
|
|
|
|
@param value
|
|
|
|
Default value (as text).
|
|
|
|
@param id
|
|
|
|
Window identifier. The value wxID_ANY indicates a default value.
|
|
|
|
@param pos
|
|
|
|
Window position.
|
|
|
|
If ::wxDefaultPosition is specified then a default position is chosen.
|
|
|
|
@param size
|
|
|
|
Window size.
|
|
|
|
If ::wxDefaultSize is specified then a default size is chosen.
|
|
|
|
@param style
|
|
|
|
Window style. See wxSpinButton.
|
|
|
|
@param min
|
|
|
|
Minimal value.
|
|
|
|
@param max
|
|
|
|
Maximal value.
|
|
|
|
@param initial
|
|
|
|
Initial value.
|
|
|
|
@param inc
|
|
|
|
Increment value.
|
|
|
|
@param name
|
|
|
|
Window name.
|
|
|
|
|
|
|
|
@see Create()
|
|
|
|
*/
|
|
|
|
wxSpinCtrlDouble(wxWindow* parent, wxWindowID id = -1,
|
|
|
|
const wxString& value = wxEmptyString,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = wxSP_ARROW_KEYS,
|
|
|
|
double min = 0, double max = 100,
|
|
|
|
double initial = 0, double inc = 1,
|
|
|
|
const wxString& name = wxT("wxSpinCtrlDouble"));
|
|
|
|
|
|
|
|
/**
|
|
|
|
Creation function called by the spin control constructor.
|
|
|
|
See wxSpinCtrlDouble() for details.
|
|
|
|
*/
|
|
|
|
bool Create(wxWindow* parent, wxWindowID id = wxID_ANY,
|
|
|
|
const wxString& value = wxEmptyString,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = wxSP_ARROW_KEYS, double min = 0, double max = 100,
|
|
|
|
double initial = 0, double inc = 1,
|
|
|
|
const wxString& name = "wxSpinCtrlDouble");
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the number of digits in the display.
|
|
|
|
*/
|
|
|
|
unsigned int GetDigits() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the increment value.
|
|
|
|
*/
|
|
|
|
double GetIncrement() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets maximal allowable value.
|
|
|
|
*/
|
|
|
|
double GetMax() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets minimal allowable value.
|
|
|
|
*/
|
|
|
|
double GetMin() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the value of the spin control.
|
|
|
|
*/
|
|
|
|
double GetValue() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the number of digits in the display.
|
|
|
|
*/
|
|
|
|
void SetDigits(unsigned int digits);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the increment value.
|
|
|
|
*/
|
|
|
|
void SetIncrement(double inc);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets range of allowable values.
|
|
|
|
*/
|
|
|
|
void SetRange(double minVal, double maxVal);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the value of the spin control. Use the variant using double instead.
|
|
|
|
*/
|
|
|
|
virtual void SetValue(const wxString& text);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the value of the spin control.
|
|
|
|
*/
|
|
|
|
void SetValue(double value);
|
|
|
|
};
|
2010-09-27 07:57:03 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxSpinDoubleEvent
|
|
|
|
|
|
|
|
This event class is used for the events generated by wxSpinCtrlDouble.
|
|
|
|
|
|
|
|
@beginEventTable{wxSpinDoubleEvent}
|
|
|
|
@event{EVT_SPINCTRLDOUBLE(id, func)}
|
|
|
|
Generated whenever the numeric value of the spin control is changed,
|
|
|
|
that is, when the up/down spin button is clicked, when ENTER is pressed,
|
|
|
|
or the control loses focus and the new value is different from the last.
|
|
|
|
See wxSpinDoubleEvent.
|
|
|
|
@endEventTable
|
|
|
|
|
|
|
|
@library{wxcore}
|
|
|
|
@category{events}
|
|
|
|
|
|
|
|
@see wxSpinCtrlDouble
|
|
|
|
*/
|
|
|
|
class wxSpinDoubleEvent : public wxNotifyEvent
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
The constructor. Not normally used by the user code.
|
|
|
|
*/
|
|
|
|
wxSpinDoubleEvent(wxEventType commandType = wxEVT_NULL, int winid = 0,
|
|
|
|
double value = 0);
|
|
|
|
|
|
|
|
/**
|
|
|
|
The copy constructor.
|
|
|
|
*/
|
|
|
|
wxSpinDoubleEvent(const wxSpinDoubleEvent& event);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the value associated with this spin control event.
|
|
|
|
*/
|
|
|
|
double GetValue() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the value associated with the event.
|
|
|
|
(Not normally used by user code.)
|
|
|
|
*/
|
|
|
|
void SetValue(double value);
|
|
|
|
};
|