X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/87fbe614866ed932f1eefa1abaf1b39ef1427309..449110cd746414d5f77db428babe20b84720c73a:/include/wx/caret.h diff --git a/include/wx/caret.h b/include/wx/caret.h index 5a2926285a..e34ed29d12 100644 --- a/include/wx/caret.h +++ b/include/wx/caret.h @@ -12,7 +12,11 @@ #ifndef _WX_CARET_H_BASE_ #define _WX_CARET_H_BASE_ -#ifdef __GNUG__ +#include "wx/defs.h" + +#if wxUSE_CARET + +#if defined(__GNUG__) && !defined(__APPLE__) #pragma interface "caret.h" #endif @@ -96,7 +100,11 @@ public: wxWindow *GetWindow() const { return (wxWindow *)m_window; } // change the size of the caret - void SetSize(int width, int height) { m_width = width; m_height = height; } + void SetSize(int width, int height) { + m_width = width; + m_height = height; + DoSize(); + } void SetSize(const wxSize& size) { SetSize(size.x, size.y); } @@ -155,6 +163,7 @@ protected: virtual void DoShow() = 0; virtual void DoHide() = 0; virtual void DoMove() = 0; + virtual void DoSize() { } // the common initialization void Init() @@ -178,7 +187,7 @@ protected: int m_countVisible; private: - DECLARE_NO_COPY_CLASS(wxCaretBase); + DECLARE_NO_COPY_CLASS(wxCaretBase) }; // --------------------------------------------------------------------------- @@ -191,5 +200,35 @@ private: #include "wx/generic/caret.h" #endif // platform +// ---------------------------------------------------------------------------- +// wxCaretSuspend: a simple class which hides the caret in its ctor and +// restores it in the dtor, this should be used when drawing on the screen to +// avoid overdrawing the caret +// ---------------------------------------------------------------------------- + +class WXDLLEXPORT wxCaretSuspend +{ +public: + wxCaretSuspend(wxWindow *win) + { + m_caret = win->GetCaret(); + if ( m_caret ) + m_caret->Hide(); + } + + ~wxCaretSuspend() + { + if ( m_caret ) + m_caret->Show(); + } + +private: + wxCaret *m_caret; + + DECLARE_NO_COPY_CLASS(wxCaretSuspend) +}; + +#endif // wxUSE_CARET + #endif // _WX_CARET_H_BASE_