/////////////////////////////////////////////////////////////////////////////
-// Name: xh_bttn.cpp
+// Name: src/xrc/xh_bttn.cpp
// Purpose: XRC resource for buttons
// Author: Vaclav Slavik
// Created: 2000/03/05
// 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"
#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()
{
- ADD_STYLE(wxBU_LEFT);
- ADD_STYLE(wxBU_RIGHT);
- ADD_STYLE(wxBU_TOP);
- ADD_STYLE(wxBU_BOTTOM);
+ XRC_ADD_STYLE(wxBU_LEFT);
+ XRC_ADD_STYLE(wxBU_RIGHT);
+ XRC_ADD_STYLE(wxBU_TOP);
+ XRC_ADD_STYLE(wxBU_BOTTOM);
+ XRC_ADD_STYLE(wxBU_EXACTFIT);
AddWindowStyles();
}
-
wxObject *wxButtonXmlHandler::DoCreateResource()
-{
- wxButton *button = wxStaticCast(m_instance, wxButton);
-
- if (!button)
- button = new wxButton;
+{
+ XRC_MAKE_INSTANCE(button, wxButton)
button->Create(m_parentAsWindow,
GetID(),
wxDefaultValidator,
GetName());
- if (GetBool(wxT("default"), 0) == 1) button->SetDefault();
+ 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;
}
-
-
bool wxButtonXmlHandler::CanHandle(wxXmlNode *node)
{
return IsOfClass(node, wxT("wxButton"));
}
-
+#endif // wxUSE_XRC && wxUSE_BUTTON