X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/1e6feb95a79834836e88143b15d9f424ebe79621..4bf45c9ecafa14b167ef0c911a83cd5cc8fba4d2:/include/wx/msw/statbmp.h diff --git a/include/wx/msw/statbmp.h b/include/wx/msw/statbmp.h index 31dbb6c88f..e778d2e373 100644 --- a/include/wx/msw/statbmp.h +++ b/include/wx/msw/statbmp.h @@ -12,7 +12,7 @@ #ifndef _WX_STATBMP_H_ #define _WX_STATBMP_H_ -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma interface "statbmp.h" #endif @@ -36,6 +36,8 @@ public: long style = 0, const wxString& name = wxStaticBitmapNameStr) { + Init(); + Create(parent, id, label, pos, size, style, name); } @@ -55,19 +57,31 @@ public: // assert failure is provoked by an attempt to get an icon from bitmap or // vice versa wxIcon GetIcon() const - { wxASSERT( m_isIcon ); return *(wxIcon *)m_image; } + { + wxASSERT_MSG( m_isIcon, _T("no icon in this wxStaticBitmap") ); + + return *(wxIcon *)m_image; + } + wxBitmap GetBitmap() const - { wxASSERT( !m_isIcon ); return *(wxBitmap *)m_image; } + { + wxASSERT_MSG( !m_isIcon, _T("no bitmap in this wxStaticBitmap") ); + + return *(wxBitmap *)m_image; + } + + // implementation only from now on + // ------------------------------- - // IMPLEMENTATION -#ifdef __WIN16__ - virtual bool MSWOnDraw(WXDRAWITEMSTRUCT *item); -#endif // __WIN16__ - virtual long MSWWindowProc(WXUINT nMsg, WXWPARAM wParam, WXLPARAM lParam); + // implement base class virtuals + virtual WXLRESULT MSWWindowProc(WXUINT nMsg, WXWPARAM wParam, WXLPARAM lParam); protected: + virtual wxBorder GetDefaultBorder() const; virtual wxSize DoGetBestSize() const; + virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const; + // ctor/dtor helpers void Init() { m_isIcon = TRUE; m_image = NULL; } void Free(); @@ -75,6 +89,7 @@ protected: bool ImageIsOk() const; void SetImage(const wxGDIImage* image); + void SetImageNoCopy( wxGDIImage* image ); // we can have either an icon or a bitmap bool m_isIcon; @@ -82,6 +97,7 @@ protected: private: DECLARE_DYNAMIC_CLASS(wxStaticBitmap) + DECLARE_NO_COPY_CLASS(wxStaticBitmap) }; #endif