X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/0e320a79f187558effb04d92020b470372bbe456..d11e8786ed13b72766eea18cb577cc00f9f08f41:/include/wx/os2/cursor.h diff --git a/include/wx/os2/cursor.h b/include/wx/os2/cursor.h index bc6397069f..eee0aeba20 100644 --- a/include/wx/os2/cursor.h +++ b/include/wx/os2/cursor.h @@ -1,36 +1,27 @@ ///////////////////////////////////////////////////////////////////////////// // Name: cursor.h // Purpose: wxCursor class -// Author: AUTHOR +// Author: David Webster // Modified by: -// Created: ??/??/98 +// Created: 10/13/99 // RCS-ID: $Id$ -// Copyright: (c) AUTHOR -// Licence: wxWindows licence +// Copyright: (c) David Webster +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// #ifndef _WX_CURSOR_H_ #define _WX_CURSOR_H_ -#ifdef __GNUG__ -#pragma interface "cursor.h" -#endif - #include "wx/bitmap.h" -class WXDLLEXPORT wxCursorRefData: public wxBitmapRefData +class WXDLLEXPORT wxCursorRefData: public wxGDIImageRefData { - friend class WXDLLEXPORT wxBitmap; - friend class WXDLLEXPORT wxCursor; public: wxCursorRefData(); - ~wxCursorRefData(); - -protected: -/* TODO: implementation - WXHCURSOR m_hCursor; -*/ -}; + ~wxCursorRefData() { Free(); } + virtual void Free(void); + bool m_bDestroyCursor; +}; // end of CLASS wxCursorRefData #define M_CURSORDATA ((wxCursorRefData *)m_refData) #define M_CURSORHANDLERDATA ((wxCursorRefData *)bitmap->m_refData) @@ -38,38 +29,47 @@ protected: // Cursor class WXDLLEXPORT wxCursor: public wxBitmap { - DECLARE_DYNAMIC_CLASS(wxCursor) - public: - wxCursor(); - - // Copy constructors - inline wxCursor(const wxCursor& cursor) { Ref(cursor); } + wxCursor(); + + // Copy constructors + wxCursor(const wxCursor& rCursor) { Ref(rCursor); } + wxCursor(const wxImage& rImage); + + wxCursor( const char acBits[] + ,int nWidth + ,int nHeight + ,int nHotSpotX = -1 + ,int nHotSpotY = -1 + ,const char zMaskBits[] = NULL + ); + wxCursor( const wxString& rsName + ,long lFlags = wxBITMAP_TYPE_CUR_RESOURCE + ,int nHotSpotX = 0 + ,int nHotSpotY = 0 + ); + wxCursor(int nCursorType); + inline ~wxCursor() { } + + inline wxCursor& operator = (const wxCursor& rCursor) + { + if (*this == rCursor) + return (*this); + Ref(rCursor); + return *this; + } + inline bool operator == (const wxCursor& rCursor) const { return m_refData == rCursor.m_refData; } + inline bool operator != (const wxCursor& rCursor) const { return m_refData != rCursor.m_refData; } + + inline WXHCURSOR GetHCURSOR(void) const { return (M_CURSORDATA ? M_CURSORDATA->m_hCursor : 0); } + inline void SetHCURSOR(WXHCURSOR hCursor) { SetHandle((WXHANDLE)hCursor); } - wxCursor(const char bits[], int width, int height, int hotSpotX = -1, int hotSpotY = -1, - const char maskBits[] = NULL); - - /* TODO: make default type suit platform */ - wxCursor(const wxString& name, long flags = wxBITMAP_TYPE_CUR_RESOURCE, - int hotSpotX = 0, int hotSpotY = 0); - - wxCursor(int cursor_type); - ~wxCursor(); - - // TODO: also verify the internal cursor handle - virtual bool Ok() const { return (m_refData != NULL) ; } - - inline wxCursor& operator = (const wxCursor& cursor) { if (*this == cursor) return (*this); Ref(cursor); return *this; } - inline bool operator == (const wxCursor& cursor) { return m_refData == cursor.m_refData; } - inline bool operator != (const wxCursor& cursor) { return m_refData != cursor.m_refData; } - -/* TODO: implementation - void SetHCURSOR(WXHCURSOR cursor); - inline WXHCURSOR GetHCURSOR() const { return (M_CURSORDATA ? M_CURSORDATA->m_hCursor : 0); } -*/ -}; +protected: + inline virtual wxGDIImageRefData* CreateData(void) const { return (new wxCursorRefData); } -extern WXDLLEXPORT void wxSetCursor(const wxCursor& cursor); +private: + DECLARE_DYNAMIC_CLASS(wxCursor) +}; // end of CLASS wxCursor #endif // _WX_CURSOR_H_