X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/27ce9aef53de32179153fbfbbdd9d52720d165e8..f23b8c0d859cf01e91ed38a9f8b79c2ebc534f47:/src/xrc/xh_bttn.cpp diff --git a/src/xrc/xh_bttn.cpp b/src/xrc/xh_bttn.cpp index 5ed5ee88db..963efd0848 100644 --- a/src/xrc/xh_bttn.cpp +++ b/src/xrc/xh_bttn.cpp @@ -1,5 +1,5 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: xh_bttn.cpp +// Name: src/xrc/xh_bttn.cpp // Purpose: XRC resource for buttons // Author: Vaclav Slavik // Created: 2000/03/05 @@ -7,10 +7,6 @@ // Copyright: (c) 2000 Vaclav Slavik // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// - -#ifdef __GNUG__ -#pragma implementation "xh_bttn.h" -#endif // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" @@ -19,13 +15,18 @@ #pragma hdrstop #endif +#if wxUSE_XRC && wxUSE_BUTTON + #include "wx/xrc/xh_bttn.h" -#include "wx/button.h" + +#ifndef WX_PRECOMP + #include "wx/button.h" +#endif IMPLEMENT_DYNAMIC_CLASS(wxButtonXmlHandler, wxXmlResourceHandler) -wxButtonXmlHandler::wxButtonXmlHandler() -: wxXmlResourceHandler() +wxButtonXmlHandler::wxButtonXmlHandler() +: wxXmlResourceHandler() { XRC_ADD_STYLE(wxBU_LEFT); XRC_ADD_STYLE(wxBU_RIGHT); @@ -36,7 +37,7 @@ wxButtonXmlHandler::wxButtonXmlHandler() } wxObject *wxButtonXmlHandler::DoCreateResource() -{ +{ XRC_MAKE_INSTANCE(button, wxButton) button->Create(m_parentAsWindow, @@ -49,8 +50,40 @@ 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; } @@ -58,3 +91,5 @@ bool wxButtonXmlHandler::CanHandle(wxXmlNode *node) { return IsOfClass(node, wxT("wxButton")); } + +#endif // wxUSE_XRC && wxUSE_BUTTON