X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/a3bf7524f394af039efe196a186f7969cbabcc19..ac8d0c118b7403e2838e75124b442051299e6f6c:/src/msw/colour.cpp diff --git a/src/msw/colour.cpp b/src/msw/colour.cpp index e1d9ee9c2d..f18b8a5f71 100644 --- a/src/msw/colour.cpp +++ b/src/msw/colour.cpp @@ -26,18 +26,44 @@ #include #if wxUSE_EXTENDED_RTTI -IMPLEMENT_DYNAMIC_CLASS_WITH_COPY_XTI( wxColour , wxObject , "wx/colour.h" ) -WX_BEGIN_PROPERTIES_TABLE(wxColour) - WX_READONLY_PROPERTY( Red, unsigned char , Red , 0 ) - WX_READONLY_PROPERTY( Green, unsigned char , Green , 0 ) - WX_READONLY_PROPERTY( Blue, unsigned char , Blue , 0 ) -WX_END_PROPERTIES_TABLE() +template<> void wxStringReadValue(const wxString &s , wxColour &data ) +{ + // copied from VS xrc + unsigned long tmp = 0; + + if (s.Length() != 7 || s[0u] != wxT('#') || + wxSscanf(s.c_str(), wxT("#%lX"), &tmp) != 1) + { + wxLogError(_("String To Colour : Incorrect colour specification : %s"), + s.c_str() ); + data = wxNullColour; + } + else + { + data = wxColour((unsigned char) ((tmp & 0xFF0000) >> 16) , + (unsigned char) ((tmp & 0x00FF00) >> 8), + (unsigned char) ((tmp & 0x0000FF))); + } +} + +template<> void wxStringWriteValue(wxString &s , const wxColour &data ) +{ + s = wxString::Format(wxT("#%02X%02X%02X"), data.Red() , data.Green() , data.Blue() ) ; +} + +IMPLEMENT_DYNAMIC_CLASS_WITH_COPY_AND_STREAMERS_XTI( wxColour , wxObject , "wx/colour.h" , &wxToStringConverter , &wxFromStringConverter) + +wxBEGIN_PROPERTIES_TABLE(wxColour) + wxREADONLY_PROPERTY( Red, unsigned char , Red , , 0 /*flags*/ , wxT("Helpstring") , wxT("group")) + wxREADONLY_PROPERTY( Green, unsigned char , Green , , 0 /*flags*/ , wxT("Helpstring") , wxT("group")) + wxREADONLY_PROPERTY( Blue, unsigned char , Blue , , 0 /*flags*/ , wxT("Helpstring") , wxT("group")) +wxEND_PROPERTIES_TABLE() -WX_CONSTRUCTOR_3( wxColour , unsigned char , Red , unsigned char , Green , unsigned char , Blue ) +wxCONSTRUCTOR_3( wxColour , unsigned char , Red , unsigned char , Green , unsigned char , Blue ) -WX_BEGIN_HANDLERS_TABLE(wxColour) -WX_END_HANDLERS_TABLE() +wxBEGIN_HANDLERS_TABLE(wxColour) +wxEND_HANDLERS_TABLE() #else IMPLEMENT_DYNAMIC_CLASS(wxColour, wxObject) #endif