X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/8bb6da4ae69b4b16982a1cf7a7284c44b98e4e21..360ae33f4392ebb8b625b8ef3b2542b58f8a3a6b:/include/wx/os2/icon.h diff --git a/include/wx/os2/icon.h b/include/wx/os2/icon.h index 22160f236a..2f000c4aa4 100644 --- a/include/wx/os2/icon.h +++ b/include/wx/os2/icon.h @@ -16,23 +16,11 @@ // headers // ---------------------------------------------------------------------------- -// compatible (even if incorrect) behaviour by default: derive wxIcon from -// wxBitmap -#ifndef wxICON_IS_BITMAP - #define wxICON_IS_BITMAP 1 -#endif - -#if wxICON_IS_BITMAP - #include "wx/bitmap.h" +#include "wx/bitmap.h" +#include "wx/os2/gdiimage.h" - #define wxIconRefDataBase wxBitmapRefData - #define wxIconBase wxBitmap -#else - #include "wx/os2/gdiimage.h" - - #define wxIconRefDataBase wxGDIImageRefData - #define wxIconBase wxGDIImage -#endif +#define wxIconRefDataBase wxGDIImageRefData +#define wxIconBase wxGDIImage class WXDLLEXPORT wxIconRefData: public wxIconRefDataBase { @@ -66,6 +54,11 @@ public: ,int nDesiredWidth = -1 ,int nDesiredHeight = -1 ); + wxIcon(const wxIconLocation& loc) + { + LoadFile(loc.GetFileName(), wxBITMAP_TYPE_ICO); + } + ~wxIcon(); bool LoadFile( const wxString& rName @@ -76,15 +69,17 @@ public: inline wxIcon& operator = (const wxIcon& rIcon) { if (*this != rIcon) Ref(rIcon); return *this; } - inline bool operator == (const wxIcon& rIcon) + inline bool operator == (const wxIcon& rIcon) const { return m_refData == rIcon.m_refData; } - inline bool operator != (const wxIcon& rIcon) + inline bool operator != (const wxIcon& rIcon) const { 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 const wxBitmap& GetXpmSrc(void) const { return m_vXpmSrc; } void CopyFromBitmap(const wxBitmap& rBmp); protected: @@ -95,6 +90,9 @@ protected: void CreateIconFromXpm(const char **ppData); private: + bool m_bIsXpm; + wxBitmap m_vXpmSrc; + DECLARE_DYNAMIC_CLASS(wxIcon) };