X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/16c1f7f345e1850f590cfbf67c3b00fbb6d2e62e..0944fceb987def04dc89d03d58c35793d0ecdfed:/include/wx/motif/icon.h diff --git a/include/wx/motif/icon.h b/include/wx/motif/icon.h index 012fd0754d..9d246c7303 100644 --- a/include/wx/motif/icon.h +++ b/include/wx/motif/icon.h @@ -12,86 +12,65 @@ #ifndef _WX_ICON_H_ #define _WX_ICON_H_ -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma interface "icon.h" #endif #include "wx/bitmap.h" -class WXDLLEXPORT wxIconRefData: public wxBitmapRefData +// Icon +class WXDLLEXPORT wxIcon : public wxBitmap { - friend class WXDLLEXPORT wxBitmap; - friend class WXDLLEXPORT wxIcon; public: - wxIconRefData(); - ~wxIconRefData(); -}; + wxIcon(); -#define M_ICONDATA ((wxIconRefData *)m_refData) -#define M_ICONHANDLERDATA ((wxIconRefData *)bitmap->GetRefData()) + // Copy constructors + inline wxIcon(const wxIcon& icon) { Ref(icon); } -// Icon -class WXDLLEXPORT wxIcon: public wxBitmap -{ - DECLARE_DYNAMIC_CLASS(wxIcon) + // Initialize with XBM data + wxIcon(const char bits[], int width, int height); -public: - wxIcon(); - - // Copy constructors - inline wxIcon(const wxIcon& icon) { Ref(icon); } - inline wxIcon(const wxIcon* icon) { if (icon) Ref(*icon); } + // Initialize with XPM data + wxIcon(const char **data); + wxIcon(char **data); - 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(); + wxIcon(const wxString& name, wxBitmapType type = wxBITMAP_TYPE_XPM, + int desiredWidth = -1, int desiredHeight = -1) + { + LoadFile(name, type, desiredWidth, desiredHeight); + } - bool LoadFile(const wxString& name, long flags = wxBITMAP_TYPE_ICO_RESOURCE, - int desiredWidth = -1, int desiredHeight = -1); + wxIcon(const wxIconLocation& loc) + { + LoadFile(loc.GetFileName(), wxBITMAP_TYPE_ANY); + } - 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; } + ~wxIcon(); -/* TODO */ - virtual bool Ok() const { return (m_refData != NULL) ; } -}; + bool LoadFile(const wxString& name, wxBitmapType type, + int desiredWidth, int desiredHeight = -1); -/* Example handlers. TODO: write your own handlers for relevant types. + // unhide base class LoadFile() + virtual bool LoadFile(const wxString& name, + wxBitmapType type = wxBITMAP_TYPE_XPM) + { + return LoadFile(name, type, -1, -1); + } -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); -}; + // create from bitmap (which should have a mask unless it's monochrome): + // there shouldn't be any implicit bitmap -> icon conversion (i.e. no + // ctors, assignment operators...), but it's ok to have such function + void CopyFromBitmap(const wxBitmap& bmp); -class WXDLLEXPORT wxICOResourceHandler: public wxBitmapHandler -{ - DECLARE_DYNAMIC_CLASS(wxICOResourceHandler) -public: - inline wxICOResourceHandler() - { - m_name = "ICO resource"; - m_extension = "ico"; - m_type = wxBITMAP_TYPE_ICO_RESOURCE; - }; + wxIcon& operator = (const wxIcon& icon) + { if (this != &icon) Ref(icon); return *this; } + bool operator == (const wxIcon& icon) const + { return m_refData == icon.m_refData; } + bool operator != (const wxIcon& icon) const + { return !(*this == icon); } - virtual bool LoadFile(wxBitmap *bitmap, const wxString& name, long flags, - int desiredWidth = -1, int desiredHeight = -1); + DECLARE_DYNAMIC_CLASS(wxIcon) }; -*/ - -#endif - // _WX_ICON_H_ +#endif // _WX_ICON_H_