X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4438caf41af49f00f3c8137ac801871f59cce386..3b59cdbfaf7df79499424c92ff6177736429ff8a:/include/wx/msw/statbmp.h diff --git a/include/wx/msw/statbmp.h b/include/wx/msw/statbmp.h index 4da9e6f89d..85308a7d13 100644 --- a/include/wx/msw/statbmp.h +++ b/include/wx/msw/statbmp.h @@ -17,6 +17,8 @@ #endif #include "wx/control.h" +#include "wx/icon.h" +#include "wx/bitmap.h" WXDLLEXPORT_DATA(extern const wxChar*) wxStaticBitmapNameStr; @@ -30,7 +32,7 @@ public: wxStaticBitmap(wxWindow *parent, wxWindowID id, - const wxBitmap& label, + const wxGDIImage& label, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, long style = 0, @@ -41,7 +43,7 @@ public: bool Create(wxWindow *parent, wxWindowID id, - const wxBitmap& label, + const wxGDIImage& label, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, long style = 0, @@ -49,15 +51,15 @@ public: virtual ~wxStaticBitmap() { Free(); } - virtual void SetIcon(const wxIcon& icon) { SetBitmap(icon); } - virtual void SetBitmap(const wxBitmap& bitmap); + void SetIcon(const wxIcon& icon) { SetImage(icon); } + void SetBitmap(const wxBitmap& bitmap) { SetImage(bitmap); } // assert failure is provoked by an attempt to get an icon from bitmap or // vice versa const wxIcon& GetIcon() const - { wxASSERT( m_isIcon ); return *m_image.icon; } + { wxASSERT( m_isIcon ); return *(wxIcon *)m_image; } const wxBitmap& GetBitmap() const - { wxASSERT( !m_isIcon ); return *m_image.bitmap; } + { wxASSERT( !m_isIcon ); return *(wxBitmap *)m_image; } // overriden base class virtuals virtual bool AcceptsFocus() const { return FALSE; } @@ -69,21 +71,19 @@ public: #endif // __WIN16__ protected: - void Init() { m_isIcon = TRUE; m_image.icon = NULL; } + virtual wxSize DoGetBestSize() const; + + void Init() { m_isIcon = TRUE; m_image = NULL; } void Free(); // TRUE if icon/bitmap is valid bool ImageIsOk() const; + void SetImage(const wxGDIImage& image); + // we can have either an icon or a bitmap bool m_isIcon; - union - { - wxIcon *icon; - wxBitmap *bitmap; - } m_image; - - virtual wxSize DoGetBestSize(); + wxGDIImage *m_image; }; #endif