X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6d167489bdf17d55d9bd11be834bc17277661063..ec2df34e27ba41f202ecbf096cdfed082a9ddb8f:/include/wx/msw/statbmp.h diff --git a/include/wx/msw/statbmp.h b/include/wx/msw/statbmp.h index fe255032bb..6d5802c008 100644 --- a/include/wx/msw/statbmp.h +++ b/include/wx/msw/statbmp.h @@ -1,6 +1,6 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: statbmp.h -// Purpose: wxStaticBitmap class +// Name: wx/msw/statbmp.h +// Purpose: wxStaticBitmap class for wxMSW // Author: Julian Smart // Modified by: // Created: 01/02/97 @@ -12,20 +12,15 @@ #ifndef _WX_STATBMP_H_ #define _WX_STATBMP_H_ -#ifdef __GNUG__ - #pragma interface "statbmp.h" -#endif - #include "wx/control.h" #include "wx/icon.h" +#include "wx/bitmap.h" -WXDLLEXPORT_DATA(extern const wxChar*) wxStaticBitmapNameStr; +extern WXDLLIMPEXP_DATA_CORE(const char) wxStaticBitmapNameStr[]; // a control showing an icon or a bitmap -class WXDLLEXPORT wxStaticBitmap : public wxControl +class WXDLLIMPEXP_CORE wxStaticBitmap : public wxStaticBitmapBase { - DECLARE_DYNAMIC_CLASS(wxStaticBitmap) - public: wxStaticBitmap() { Init(); } @@ -37,6 +32,8 @@ public: long style = 0, const wxString& name = wxStaticBitmapNameStr) { + Init(); + Create(parent, id, label, pos, size, style, name); } @@ -50,39 +47,48 @@ public: virtual ~wxStaticBitmap() { Free(); } - 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 *(wxIcon *)m_image; } - const wxBitmap& GetBitmap() const - { wxASSERT( !m_isIcon ); return *(wxBitmap *)m_image; } + virtual void SetIcon(const wxIcon& icon) { SetImage(&icon); } + virtual void SetBitmap(const wxBitmap& bitmap) { SetImage(&bitmap); } + virtual wxBitmap GetBitmap() const; + virtual wxIcon GetIcon() const; - // overriden base class virtuals - virtual bool AcceptsFocus() const { return FALSE; } + virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const; - // IMPLEMENTATION -#ifdef __WIN16__ - virtual bool MSWOnDraw(WXDRAWITEMSTRUCT *item); - virtual long MSWWindowProc(WXUINT nMsg, WXWPARAM wParam, WXLPARAM lParam); -#endif // __WIN16__ + // returns true if the platform should explicitly apply a theme border + virtual bool CanApplyThemeBorder() const { return false; } protected: - virtual wxSize DoGetBestSize() const; + virtual wxSize DoGetBestClientSize() const; - void Init() { m_isIcon = TRUE; m_image = NULL; } + // ctor/dtor helpers + void Init() { m_isIcon = true; m_image = NULL; m_currentHandle = 0; } void Free(); - // TRUE if icon/bitmap is valid + // true if icon/bitmap is valid bool ImageIsOk() const; - void SetImage(const wxGDIImage& image); + void SetImage(const wxGDIImage* image); + void SetImageNoCopy( wxGDIImage* image ); + +#ifndef __WXWINCE__ + // draw the bitmap ourselves here if the OS can't do it correctly (if it + // can we leave it to it) + void DoPaintManually(wxPaintEvent& event); +#endif // !__WXWINCE__ + + void WXHandleSize(wxSizeEvent& event); // we can have either an icon or a bitmap bool m_isIcon; wxGDIImage *m_image; + + // handle used in last call to STM_SETIMAGE + WXHANDLE m_currentHandle; + +private: + DECLARE_DYNAMIC_CLASS(wxStaticBitmap) + wxDECLARE_EVENT_TABLE(); + wxDECLARE_NO_COPY_CLASS(wxStaticBitmap); }; #endif