X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e9576ca53db96b462ed4c0b4bdf47d64c40203e4..c97e7fa8dbda704c9c9cdb61c22ebdf9b692e114:/src/mac/radiobut.cpp diff --git a/src/mac/radiobut.cpp b/src/mac/radiobut.cpp index 65baab38b6..1f5bb9c67a 100644 --- a/src/mac/radiobut.cpp +++ b/src/mac/radiobut.cpp @@ -2,7 +2,7 @@ // Name: radiobut.cpp // Purpose: wxRadioButton // Author: AUTHOR -// Modified by: +// Modified by: JS Lair (99/11/15) adding the cyclic groupe notion for radiobox // Created: ??/??/98 // RCS-ID: $Id$ // Copyright: (c) AUTHOR @@ -15,9 +15,14 @@ #include "wx/radiobut.h" -#if !USE_SHARED_LIBRARY + IMPLEMENT_DYNAMIC_CLASS(wxRadioButton, wxControl) -#endif + +BEGIN_EVENT_TABLE(wxRadioButton, wxControl) + EVT_IDLE( wxRadioButton::OnIdle ) +END_EVENT_TABLE() + +#include bool wxRadioButton::Create(wxWindow *parent, wxWindowID id, const wxString& label, @@ -26,43 +31,118 @@ bool wxRadioButton::Create(wxWindow *parent, wxWindowID id, const wxValidator& validator, const wxString& name) { - SetName(name); - SetValidator(validator); - - if (parent) parent->AddChild(this); + Rect bounds ; + Str255 title ; + + m_cycle=NULL; + + MacPreControlCreate( parent , id , label , pos , size ,style, validator , name , &bounds , title ) ; - if ( id == -1 ) - m_windowId = (int)NewControlId(); - else - m_windowId = id; + m_macControl = UMANewControl( parent->GetMacRootWindow() , &bounds , title , true , 0 , 0 , 1, + kControlRadioButtonProc , (long) this ) ; + + MacPostControlCreate() ; - m_windowStyle = style ; - - // TODO create radiobutton - return FALSE; + return TRUE; } -void wxRadioButton::SetLabel(const wxString& label) +void wxRadioButton::OnIdle( wxIdleEvent &event ) { - // TODO + if (!m_cycle && HasFlag(wxRB_GROUP)) + { + // we are a stand-alone radiobutton and have + // the group flag indicating we have to collect + // the other radiobuttons belonging to this one + + bool reached_this = FALSE; + wxRadioButton *m_radioButtonCycle = NULL; + m_radioButtonCycle = AddInCycle( m_radioButtonCycle ); + + wxWindow *parent = GetParent(); + wxNode *node = parent->GetChildren().First(); + while (node) + { + wxWindow *child = (wxWindow*) node->Data(); + + node = node->Next(); + + // start searching behind current radiobutton + if (!reached_this) + { + reached_this = (this == child); + continue; + } + + if (child->IsKindOf( CLASSINFO ( wxRadioButton ) )) + { + wxRadioButton *rb = (wxRadioButton*) child; + + // already reached next group + if (rb->HasFlag(wxRB_GROUP)) break; + + // part of a radiobox + if (rb->NextInCycle()) break; + + m_radioButtonCycle = rb->AddInCycle( m_radioButtonCycle ); + } + } + + } + + event.Skip( TRUE ); } -void wxRadioButton::SetValue(bool value) +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(); + } + } + } } -// Get single selection, for single choice list items bool wxRadioButton::GetValue() const { - // TODO - return FALSE; + return ::GetControlValue( m_macControl ) ; } void wxRadioButton::Command (wxCommandEvent & event) { - SetValue ( (event.m_commandInt != 0) ); + SetValue ( (event.GetInt() != 0) ); ProcessCommand (event); } +void wxRadioButton::MacHandleControlClick( ControlHandle control , SInt16 controlpart ) +{ + SetValue(true) ; + wxCommandEvent event(wxEVT_COMMAND_RADIOBUTTON_SELECTED, m_windowId ); + event.SetEventObject(this); + ProcessCommand(event); +} +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); + } +}