X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/0e320a79f187558effb04d92020b470372bbe456..ab67e8874db324fab5223cc8d5dff8a8de3e2b77:/include/wx/os2/icon.h diff --git a/include/wx/os2/icon.h b/include/wx/os2/icon.h index 038d778613..83cef7afa1 100644 --- a/include/wx/os2/icon.h +++ b/include/wx/os2/icon.h @@ -1,112 +1,92 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: icon.h +// Name: wx/os2/icon.h // Purpose: wxIcon class -// Author: AUTHOR +// Author: David Webster // Modified by: -// Created: ??/??/98 +// Created: 10/09/99 // RCS-ID: $Id$ -// Copyright: (c) AUTHOR -// Licence: wxWindows licence +// Copyright: (c) David Webster +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// #ifndef _WX_ICON_H_ #define _WX_ICON_H_ -#ifdef __GNUG__ -#pragma interface "icon.h" -#endif +// ---------------------------------------------------------------------------- +// headers +// ---------------------------------------------------------------------------- #include "wx/bitmap.h" +#include "wx/os2/gdiimage.h" -class WXDLLEXPORT wxIconRefData: public wxBitmapRefData -{ - friend class WXDLLEXPORT wxBitmap; - friend class WXDLLEXPORT wxIcon; -public: - wxIconRefData(); - ~wxIconRefData(); - -public: -/* TODO: whatever your actual icon handle is - WXHICON m_hIcon; -*/ -}; - -#define M_ICONDATA ((wxIconRefData *)m_refData) -#define M_ICONHANDLERDATA ((wxIconRefData *)bitmap->GetRefData()) +#define wxIconRefDataBase wxGDIImageRefData +#define wxIconBase wxGDIImage -// Icon -class WXDLLEXPORT wxIcon: public wxBitmap +class WXDLLIMPEXP_CORE wxIconRefData: public wxIconRefDataBase { - DECLARE_DYNAMIC_CLASS(wxIcon) - public: - wxIcon(); - - // Copy constructors - inline wxIcon(const wxIcon& icon) { Ref(icon); } - - wxIcon(const char bits[], int width, int height); - wxIcon(const wxString& name, long flags = wxBITMAP_TYPE_ICO_RESOURCE, - int desiredWidth = -1, int desiredHeight = -1); - wxIcon( char **bits, int width=-1, int height=-1 ); - - ~wxIcon(); - - bool LoadFile(const wxString& name, long flags = wxBITMAP_TYPE_ICO_RESOURCE, - int desiredWidth = -1, int desiredHeight = -1); + wxIconRefData() { } + virtual ~wxIconRefData() { Free(); } - inline wxIcon& operator = (const wxIcon& icon) { if (*this == icon) return (*this); Ref(icon); return *this; } - inline bool operator == (const wxIcon& icon) { return m_refData == icon.m_refData; } - inline bool operator != (const wxIcon& icon) { return m_refData != icon.m_refData; } + virtual void Free(); +}; // end of -/* TODO: implementation - void SetHICON(WXHICON ico); - inline WXHICON GetHICON() const { return (M_ICONDATA ? M_ICONDATA->m_hIcon : 0); } -*/ - -/* TODO */ - virtual bool Ok() const { return (m_refData != NULL) ; } -private: - // supress VisAge hiding warning - bool LoadFile(const wxString& name, long type = wxBITMAP_TYPE_BMP_RESOURCE) - { return(wxBitmap::LoadFile(name, type)); } -}; - -/* Example handlers. TODO: write your own handlers for relevant types. - -class WXDLLEXPORT wxICOFileHandler: public wxBitmapHandler -{ - DECLARE_DYNAMIC_CLASS(wxICOFileHandler) -public: - inline wxICOFileHandler() - { - m_name = "ICO icon file"; - m_extension = "ico"; - m_type = wxBITMAP_TYPE_ICO; - }; - - virtual bool LoadFile(wxBitmap *bitmap, const wxString& name, long flags, - int desiredWidth = -1, int desiredHeight = -1); -}; +// --------------------------------------------------------------------------- +// Icon +// --------------------------------------------------------------------------- -class WXDLLEXPORT wxICOResourceHandler: public wxBitmapHandler +class WXDLLIMPEXP_CORE wxIcon: public wxIconBase { - DECLARE_DYNAMIC_CLASS(wxICOResourceHandler) public: - inline wxICOResourceHandler() - { - m_name = "ICO resource"; - m_extension = "ico"; - m_type = wxBITMAP_TYPE_ICO_RESOURCE; - }; + wxIcon(); + + wxIcon( const char bits[] + ,int nWidth + ,int nHeight + ); + wxIcon(const char* const* ppData) { CreateIconFromXpm(ppData); } +#ifdef wxNEEDS_CHARPP + wxIcon(char** ppData) { CreateIconFromXpm(const_cast(ppData)); } +#endif + wxIcon( const wxString& rName + ,wxBitmapType lFlags = wxICON_DEFAULT_TYPE + ,int nDesiredWidth = -1 + ,int nDesiredHeight = -1 + ); + wxIcon(const wxIconLocation& loc) + { + LoadFile(loc.GetFileName(), wxBITMAP_TYPE_ICO); + } + + virtual ~wxIcon(); + + bool LoadFile( const wxString& rName + ,wxBitmapType lFlags = wxICON_DEFAULT_TYPE + ,int nDesiredWidth = -1 + ,int nDesiredHeight = -1 + ); + + 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: + virtual wxGDIImageRefData* CreateData() const + { + return new wxIconRefData; + } + void CreateIconFromXpm(const char* const* ppData); - virtual bool LoadFile(wxBitmap *bitmap, const wxString& name, long flags, - int desiredWidth = -1, int desiredHeight = -1); +private: + bool m_bIsXpm; + wxBitmap m_vXpmSrc; + DECLARE_DYNAMIC_CLASS(wxIcon) }; -*/ - #endif // _WX_ICON_H_