]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/msw/tooltip.h
add a critical section protecting ms_prev variables (replaces patch 1819224)
[wxWidgets.git] / include / wx / msw / tooltip.h
index d8fb5c35e557a3f877eb1e380f7e6772d0e10174..d1b6bba8248f0fd530ad4c8b2c78065b90f58d86 100644 (file)
@@ -1,5 +1,5 @@
 ///////////////////////////////////////////////////////////////////////////////
 ///////////////////////////////////////////////////////////////////////////////
-// Name:        msw/tooltip.h
+// Name:        wx/msw/tooltip.h
 // Purpose:     wxToolTip class - tooltip control
 // Author:      Vadim Zeitlin
 // Modified by:
 // Purpose:     wxToolTip class - tooltip control
 // Author:      Vadim Zeitlin
 // Modified by:
@@ -9,6 +9,13 @@
 // Licence:     wxWindows licence
 ///////////////////////////////////////////////////////////////////////////////
 
 // Licence:     wxWindows licence
 ///////////////////////////////////////////////////////////////////////////////
 
+#ifndef _WX_MSW_TOOLTIP_H_
+#define _WX_MSW_TOOLTIP_H_
+
+#include "wx/object.h"
+
+class WXDLLIMPEXP_FWD_CORE wxWindow;
+
 class WXDLLEXPORT wxToolTip : public wxObject
 {
 public:
 class WXDLLEXPORT wxToolTip : public wxObject
 {
 public:
@@ -30,12 +37,22 @@ public:
     static void Enable(bool flag);
         // set the delay after which the tooltip appears
     static void SetDelay(long milliseconds);
     static void Enable(bool flag);
         // set the delay after which the tooltip appears
     static void SetDelay(long milliseconds);
+        // set the delay after which the tooltip disappears or how long the tooltip remains visible
+    static void SetAutoPop(long milliseconds);
+        // set the delay between subsequent tooltips to appear
+    static void SetReshow(long milliseconds);
 
     // implementation only from now on
     // -------------------------------
 
     // should be called in responde to WM_MOUSEMOVE
 
     // implementation only from now on
     // -------------------------------
 
     // should be called in responde to WM_MOUSEMOVE
-    void RelayEvent(WXMSG *msg);
+    static void RelayEvent(WXMSG *msg);
+
+    // add a window to the tooltip control
+    void Add(WXHWND hwnd);
+
+    // remove any tooltip from the window
+    static void Remove(WXHWND hwnd);
 
 private:
     // the one and only one tooltip control we use - never access it directly
 
 private:
     // the one and only one tooltip control we use - never access it directly
@@ -48,9 +65,6 @@ private:
     // remove this tooltip from the tooltip control
     void Remove();
 
     // remove this tooltip from the tooltip control
     void Remove();
 
-    // add a window to the tooltip control
-    void Add(WXHWND hwnd);
-
     wxString  m_text;           // tooltip text
     wxWindow *m_window;         // window we're associated with
 
     wxString  m_text;           // tooltip text
     wxWindow *m_window;         // window we're associated with
 
@@ -58,3 +72,4 @@ private:
     DECLARE_NO_COPY_CLASS(wxToolTip)
 };
 
     DECLARE_NO_COPY_CLASS(wxToolTip)
 };
 
+#endif // _WX_MSW_TOOLTIP_H_