2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: checkbox.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxCheckBox
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
2010-07-13 13:29:13 +00:00
|
|
|
// Licence: wxWindows licence
|
2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2008-04-05 09:12:23 +00:00
|
|
|
/**
|
|
|
|
The possible states of a 3-state wxCheckBox (Compatible with the 2-state
|
|
|
|
wxCheckBox).
|
|
|
|
*/
|
|
|
|
enum wxCheckBoxState
|
|
|
|
{
|
|
|
|
wxCHK_UNCHECKED,
|
|
|
|
wxCHK_CHECKED,
|
|
|
|
wxCHK_UNDETERMINED ///< 3-state checkbox only
|
|
|
|
};
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxCheckBox
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
A checkbox is a labelled box which by default is either on (checkmark is
|
2008-04-05 09:12:23 +00:00
|
|
|
visible) or off (no checkmark). Optionally (when the wxCHK_3STATE style
|
|
|
|
flag is set) it can have a third state, called the mixed or undetermined
|
|
|
|
state. Often this is used as a "Does Not Apply" state.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@beginStyleTable
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxCHK_2STATE}
|
2008-03-08 13:52:38 +00:00
|
|
|
Create a 2-state checkbox. This is the default.
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxCHK_3STATE}
|
2008-03-08 13:52:38 +00:00
|
|
|
Create a 3-state checkbox. Not implemented in wxMGL, wxOS2 and
|
|
|
|
wxGTK built against GTK+ 1.2.
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxCHK_ALLOW_3RD_STATE_FOR_USER}
|
2008-03-08 13:52:38 +00:00
|
|
|
By default a user can't set a 3-state checkbox to the third state.
|
|
|
|
It can only be done from code. Using this flags allows the user to
|
|
|
|
set the checkbox to the third state by clicking.
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxALIGN_RIGHT}
|
2008-03-08 13:52:38 +00:00
|
|
|
Makes the text appear on the left of the checkbox.
|
|
|
|
@endStyleTable
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2009-02-18 17:58:51 +00:00
|
|
|
@beginEventEmissionTable{wxCommandEvent}
|
2008-04-06 14:43:04 +00:00
|
|
|
@event{EVT_CHECKBOX(id, func)}
|
2011-01-06 19:52:14 +00:00
|
|
|
Process a @c wxEVT_COMMAND_CHECKBOX_CLICKED event, when the checkbox
|
2008-03-08 13:52:38 +00:00
|
|
|
is clicked.
|
|
|
|
@endEventTable
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxcore}
|
|
|
|
@category{ctrl}
|
2008-10-13 08:05:18 +00:00
|
|
|
@appearance{checkbox.png}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxRadioButton, wxCommandEvent
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxCheckBox : public wxControl
|
|
|
|
{
|
|
|
|
public:
|
2008-04-05 09:12:23 +00:00
|
|
|
/**
|
|
|
|
Default constructor.
|
|
|
|
|
|
|
|
@see Create(), wxValidator
|
|
|
|
*/
|
|
|
|
wxCheckBox();
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
Constructor, creating and showing a checkbox.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 14:43:31 +00:00
|
|
|
@param parent
|
2008-03-09 12:33:59 +00:00
|
|
|
Parent window. Must not be @NULL.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param id
|
2008-03-09 12:33:59 +00:00
|
|
|
Checkbox identifier. The value wxID_ANY indicates a default value.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param label
|
2008-03-09 12:33:59 +00:00
|
|
|
Text to be displayed next to the checkbox.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param pos
|
2009-04-21 11:21:36 +00:00
|
|
|
Checkbox position.
|
|
|
|
If ::wxDefaultPosition is specified then a default position is chosen.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param size
|
2009-04-21 11:21:36 +00:00
|
|
|
Checkbox size.
|
|
|
|
If ::wxDefaultSize is specified then a default size is chosen.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param style
|
2008-03-09 12:33:59 +00:00
|
|
|
Window style. See wxCheckBox.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param validator
|
2008-03-09 12:33:59 +00:00
|
|
|
Window validator.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param name
|
2008-03-09 12:33:59 +00:00
|
|
|
Window name.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
@see Create(), wxValidator
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-08 14:43:31 +00:00
|
|
|
wxCheckBox(wxWindow* parent, wxWindowID id,
|
|
|
|
const wxString& label,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = 0,
|
2008-08-30 12:44:43 +00:00
|
|
|
const wxValidator& validator = wxDefaultValidator,
|
2008-09-21 23:48:04 +00:00
|
|
|
const wxString& name = wxCheckBoxNameStr);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor, destroying the checkbox.
|
|
|
|
*/
|
2008-09-21 23:48:04 +00:00
|
|
|
virtual ~wxCheckBox();
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Creates the checkbox for two-step construction. See wxCheckBox()
|
|
|
|
for details.
|
|
|
|
*/
|
2008-09-21 23:48:04 +00:00
|
|
|
bool Create(wxWindow* parent, wxWindowID id, const wxString& label,
|
2008-03-08 13:52:38 +00:00
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
2008-09-21 23:48:04 +00:00
|
|
|
const wxSize& size = wxDefaultSize, long style = 0,
|
2008-08-30 12:44:43 +00:00
|
|
|
const wxValidator& validator = wxDefaultValidator,
|
2008-09-21 23:48:04 +00:00
|
|
|
const wxString& = wxCheckBoxNameStr);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the state of a 2-state checkbox.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-05-11 01:38:53 +00:00
|
|
|
@return Returns @true if it is checked, @false otherwise.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-09-21 23:48:04 +00:00
|
|
|
virtual bool GetValue() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
2008-04-05 09:12:23 +00:00
|
|
|
/**
|
|
|
|
Gets the state of a 3-state checkbox. Asserts when the function is used
|
|
|
|
with a 2-state checkbox.
|
|
|
|
*/
|
|
|
|
wxCheckBoxState Get3StateValue() const;
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
Returns whether or not the checkbox is a 3-state checkbox.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-05-11 01:38:53 +00:00
|
|
|
@return @true if this checkbox is a 3-state checkbox, @false if it's
|
|
|
|
a 2-state checkbox.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool Is3State() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-04-05 09:12:23 +00:00
|
|
|
Returns whether or not the user can set the checkbox to the third
|
|
|
|
state.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-05-11 01:38:53 +00:00
|
|
|
@return @true if the user can set the third state of this checkbox,
|
|
|
|
@false if it can only be set programmatically or if it's a
|
|
|
|
2-state checkbox.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool Is3rdStateAllowedForUser() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-04-05 09:12:23 +00:00
|
|
|
This is just a maybe more readable synonym for GetValue(): just as the
|
|
|
|
latter, it returns @true if the checkbox is checked and @false
|
|
|
|
otherwise.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool IsChecked() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the checkbox to the given state. This does not cause a
|
2011-01-06 19:52:14 +00:00
|
|
|
@c wxEVT_COMMAND_CHECKBOX_CLICKED event to get emitted.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 14:43:31 +00:00
|
|
|
@param state
|
2008-03-09 12:33:59 +00:00
|
|
|
If @true, the check is on, otherwise it is off.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-09-21 23:48:04 +00:00
|
|
|
virtual void SetValue(bool state);
|
2008-04-05 09:12:23 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the checkbox to the given state. This does not cause a
|
2011-01-06 19:52:14 +00:00
|
|
|
@c wxEVT_COMMAND_CHECKBOX_CLICKED event to get emitted.
|
2008-04-05 09:12:23 +00:00
|
|
|
|
|
|
|
Asserts when the checkbox is a 2-state checkbox and setting the state
|
|
|
|
to wxCHK_UNDETERMINED.
|
|
|
|
*/
|
2008-09-22 18:21:32 +00:00
|
|
|
void Set3StateValue(wxCheckBoxState state);
|
2008-03-08 13:52:38 +00:00
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|