X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/cc11cc69186f64a7729cd3b5a892dd487b9f6f0c..07aaf32633ecf18ec3edfbb41793a112914792d0:/src/xrc/xh_radbx.cpp?ds=sidebyside diff --git a/src/xrc/xh_radbx.cpp b/src/xrc/xh_radbx.cpp index edbbbf6a49..921938f540 100644 --- a/src/xrc/xh_radbx.cpp +++ b/src/xrc/xh_radbx.cpp @@ -24,6 +24,8 @@ #include "wx/radiobox.h" #endif +#include "wx/xml/xml.h" + IMPLEMENT_DYNAMIC_CLASS(wxRadioBoxXmlHandler, wxXmlResourceHandler) wxRadioBoxXmlHandler::wxRadioBoxXmlHandler() @@ -47,70 +49,92 @@ wxObject *wxRadioBoxXmlHandler::DoCreateResource() m_insideBox = true; CreateChildrenPrivately( NULL, GetParamNode(wxT("content"))); - wxString *strings; - if ( !labels.empty() ) - { - strings = new wxString[labels.size()]; - const unsigned count = labels.size(); - for( unsigned i = 0; i < count; i++ ) - strings[i] = labels[i]; - } - else - { - strings = NULL; - } - XRC_MAKE_INSTANCE(control, wxRadioBox) control->Create(m_parentAsWindow, GetID(), GetText(wxT("label")), GetPosition(), GetSize(), - labels.size(), - strings, + m_labels, GetLong(wxT("dimension"), 1), GetStyle(), wxDefaultValidator, GetName()); - delete[] strings; - if (selection != -1) control->SetSelection(selection); SetupWindow(control); -#if wxUSE_TOOLTIPS - const unsigned count = labels.size(); + const unsigned count = m_labels.size(); for( unsigned i = 0; i < count; i++ ) { - if ( !tooltips[i].empty() ) - control->SetItemToolTip(i, tooltips[i]); +#if wxUSE_TOOLTIPS + if ( !m_tooltips[i].empty() ) + control->SetItemToolTip(i, m_tooltips[i]); +#endif // wxUSE_TOOLTIPS +#if wxUSE_HELP + if ( m_helptextSpecified[i] ) + control->SetItemHelpText(i, m_helptexts[i]); +#endif // wxUSE_HELP + + if ( !m_isShown[i] ) + control->Show(i, false); + if ( !m_isEnabled[i] ) + control->Enable(i, false); } + + + // forget information about the items of this radiobox, we should start + // afresh for the next one + m_labels.clear(); + +#if wxUSE_TOOLTIPS + m_tooltips.clear(); #endif // wxUSE_TOOLTIPS - labels.clear(); // dump the strings - tooltips.clear(); // dump the tooltips +#if wxUSE_HELP + m_helptexts.clear(); + m_helptextSpecified.clear(); +#endif // wxUSE_HELP + + m_isShown.clear(); + m_isEnabled.clear(); return control; } else // inside the radiobox element { - // we handle Label constructs here + // we handle handle Label constructs here, and the item + // tag can have tooltip, helptext, enabled and hidden attributes + + wxString label = GetNodeContent(m_node); - wxString str = GetNodeContent(m_node); wxString tooltip; - m_node->GetPropVal(wxT("tooltip"), &tooltip); + m_node->GetAttribute(wxT("tooltip"), &tooltip); + + wxString helptext; + bool hasHelptext = m_node->GetAttribute(wxT("helptext"), &helptext); if (m_resource->GetFlags() & wxXRC_USE_LOCALE) { - str = wxGetTranslation(str); + label = wxGetTranslation(label, m_resource->GetDomain()); if ( !tooltip.empty() ) - tooltip = wxGetTranslation(tooltip); + tooltip = wxGetTranslation(tooltip, m_resource->GetDomain()); + if ( hasHelptext ) + helptext = wxGetTranslation(helptext, m_resource->GetDomain()); } - labels.push_back(str); - tooltips.push_back(tooltip); + m_labels.push_back(label); +#if wxUSE_TOOLTIPS + m_tooltips.push_back(tooltip); +#endif // wxUSE_TOOLTIPS +#if wxUSE_HELP + m_helptexts.push_back(helptext); + m_helptextSpecified.push_back(hasHelptext); +#endif // wxUSE_HELP + m_isEnabled.push_back(GetBoolAttr("enabled", 1)); + m_isShown.push_back(!GetBoolAttr("hidden", 0)); return NULL; }