X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f1e01716310cb6e3bfcf5894b442d277bc32789a..f239a20092359e3c914adb79bd39f3f5d2b2e06f:/src/xrc/xh_bttn.cpp?ds=sidebyside diff --git a/src/xrc/xh_bttn.cpp b/src/xrc/xh_bttn.cpp index 397c6dbe47..963efd0848 100644 --- a/src/xrc/xh_bttn.cpp +++ b/src/xrc/xh_bttn.cpp @@ -15,7 +15,7 @@ #pragma hdrstop #endif -#if wxUSE_XRC +#if wxUSE_XRC && wxUSE_BUTTON #include "wx/xrc/xh_bttn.h" @@ -50,6 +50,38 @@ wxObject *wxButtonXmlHandler::DoCreateResource() if (GetBool(wxT("default"), 0)) button->SetDefault(); + + if ( GetParamNode("bitmap") ) + { + wxDirection dir; + const wxString dirstr = GetParamValue("direction"); + if ( dirstr.empty() || dirstr == "wxLEFT" ) + dir = wxLEFT; + else if ( dirstr == "wxRIGHT" ) + dir = wxRIGHT; + else if ( dirstr == "wxTOP" ) + dir = wxTOP; + else if ( dirstr == "wxBOTTOM" ) + dir = wxBOTTOM; + else + { + ReportError + ( + GetParamNode("bitmapposition"), + wxString::Format + ( + "Invalid bitmap position \"%s\": must be one of " + "wxLEFT|wxRIGHT|wxTOP|wxBOTTOM.", + dirstr + ) + ); + + dir = wxLEFT; + } + + button->SetBitmap(GetBitmap("bitmap", wxART_BUTTON), dir); + } + SetupWindow(button); return button; @@ -60,4 +92,4 @@ bool wxButtonXmlHandler::CanHandle(wxXmlNode *node) return IsOfClass(node, wxT("wxButton")); } -#endif // wxUSE_XRC +#endif // wxUSE_XRC && wxUSE_BUTTON