#ifndef _WX_STATBMP_H_
#define _WX_STATBMP_H_
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
#pragma interface "statbmp.h"
#endif
#include "wx/icon.h"
#include "wx/bitmap.h"
-WXDLLEXPORT_DATA(extern const wxChar*) wxStaticBitmapNameStr;
+extern WXDLLEXPORT_DATA(const wxChar*) wxStaticBitmapNameStr;
// a control showing an icon or a bitmap
class WXDLLEXPORT wxStaticBitmap : public wxStaticBitmapBase
long style = 0,
const wxString& name = wxStaticBitmapNameStr)
{
+ Init();
+
Create(parent, id, label, pos, size, style, name);
}
// 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
-#ifdef __WIN16__
- virtual bool MSWOnDraw(WXDRAWITEMSTRUCT *item);
-#endif // __WIN16__
- virtual long MSWWindowProc(WXUINT nMsg, WXWPARAM wParam, WXLPARAM lParam);
+ // implementation only from now on
+ // -------------------------------
protected:
+ virtual wxBorder GetDefaultBorder() const;
virtual wxSize DoGetBestSize() const;
+ virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const;
- void Init() { m_isIcon = TRUE; m_image = NULL; }
+ // ctor/dtor helpers
+ void Init() { m_isIcon = true; m_image = NULL; }
void Free();
- // TRUE if icon/bitmap is valid
+ // true if icon/bitmap is valid
bool ImageIsOk() const;
void SetImage(const wxGDIImage* image);
+ void SetImageNoCopy( wxGDIImage* image );
// we can have either an icon or a bitmap
bool m_isIcon;
private:
DECLARE_DYNAMIC_CLASS(wxStaticBitmap)
+ DECLARE_NO_COPY_CLASS(wxStaticBitmap)
};
#endif