X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6d167489bdf17d55d9bd11be834bc17277661063..abb69c6c82d61cf18f14270650a68896a3d8ed47:/include/wx/msw/icon.h diff --git a/include/wx/msw/icon.h b/include/wx/msw/icon.h index 6104c696ec..1d9305e9aa 100644 --- a/include/wx/msw/icon.h +++ b/include/wx/msw/icon.h @@ -60,15 +60,23 @@ public: class WXDLLEXPORT wxIcon : public wxIconBase { public: - wxIcon(); + // ctors + // default + wxIcon() { } - // Copy constructors + // copy wxIcon(const wxIcon& icon) { Ref(icon); } + // from raw data wxIcon(const char bits[], int width, int height); + // from XPM data + wxIcon(const char **data) { CreateIconFromXpm(data); } + wxIcon(char **data) { CreateIconFromXpm((const char **)data); } + // from resource/file wxIcon(const wxString& name, long type = wxBITMAP_TYPE_ICO_RESOURCE, int desiredWidth = -1, int desiredHeight = -1); + virtual ~wxIcon(); virtual bool LoadFile(const wxString& name, @@ -82,17 +90,26 @@ public: bool operator != (const wxIcon& icon) const { return m_refData != icon.m_refData; } + // implementation only from now on wxIconRefData *GetIconData() const { return (wxIconRefData *)m_refData; } void SetHICON(WXHICON icon) { SetHandle((WXHANDLE)icon); } WXHICON GetHICON() const { return (WXHICON)GetHandle(); } + // 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); + protected: virtual wxGDIImageRefData *CreateData() const { return new wxIconRefData; } + // create from XPM data + void CreateIconFromXpm(const char **data); + private: DECLARE_DYNAMIC_CLASS(wxIcon) };