]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/checkbox.h
use a single wxBookCtrlEvent class for all wxBookCtrlBase-derived controls (#9667)
[wxWidgets.git] / interface / wx / checkbox.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: checkbox.h
e54c96f1 3// Purpose: interface of wxCheckBox
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
bfac6166
BP
9/**
10 The possible states of a 3-state wxCheckBox (Compatible with the 2-state
11 wxCheckBox).
12*/
13enum wxCheckBoxState
14{
15 wxCHK_UNCHECKED,
16 wxCHK_CHECKED,
17 wxCHK_UNDETERMINED ///< 3-state checkbox only
18};
19
23324ae1
FM
20/**
21 @class wxCheckBox
7c913512 22
23324ae1 23 A checkbox is a labelled box which by default is either on (checkmark is
bfac6166
BP
24 visible) or off (no checkmark). Optionally (when the wxCHK_3STATE style
25 flag is set) it can have a third state, called the mixed or undetermined
26 state. Often this is used as a "Does Not Apply" state.
7c913512 27
23324ae1 28 @beginStyleTable
8c6791e4 29 @style{wxCHK_2STATE}
23324ae1 30 Create a 2-state checkbox. This is the default.
8c6791e4 31 @style{wxCHK_3STATE}
23324ae1
FM
32 Create a 3-state checkbox. Not implemented in wxMGL, wxOS2 and
33 wxGTK built against GTK+ 1.2.
8c6791e4 34 @style{wxCHK_ALLOW_3RD_STATE_FOR_USER}
23324ae1
FM
35 By default a user can't set a 3-state checkbox to the third state.
36 It can only be done from code. Using this flags allows the user to
37 set the checkbox to the third state by clicking.
8c6791e4 38 @style{wxALIGN_RIGHT}
23324ae1
FM
39 Makes the text appear on the left of the checkbox.
40 @endStyleTable
7c913512 41
1f1d2182 42 @beginEventTable{wxCommandEvent}
8c6791e4 43 @event{EVT_CHECKBOX(id, func)}
23324ae1
FM
44 Process a wxEVT_COMMAND_CHECKBOX_CLICKED event, when the checkbox
45 is clicked.
46 @endEventTable
7c913512 47
23324ae1
FM
48 @library{wxcore}
49 @category{ctrl}
bfac6166 50 <!-- @appearance{checkbox.png} -->
7c913512 51
e54c96f1 52 @see wxRadioButton, wxCommandEvent
23324ae1
FM
53*/
54class wxCheckBox : public wxControl
55{
56public:
bfac6166
BP
57 /**
58 Default constructor.
59
60 @see Create(), wxValidator
61 */
62 wxCheckBox();
63
23324ae1
FM
64 /**
65 Constructor, creating and showing a checkbox.
3c4f71cc 66
7c913512 67 @param parent
4cc4bfaf 68 Parent window. Must not be @NULL.
7c913512 69 @param id
4cc4bfaf 70 Checkbox identifier. The value wxID_ANY indicates a default value.
7c913512 71 @param label
4cc4bfaf 72 Text to be displayed next to the checkbox.
7c913512 73 @param pos
4cc4bfaf 74 Checkbox position. If wxDefaultPosition is specified then a default
bfac6166 75 position is chosen.
7c913512 76 @param size
bfac6166
BP
77 Checkbox size. If wxDefaultSize is specified then a default size is
78 chosen.
7c913512 79 @param style
4cc4bfaf 80 Window style. See wxCheckBox.
7c913512 81 @param validator
4cc4bfaf 82 Window validator.
7c913512 83 @param name
4cc4bfaf 84 Window name.
3c4f71cc 85
4cc4bfaf 86 @see Create(), wxValidator
23324ae1 87 */
7c913512
FM
88 wxCheckBox(wxWindow* parent, wxWindowID id,
89 const wxString& label,
90 const wxPoint& pos = wxDefaultPosition,
91 const wxSize& size = wxDefaultSize,
92 long style = 0,
1d497b99 93 const wxValidator& val = wxDefaultValidator,
7c913512 94 const wxString& name = "checkBox");
23324ae1
FM
95
96 /**
97 Destructor, destroying the checkbox.
98 */
99 ~wxCheckBox();
100
101 /**
102 Creates the checkbox for two-step construction. See wxCheckBox()
103 for details.
104 */
105 bool Create(wxWindow* parent, wxWindowID id,
106 const wxString& label,
107 const wxPoint& pos = wxDefaultPosition,
108 const wxSize& size = wxDefaultSize,
109 long style = 0,
1d497b99 110 const wxValidator& val = wxDefaultValidator,
23324ae1
FM
111 const wxString& name = "checkBox");
112
23324ae1
FM
113 /**
114 Gets the state of a 2-state checkbox.
3c4f71cc 115
d29a9a8a 116 @return Returns @true if it is checked, @false otherwise.
23324ae1 117 */
328f5751 118 bool GetValue() const;
23324ae1 119
bfac6166
BP
120 /**
121 Gets the state of a 3-state checkbox. Asserts when the function is used
122 with a 2-state checkbox.
123 */
124 wxCheckBoxState Get3StateValue() const;
125
23324ae1
FM
126 /**
127 Returns whether or not the checkbox is a 3-state checkbox.
3c4f71cc 128
d29a9a8a
BP
129 @return @true if this checkbox is a 3-state checkbox, @false if it's
130 a 2-state checkbox.
23324ae1 131 */
328f5751 132 bool Is3State() const;
23324ae1
FM
133
134 /**
bfac6166
BP
135 Returns whether or not the user can set the checkbox to the third
136 state.
3c4f71cc 137
d29a9a8a
BP
138 @return @true if the user can set the third state of this checkbox,
139 @false if it can only be set programmatically or if it's a
140 2-state checkbox.
23324ae1 141 */
328f5751 142 bool Is3rdStateAllowedForUser() const;
23324ae1
FM
143
144 /**
bfac6166
BP
145 This is just a maybe more readable synonym for GetValue(): just as the
146 latter, it returns @true if the checkbox is checked and @false
147 otherwise.
23324ae1 148 */
328f5751 149 bool IsChecked() const;
23324ae1
FM
150
151 /**
152 Sets the checkbox to the given state. This does not cause a
153 wxEVT_COMMAND_CHECKBOX_CLICKED event to get emitted.
3c4f71cc 154
7c913512 155 @param state
4cc4bfaf 156 If @true, the check is on, otherwise it is off.
23324ae1
FM
157 */
158 void SetValue(bool state);
bfac6166
BP
159
160 /**
161 Sets the checkbox to the given state. This does not cause a
162 wxEVT_COMMAND_CHECKBOX_CLICKED event to get emitted.
163
164 Asserts when the checkbox is a 2-state checkbox and setting the state
165 to wxCHK_UNDETERMINED.
166 */
167 void Set3StateValue(const wxCheckBoxState state);
23324ae1 168};
e54c96f1 169