#include "wx/image.h"
#endif // WX_PRECOMP
+#if wxUSE_IMAGE && wxUSE_LIBPNG && wxUSE_STREAMS
+ #define wxHAS_PNG_LOAD
+
+ #include "wx/mstream.h"
+#endif
+
// ----------------------------------------------------------------------------
// wxVariant support
// ----------------------------------------------------------------------------
IMPLEMENT_VARIANT_OBJECT_EXPORTED_SHALLOWCMP(wxIcon,WXDLLEXPORT)
#endif
+#if wxUSE_EXTENDED_RTTI
+//WX_IMPLEMENT_ANY_VALUE_TYPE(wxAnyValueTypeImpl<wxBitmap>)
+//WX_IMPLEMENT_ANY_VALUE_TYPE(wxAnyValueTypeImpl<wxIcon>)
+#endif
+
+// ----------------------------------------------------------------------------
+// wxBitmapHelpers
+// ----------------------------------------------------------------------------
+
+// wxOSX has a native version and doesn't use this one.
+
+#ifndef __WXOSX__
+
+/* static */
+wxBitmap wxBitmapHelpers::NewFromPNGData(const void* data, size_t size)
+{
+ wxBitmap bitmap;
+
+#ifdef wxHAS_PNG_LOAD
+ wxMemoryInputStream is(data, size);
+ wxImage image(is, wxBITMAP_TYPE_PNG);
+ if ( image.IsOk() )
+ bitmap = wxBitmap(image);
+#endif // wxHAS_PNG_LOAD
+
+ return bitmap;
+}
+
+#endif // !__WXOSX__
+
// ----------------------------------------------------------------------------
// wxBitmapBase
// ----------------------------------------------------------------------------
void OnExit() { wxBitmap::CleanUpHandlers(); }
};
-wxBitmap wxBitmapBase::ConvertToDisabled(unsigned char brightness) const
-{
- wxBitmap bmp;
-#if wxUSE_IMAGE
- wxImage image = ConvertToImage();
- bmp = wxBitmap(image.ConvertToDisabled(brightness));
-#endif
- return bmp;
-}
-
IMPLEMENT_DYNAMIC_CLASS(wxBitmapBaseModule, wxModule)
#endif // wxUSE_BITMAP_BASE
#if wxUSE_IMAGE && wxUSE_XPM
wxImage image(bits);
- wxCHECK2_MSG(image.Ok(), return, wxT("invalid bitmap data"));
+ wxCHECK2_MSG(image.IsOk(), return, wxT("invalid bitmap data"));
*this = wxBitmap(image);
#else