X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/79c093419e9f7e15ac1293ef0c35eaf35ee2345a..438959cca892a7651634cc3a7aad4819ac49b23c:/include/wx/os2/icon.h diff --git a/include/wx/os2/icon.h b/include/wx/os2/icon.h index 035506f8c7..83cef7afa1 100644 --- a/include/wx/os2/icon.h +++ b/include/wx/os2/icon.h @@ -1,5 +1,5 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: icon.h +// Name: wx/os2/icon.h // Purpose: wxIcon class // Author: David Webster // Modified by: @@ -16,28 +16,16 @@ // headers // ---------------------------------------------------------------------------- -// compatible (even if incorrect) behaviour by default: derive wxIcon from -// wxBitmap -#ifndef wxICON_IS_BITMAP - #define wxICON_IS_BITMAP 1 -#endif - #include "wx/bitmap.h" -#if wxICON_IS_BITMAP +#include "wx/os2/gdiimage.h" - #define wxIconRefDataBase wxBitmapRefData - #define wxIconBase wxBitmap -#else - #include "wx/os2/gdiimage.h" +#define wxIconRefDataBase wxGDIImageRefData +#define wxIconBase wxGDIImage - #define wxIconRefDataBase wxGDIImageRefData - #define wxIconBase wxGDIImage -#endif - -class WXDLLEXPORT wxIconRefData: public wxIconRefDataBase +class WXDLLIMPEXP_CORE wxIconRefData: public wxIconRefDataBase { public: - wxIconRefData() { }; + wxIconRefData() { } virtual ~wxIconRefData() { Free(); } virtual void Free(); @@ -47,45 +35,42 @@ public: // Icon // --------------------------------------------------------------------------- -class WXDLLEXPORT wxIcon: public wxIconBase +class WXDLLIMPEXP_CORE wxIcon: public wxIconBase { public: wxIcon(); - // Copy constructors - inline wxIcon(const wxIcon& icon) { Ref(icon); } - wxIcon( const char bits[] ,int nWidth ,int nHeight ); - inline wxIcon(const char** ppData) { CreateIconFromXpm(ppData); } - inline wxIcon(char** ppData) { CreateIconFromXpm((const char**)ppData); } + wxIcon(const char* const* ppData) { CreateIconFromXpm(ppData); } +#ifdef wxNEEDS_CHARPP + wxIcon(char** ppData) { CreateIconFromXpm(const_cast(ppData)); } +#endif wxIcon( const wxString& rName - ,long lFlags = wxBITMAP_TYPE_ICO_RESOURCE + ,wxBitmapType lFlags = wxICON_DEFAULT_TYPE ,int nDesiredWidth = -1 ,int nDesiredHeight = -1 ); - ~wxIcon(); + wxIcon(const wxIconLocation& loc) + { + LoadFile(loc.GetFileName(), wxBITMAP_TYPE_ICO); + } + + virtual ~wxIcon(); bool LoadFile( const wxString& rName - ,long lFlags = wxBITMAP_TYPE_ICO_RESOURCE + ,wxBitmapType lFlags = wxICON_DEFAULT_TYPE ,int nDesiredWidth = -1 ,int nDesiredHeight = -1 ); - inline wxIcon& operator = (const wxIcon& rIcon) - { if (*this != rIcon) Ref(rIcon); return *this; } - inline bool operator == (const wxIcon& rIcon) - { return m_refData == rIcon.m_refData; } - inline bool operator != (const wxIcon& rIcon) - { return m_refData != rIcon.m_refData; } - wxIconRefData *GetIconData() const { return (wxIconRefData *)m_refData; } inline void SetHICON(WXHICON hIcon) { SetHandle((WXHANDLE)hIcon); } inline WXHICON GetHICON() const { return (WXHICON)GetHandle(); } - inline bool IsXpm(void) const { return m_bIsXpm; }; + inline bool IsXpm(void) const { return m_bIsXpm; } inline const wxBitmap& GetXpmSrc(void) const { return m_vXpmSrc; } void CopyFromBitmap(const wxBitmap& rBmp); @@ -94,7 +79,7 @@ protected: { return new wxIconRefData; } - void CreateIconFromXpm(const char **ppData); + void CreateIconFromXpm(const char* const* ppData); private: bool m_bIsXpm;