/////////////////////////////////////////////////////////////////////////////
-// Name: xh_bttn.cpp
+// Name: src/xrc/xh_bttn.cpp
// Purpose: XRC resource for buttons
// Author: Vaclav Slavik
// Created: 2000/03/05
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#ifdef __GNUG__
-#pragma implementation "xh_bttn.h"
-#endif
-
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
#pragma hdrstop
#endif
-#if wxUSE_XRC
+#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)
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;
return IsOfClass(node, wxT("wxButton"));
}
-#endif // wxUSE_XRC
+#endif // wxUSE_XRC && wxUSE_BUTTON