adding the notion of cyclic group of radiobutton
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@4627 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -43,11 +43,17 @@ class WXDLLEXPORT wxRadioButton: public wxControl
|
|||||||
const wxValidator& validator = wxDefaultValidator,
|
const wxValidator& validator = wxDefaultValidator,
|
||||||
const wxString& name = wxRadioButtonNameStr);
|
const wxString& name = wxRadioButtonNameStr);
|
||||||
|
|
||||||
virtual void SetLabel(const wxString& label);
|
|
||||||
virtual void SetValue(bool val);
|
virtual void SetValue(bool val);
|
||||||
virtual bool GetValue() const ;
|
virtual bool GetValue() const ;
|
||||||
|
|
||||||
|
virtual void MacHandleControlClick( ControlHandle control , SInt16 controlpart );
|
||||||
void Command(wxCommandEvent& event);
|
void Command(wxCommandEvent& event);
|
||||||
|
wxRadioButton *AddInCycle(wxRadioButton *cycle);
|
||||||
|
inline wxRadioButton *NextInCycle() {return m_cycle;}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
wxRadioButton *m_cycle;
|
||||||
};
|
};
|
||||||
|
|
||||||
// Not implemented
|
// Not implemented
|
||||||
|
@@ -2,7 +2,7 @@
|
|||||||
// Name: radiobut.cpp
|
// Name: radiobut.cpp
|
||||||
// Purpose: wxRadioButton
|
// Purpose: wxRadioButton
|
||||||
// Author: AUTHOR
|
// Author: AUTHOR
|
||||||
// Modified by:
|
// Modified by: JS Lair (99/11/15) adding the cyclic groupe notion for radiobox
|
||||||
// Created: ??/??/98
|
// Created: ??/??/98
|
||||||
// RCS-ID: $Id$
|
// RCS-ID: $Id$
|
||||||
// Copyright: (c) AUTHOR
|
// Copyright: (c) AUTHOR
|
||||||
@@ -19,6 +19,8 @@
|
|||||||
IMPLEMENT_DYNAMIC_CLASS(wxRadioButton, wxControl)
|
IMPLEMENT_DYNAMIC_CLASS(wxRadioButton, wxControl)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <wx/mac/uma.h>
|
||||||
|
|
||||||
bool wxRadioButton::Create(wxWindow *parent, wxWindowID id,
|
bool wxRadioButton::Create(wxWindow *parent, wxWindowID id,
|
||||||
const wxString& label,
|
const wxString& label,
|
||||||
const wxPoint& pos,
|
const wxPoint& pos,
|
||||||
@@ -26,43 +28,69 @@ bool wxRadioButton::Create(wxWindow *parent, wxWindowID id,
|
|||||||
const wxValidator& validator,
|
const wxValidator& validator,
|
||||||
const wxString& name)
|
const wxString& name)
|
||||||
{
|
{
|
||||||
SetName(name);
|
Rect bounds ;
|
||||||
SetValidator(validator);
|
Str255 title ;
|
||||||
|
|
||||||
if (parent) parent->AddChild(this);
|
m_cycle=NULL;
|
||||||
|
|
||||||
if ( id == -1 )
|
MacPreControlCreate( parent , id , label , pos , size ,style, validator , name , &bounds , title ) ;
|
||||||
m_windowId = (int)NewControlId();
|
|
||||||
else
|
|
||||||
m_windowId = id;
|
|
||||||
|
|
||||||
m_windowStyle = style ;
|
m_macControl = UMANewControl( parent->GetMacRootWindow() , &bounds , title , true , 0 , 0 , 1,
|
||||||
|
kControlRadioButtonProc , (long) this ) ;
|
||||||
|
|
||||||
// TODO create radiobutton
|
MacPostControlCreate() ;
|
||||||
return FALSE;
|
|
||||||
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxRadioButton::SetLabel(const wxString& label)
|
void wxRadioButton::SetValue(bool val)
|
||||||
{
|
{
|
||||||
// TODO
|
int i;
|
||||||
|
wxRadioButton *cycle;
|
||||||
|
|
||||||
|
::SetControlValue( m_macControl , val ) ;
|
||||||
|
|
||||||
|
if (val) {
|
||||||
|
cycle=this->NextInCycle();
|
||||||
|
if (cycle!=NULL) {
|
||||||
|
while (cycle!=this) {
|
||||||
|
cycle->SetValue(false);
|
||||||
|
cycle=cycle->NextInCycle();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxRadioButton::SetValue(bool value)
|
|
||||||
{
|
|
||||||
// TODO
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get single selection, for single choice list items
|
|
||||||
bool wxRadioButton::GetValue() const
|
bool wxRadioButton::GetValue() const
|
||||||
{
|
{
|
||||||
// TODO
|
return ::GetControlValue( m_macControl ) ;
|
||||||
return FALSE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxRadioButton::Command (wxCommandEvent & event)
|
void wxRadioButton::Command (wxCommandEvent & event)
|
||||||
{
|
{
|
||||||
SetValue ( (event.m_commandInt != 0) );
|
SetValue ( (event.GetInt() != 0) );
|
||||||
ProcessCommand (event);
|
ProcessCommand (event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxRadioButton::MacHandleControlClick( ControlHandle control , SInt16 controlpart )
|
||||||
|
{
|
||||||
|
SetValue(true) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxRadioButton *wxRadioButton::AddInCycle(wxRadioButton *cycle)
|
||||||
|
{
|
||||||
|
wxRadioButton *next,*current;
|
||||||
|
|
||||||
|
if (cycle==NULL) {
|
||||||
|
m_cycle=this;
|
||||||
|
return(this);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
current=cycle;
|
||||||
|
while ((next=current->m_cycle)!=cycle) current=current->m_cycle;
|
||||||
|
m_cycle=cycle;
|
||||||
|
current->m_cycle=this;
|
||||||
|
return(cycle);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -2,7 +2,7 @@
|
|||||||
// Name: radiobut.cpp
|
// Name: radiobut.cpp
|
||||||
// Purpose: wxRadioButton
|
// Purpose: wxRadioButton
|
||||||
// Author: AUTHOR
|
// Author: AUTHOR
|
||||||
// Modified by:
|
// Modified by: JS Lair (99/11/15) adding the cyclic groupe notion for radiobox
|
||||||
// Created: ??/??/98
|
// Created: ??/??/98
|
||||||
// RCS-ID: $Id$
|
// RCS-ID: $Id$
|
||||||
// Copyright: (c) AUTHOR
|
// Copyright: (c) AUTHOR
|
||||||
@@ -19,6 +19,8 @@
|
|||||||
IMPLEMENT_DYNAMIC_CLASS(wxRadioButton, wxControl)
|
IMPLEMENT_DYNAMIC_CLASS(wxRadioButton, wxControl)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <wx/mac/uma.h>
|
||||||
|
|
||||||
bool wxRadioButton::Create(wxWindow *parent, wxWindowID id,
|
bool wxRadioButton::Create(wxWindow *parent, wxWindowID id,
|
||||||
const wxString& label,
|
const wxString& label,
|
||||||
const wxPoint& pos,
|
const wxPoint& pos,
|
||||||
@@ -26,43 +28,69 @@ bool wxRadioButton::Create(wxWindow *parent, wxWindowID id,
|
|||||||
const wxValidator& validator,
|
const wxValidator& validator,
|
||||||
const wxString& name)
|
const wxString& name)
|
||||||
{
|
{
|
||||||
SetName(name);
|
Rect bounds ;
|
||||||
SetValidator(validator);
|
Str255 title ;
|
||||||
|
|
||||||
if (parent) parent->AddChild(this);
|
m_cycle=NULL;
|
||||||
|
|
||||||
if ( id == -1 )
|
MacPreControlCreate( parent , id , label , pos , size ,style, validator , name , &bounds , title ) ;
|
||||||
m_windowId = (int)NewControlId();
|
|
||||||
else
|
|
||||||
m_windowId = id;
|
|
||||||
|
|
||||||
m_windowStyle = style ;
|
m_macControl = UMANewControl( parent->GetMacRootWindow() , &bounds , title , true , 0 , 0 , 1,
|
||||||
|
kControlRadioButtonProc , (long) this ) ;
|
||||||
|
|
||||||
// TODO create radiobutton
|
MacPostControlCreate() ;
|
||||||
return FALSE;
|
|
||||||
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxRadioButton::SetLabel(const wxString& label)
|
void wxRadioButton::SetValue(bool val)
|
||||||
{
|
{
|
||||||
// TODO
|
int i;
|
||||||
|
wxRadioButton *cycle;
|
||||||
|
|
||||||
|
::SetControlValue( m_macControl , val ) ;
|
||||||
|
|
||||||
|
if (val) {
|
||||||
|
cycle=this->NextInCycle();
|
||||||
|
if (cycle!=NULL) {
|
||||||
|
while (cycle!=this) {
|
||||||
|
cycle->SetValue(false);
|
||||||
|
cycle=cycle->NextInCycle();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxRadioButton::SetValue(bool value)
|
|
||||||
{
|
|
||||||
// TODO
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get single selection, for single choice list items
|
|
||||||
bool wxRadioButton::GetValue() const
|
bool wxRadioButton::GetValue() const
|
||||||
{
|
{
|
||||||
// TODO
|
return ::GetControlValue( m_macControl ) ;
|
||||||
return FALSE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxRadioButton::Command (wxCommandEvent & event)
|
void wxRadioButton::Command (wxCommandEvent & event)
|
||||||
{
|
{
|
||||||
SetValue ( (event.m_commandInt != 0) );
|
SetValue ( (event.GetInt() != 0) );
|
||||||
ProcessCommand (event);
|
ProcessCommand (event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxRadioButton::MacHandleControlClick( ControlHandle control , SInt16 controlpart )
|
||||||
|
{
|
||||||
|
SetValue(true) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxRadioButton *wxRadioButton::AddInCycle(wxRadioButton *cycle)
|
||||||
|
{
|
||||||
|
wxRadioButton *next,*current;
|
||||||
|
|
||||||
|
if (cycle==NULL) {
|
||||||
|
m_cycle=this;
|
||||||
|
return(this);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
current=cycle;
|
||||||
|
while ((next=current->m_cycle)!=cycle) current=current->m_cycle;
|
||||||
|
m_cycle=cycle;
|
||||||
|
current->m_cycle=this;
|
||||||
|
return(cycle);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user