// Modified by:
// Created: 11.09.00
// RCS-ID: $Id$
-// Copyright: (c) 2000 Vadim Zeitlin
-// Licence: wxWindows license
+// Copyright: (c) 2000 SciTech Software, Inc. (www.scitechsoft.com)
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
// ============================================================================
// headers
// ----------------------------------------------------------------------------
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
#pragma implementation "univradiobox.h"
#endif
#include "wx/radiobox.h"
#include "wx/radiobut.h"
#include "wx/validate.h"
+ #include "wx/arrstr.h"
#endif
+#include "wx/tooltip.h"
+
#include "wx/univ/theme.h"
#include "wx/univ/renderer.h"
#include "wx/univ/inphand.h"
m_majorDim = 0;
}
+wxRadioBox::wxRadioBox(wxWindow *parent, wxWindowID id, const wxString& title,
+ const wxPoint& pos, const wxSize& size,
+ const wxArrayString& choices,
+ int majorDim, long style,
+ const wxValidator& val, const wxString& name)
+{
+ wxCArrayString chs(choices);
+
+ Init();
+
+ (void)Create(parent, id, title, pos, size, chs.GetCount(),
+ chs.GetStrings(), majorDim, style, val, name);
+}
+
+bool wxRadioBox::Create(wxWindow *parent,
+ wxWindowID id,
+ const wxString& title,
+ const wxPoint& pos,
+ const wxSize& size,
+ const wxArrayString& choices,
+ int majorDim,
+ long style,
+ const wxValidator& val,
+ const wxString& name)
+{
+ wxCArrayString chs(choices);
+
+ return Create(parent, id, title, pos, size, chs.GetCount(),
+ chs.GetStrings(), majorDim, style, val, name);
+}
+
bool wxRadioBox::Create(wxWindow *parent,
wxWindowID id,
const wxString& title,
SetClientSize(DoGetBestClientSize());
}
+ // Need to move the radiobox in order to move the radio buttons
+ wxPoint actualPos = GetPosition();
+ wxSize actualSize = GetSize();
+ DoMoveWindow(actualPos.x, actualPos.y, actualSize.x, actualSize.y);
+
// radiobox should already have selection so select at least one item
SetSelection(0);
bool wxRadioBox::Enable(bool enable)
{
- return wxStaticBox::Enable(enable);
+ if ( !wxStaticBox::Enable(enable) )
+ return FALSE;
+
+ // also enable/disable the buttons
+ size_t count = m_buttons.GetCount();
+ for ( size_t n = 0; n < count; n++ )
+ {
+ Enable(n, enable);
+ }
+
+ return TRUE;
}
bool wxRadioBox::Show(bool show)
{
- return wxStaticBox::Show(show);
+ if ( !wxStaticBox::Show(show) )
+ return FALSE;
+
+ // also show/hide the buttons
+ size_t count = m_buttons.GetCount();
+ for ( size_t n = 0; n < count; n++ )
+ {
+ Show(n, show);
+ }
+
+ return TRUE;
}
wxString wxRadioBox::GetLabel() const
wxStaticBox::SetLabel(label);
}
+#if wxUSE_TOOLTIPS
+void wxRadioBox::DoSetToolTip(wxToolTip *tooltip)
+{
+ wxControl::DoSetToolTip(tooltip);
+
+ // Also set them for all Radio Buttons
+ size_t count = m_buttons.GetCount();
+ for ( size_t n = 0; n < count; n++ )
+ {
+ if (tooltip)
+ m_buttons[n]->SetToolTip(tooltip->GetTip());
+ else
+ m_buttons[n]->SetToolTip(NULL);
+ }
+}
+#endif // wxUSE_TOOLTIPS
+
// ----------------------------------------------------------------------------
// buttons positioning
// ----------------------------------------------------------------------------
wxSize sizeBtn = GetMaxButtonSize();
wxPoint ptOrigin = GetBoxAreaOrigin();
+ wxPoint clientOrigin = GetParent() ? GetParent()->GetClientAreaOrigin() : wxPoint(0,0);
- x0 += ptOrigin.x + BOX_BORDER_X;
- y0 += ptOrigin.y + BOX_BORDER_Y;
+ x0 += ptOrigin.x + BOX_BORDER_X - clientOrigin.x;
+ y0 += ptOrigin.y + BOX_BORDER_Y - clientOrigin.y;
int x = x0,
y = y0;