X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7205570233ce8420b71fa5df368054c8953ff0e4..94311eef78b66304c9a2f78bcbdd396c798f19a6:/src/mac/radiobox.cpp diff --git a/src/mac/radiobox.cpp b/src/mac/radiobox.cpp index f4c7ca1509..5c1938736c 100644 --- a/src/mac/radiobox.cpp +++ b/src/mac/radiobox.cpp @@ -9,15 +9,15 @@ // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -//------------------------------------------------------------------------------------- -// headers -//------------------------------------------------------------------------------------- - #ifdef __GNUG__ #pragma implementation "radioboxbase.h" #pragma implementation "radiobox.h" #endif +//------------------------------------------------------------------------------------- +// headers +//------------------------------------------------------------------------------------- + #include "wx/defs.h" #include "wx/radiobox.h" @@ -112,27 +112,27 @@ bool wxRadioBox::Create(wxWindow *parent, wxWindowID id, const wxString& label, m_majorDim = majorDim ; - Rect bounds ; - Str255 title ; - - MacPreControlCreate( parent , id , label , pos , size ,style, val , name , &bounds , title ) ; - - m_macControl = ::NewControl( parent->GetMacRootWindow() , &bounds , title , false , 0 , 0 , 1, - kControlGroupBoxTextTitleProc , (long) this ) ; - + Rect bounds ; + Str255 title ; + + MacPreControlCreate( parent , id , wxStripMenuCodes(label) , pos , size ,style, val , name , &bounds , title ) ; + + m_macControl = ::NewControl( MAC_WXHWND(parent->MacGetRootWindow()) , &bounds , title , false , 0 , 0 , 1, + kControlGroupBoxTextTitleProc , (long) this ) ; + for (i = 0; i < n; i++) { - wxRadioButton *radBtn = new wxRadioButton(this, NewControlId(),choices[i],wxPoint(5,20*i+10), - wxDefaultSize , i == 0 ? wxRB_GROUP : 0 ) ; + wxRadioButton *radBtn = new wxRadioButton(this, NewControlId(), wxStripMenuCodes(choices[i]),wxPoint(5,20*i+10), + wxDefaultSize , i == 0 ? wxRB_GROUP : 0 ) ; if ( i == 0 ) m_radioButtonCycle = radBtn ; // m_radioButtonCycle=radBtn->AddInCycle(m_radioButtonCycle); } - SetSelection(0); - MacPostControlCreate() ; + SetSelection(0); + MacPostControlCreate() ; - return TRUE; + return TRUE; } @@ -146,18 +146,18 @@ bool wxRadioBox::Create(wxWindow *parent, wxWindowID id, const wxString& label, bool wxRadioBox::Enable(bool enable) { - int i; + int i; wxRadioButton *current; if (!wxControl::Enable(enable)) - return (false); - - current=m_radioButtonCycle; - for (i=0;iEnable(enable); - current=current->NextInCycle(); - } - return (true); + current = current->NextInCycle(); + } + return true; } //------------------------------------------------------------------------------------- @@ -167,17 +167,19 @@ bool wxRadioBox::Enable(bool enable) void wxRadioBox::Enable(int item, bool enable) { - int i; + int i; wxRadioButton *current; if ((item < 0) || (item >= m_noItems)) return; - i=0; - current=m_radioButtonCycle; - while (i!=item) { + + i = 0; + current = m_radioButtonCycle; + while (i != item) { i++; - current=current->NextInCycle(); - } + current = current->NextInCycle(); + } + current->Enable(enable); } //------------------------------------------------------------------------------------- @@ -197,17 +199,18 @@ wxString wxRadioBox::GetLabel() const wxString wxRadioBox::GetString(int item) const { - int i; + int i; wxRadioButton *current; if ((item < 0) || (item >= m_noItems)) return wxString(""); - i=0; - current=m_radioButtonCycle; - while (i!=item) { + + i = 0; + current = m_radioButtonCycle; + while (i != item) { i++; - current=current->NextInCycle(); - } + current = current->NextInCycle(); + } return current->GetLabel(); } @@ -493,6 +496,7 @@ wxSize wxRadioBox::DoGetBestSize() const maxWidth = -1; maxHeight = -1; + for (int i = 0 ; i < m_noItems; i++) { GetTextExtent(GetString(i), &eachWidth, &eachHeight); @@ -504,6 +508,13 @@ wxSize wxRadioBox::DoGetBestSize() const totHeight = GetRowCount() * (maxHeight + charHeight/2) + charHeight * 3/2; totWidth = GetColumnCount() * (maxWidth + charWidth) + charWidth; + + // handle radio box title as well + GetTextExtent(GetTitle(), &eachWidth, NULL); + eachWidth = (int)(eachWidth + RADIO_SIZE) + 3 * charWidth ; + if (totWidth < eachWidth) + totWidth = eachWidth; + return wxSize(totWidth, totHeight); } //-------------------------------------------------------------------------------------