2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: radiobut.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxRadioButton
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxRadioButton
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-05-04 09:04:38 +00:00
|
|
|
A radio button item is a button which usually denotes one of several
|
|
|
|
mutually exclusive options. It has a text label next to a (usually) round
|
|
|
|
button.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-05-04 09:04:38 +00:00
|
|
|
You can create a group of mutually-exclusive radio buttons by specifying
|
|
|
|
@c wxRB_GROUP for the first in the group. The group ends when another
|
|
|
|
radio button group is created, or there are no more radio buttons.
|
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{wxRB_GROUP}
|
2008-03-08 13:52:38 +00:00
|
|
|
Marks the beginning of a new group of radio buttons.
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxRB_SINGLE}
|
2008-03-08 13:52:38 +00:00
|
|
|
In some circumstances, radio buttons that are not consecutive
|
|
|
|
siblings trigger a hang bug in Windows (only). If this happens, add
|
|
|
|
this style to mark the button as not belonging to a group, and
|
|
|
|
implement the mutually-exclusive group behaviour yourself.
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxRB_USE_CHECKBOX}
|
2008-03-08 13:52:38 +00:00
|
|
|
Use a checkbox button instead of radio button (currently supported
|
|
|
|
only on PalmOS).
|
|
|
|
@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_RADIOBUTTON(id, func)}
|
2008-05-04 09:04:38 +00:00
|
|
|
Process a @c wxEVT_COMMAND_RADIOBUTTON_SELECTED event, when the
|
2008-03-08 13:52:38 +00:00
|
|
|
radiobutton 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{radiobutton.png}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2009-02-18 00:19:22 +00:00
|
|
|
@see @ref overview_events, wxRadioBox, wxCheckBox
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxRadioButton : public wxControl
|
|
|
|
{
|
|
|
|
public:
|
2008-05-04 09:04:38 +00:00
|
|
|
/**
|
|
|
|
Default constructor.
|
|
|
|
|
|
|
|
@see Create(), wxValidator
|
|
|
|
*/
|
|
|
|
wxRadioButton();
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
Constructor, creating and showing a radio button.
|
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-05-04 09:04:38 +00:00
|
|
|
Window identifier. The value @c wxID_ANY indicates a default value.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param label
|
2008-03-09 12:33:59 +00:00
|
|
|
Label for the radio button.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param pos
|
2009-03-14 00:49:24 +00:00
|
|
|
Window position. If ::wxDefaultPosition is specified then a default
|
|
|
|
position is chosen.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param size
|
2009-03-14 00:49:24 +00:00
|
|
|
Window 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 wxRadioButton.
|
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
|
|
|
wxRadioButton(wxWindow* parent, wxWindowID id,
|
|
|
|
const wxString& label,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = 0,
|
|
|
|
const wxValidator& validator = wxDefaultValidator,
|
2008-11-13 21:32:53 +00:00
|
|
|
const wxString& name = wxRadioButtonNameStr);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor, destroying the radio button item.
|
|
|
|
*/
|
2008-09-27 11:21:10 +00:00
|
|
|
virtual ~wxRadioButton();
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Creates the choice for two-step construction. See wxRadioButton() for
|
|
|
|
further details.
|
|
|
|
*/
|
2008-10-28 15:36:26 +00:00
|
|
|
bool Create(wxWindow* parent, wxWindowID id, const wxString& label,
|
2008-03-08 13:52:38 +00:00
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
2008-10-28 15:36:26 +00:00
|
|
|
const wxSize& size = wxDefaultSize, long style = 0,
|
2008-03-08 13:52:38 +00:00
|
|
|
const wxValidator& validator = wxDefaultValidator,
|
2008-10-28 15:36:26 +00:00
|
|
|
const wxString& name = wxRadioButtonNameStr);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if the radio button is depressed, @false otherwise.
|
|
|
|
*/
|
2008-09-27 11:21:10 +00:00
|
|
|
virtual bool GetValue() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the radio button to selected or deselected status. This does not cause a
|
2008-05-04 09:04:38 +00:00
|
|
|
@c wxEVT_COMMAND_RADIOBUTTON_SELECTED event to get emitted.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 14:43:31 +00:00
|
|
|
@param value
|
2008-03-09 12:33:59 +00:00
|
|
|
@true to select, @false to deselect.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-10-28 15:36:26 +00:00
|
|
|
virtual void SetValue(bool value);
|
2008-03-08 13:52:38 +00:00
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|