1999-01-31 23:38:10 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
2006-07-24 14:04:31 +00:00
|
|
|
// Name: wx/msw/tooltip.h
|
1999-01-31 23:38:10 +00:00
|
|
|
// Purpose: wxToolTip class - tooltip control
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Modified by:
|
|
|
|
// Created: 31.01.99
|
|
|
|
// Copyright: (c) 1999 Robert Roebling, Vadim Zeitlin
|
2004-05-23 20:53:33 +00:00
|
|
|
// Licence: wxWindows licence
|
1999-01-31 23:38:10 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2005-09-25 20:49:40 +00:00
|
|
|
#ifndef _WX_MSW_TOOLTIP_H_
|
|
|
|
#define _WX_MSW_TOOLTIP_H_
|
|
|
|
|
2006-01-06 12:54:44 +00:00
|
|
|
#include "wx/object.h"
|
2009-04-28 09:39:52 +00:00
|
|
|
#include "wx/gdicmn.h"
|
2006-01-06 12:54:44 +00:00
|
|
|
|
2007-07-09 10:09:52 +00:00
|
|
|
class WXDLLIMPEXP_FWD_CORE wxWindow;
|
2010-11-07 13:12:16 +00:00
|
|
|
class wxToolTipOtherWindows;
|
2006-07-24 14:04:31 +00:00
|
|
|
|
2008-03-26 15:06:00 +00:00
|
|
|
class WXDLLIMPEXP_CORE wxToolTip : public wxObject
|
1999-01-31 23:38:10 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
// ctor & dtor
|
|
|
|
wxToolTip(const wxString &tip);
|
|
|
|
virtual ~wxToolTip();
|
2009-08-21 10:41:26 +00:00
|
|
|
|
2009-04-26 13:37:16 +00:00
|
|
|
// ctor used by wxStatusBar to associate a tooltip to a portion of
|
|
|
|
// the status bar window:
|
2009-08-21 10:41:26 +00:00
|
|
|
wxToolTip(wxWindow* win, unsigned int id,
|
2009-04-26 13:37:16 +00:00
|
|
|
const wxString &tip, const wxRect& rc);
|
1999-01-31 23:38:10 +00:00
|
|
|
|
|
|
|
// accessors
|
|
|
|
// tip text
|
|
|
|
void SetTip(const wxString& tip);
|
|
|
|
const wxString& GetTip() const { return m_text; }
|
|
|
|
|
|
|
|
// the window we're associated with
|
|
|
|
void SetWindow(wxWindow *win);
|
|
|
|
wxWindow *GetWindow() const { return m_window; }
|
|
|
|
|
1999-02-14 21:59:48 +00:00
|
|
|
// controlling tooltip behaviour: globally change tooltip parameters
|
1999-01-31 23:38:10 +00:00
|
|
|
// enable or disable the tooltips globally
|
1999-02-14 21:59:48 +00:00
|
|
|
static void Enable(bool flag);
|
1999-01-31 23:38:10 +00:00
|
|
|
// set the delay after which the tooltip appears
|
1999-02-14 21:59:48 +00:00
|
|
|
static void SetDelay(long milliseconds);
|
2009-01-23 13:26:20 +00:00
|
|
|
// set the delay after which the tooltip disappears or how long the
|
|
|
|
// tooltip remains visible
|
2007-08-15 12:57:36 +00:00
|
|
|
static void SetAutoPop(long milliseconds);
|
|
|
|
// set the delay between subsequent tooltips to appear
|
|
|
|
static void SetReshow(long milliseconds);
|
2009-01-23 13:26:20 +00:00
|
|
|
// set maximum width for the new tooltips: -1 disables wrapping
|
|
|
|
// entirely, 0 restores the default behaviour
|
|
|
|
static void SetMaxWidth(int width);
|
1999-01-31 23:38:10 +00:00
|
|
|
|
2000-01-23 23:23:46 +00:00
|
|
|
// implementation only from now on
|
|
|
|
// -------------------------------
|
|
|
|
|
2009-04-26 13:37:16 +00:00
|
|
|
// should be called in response to WM_MOUSEMOVE
|
2006-05-04 15:58:29 +00:00
|
|
|
static void RelayEvent(WXMSG *msg);
|
1999-01-31 23:38:10 +00:00
|
|
|
|
2005-02-28 01:22:35 +00:00
|
|
|
// add a window to the tooltip control
|
2012-04-05 13:55:51 +00:00
|
|
|
void AddOtherWindow(WXHWND hwnd);
|
2005-02-28 01:22:35 +00:00
|
|
|
|
2006-05-04 15:51:38 +00:00
|
|
|
// remove any tooltip from the window
|
2009-04-26 13:37:16 +00:00
|
|
|
static void Remove(WXHWND hwnd, unsigned int id, const wxRect& rc);
|
|
|
|
|
2010-11-07 13:12:16 +00:00
|
|
|
// Set the rectangle we're associated with. This rectangle is only used for
|
|
|
|
// the main window, not any sub-windows added with Add() so in general it
|
|
|
|
// makes sense to use it for tooltips associated with a single window only.
|
2009-04-26 13:37:16 +00:00
|
|
|
void SetRect(const wxRect& rc);
|
2006-05-04 15:51:38 +00:00
|
|
|
|
2014-06-02 01:15:39 +00:00
|
|
|
// Called when TLW shown state is changed and hides the tooltip itself if
|
|
|
|
// the window it's associated with is hidden.
|
|
|
|
static void UpdateVisibility();
|
|
|
|
|
1999-01-31 23:38:10 +00:00
|
|
|
private:
|
2016-02-13 11:55:17 +00:00
|
|
|
// This module calls our DeleteToolTipCtrl().
|
|
|
|
friend class wxToolTipModule;
|
|
|
|
|
2010-11-07 13:12:16 +00:00
|
|
|
// Adds a window other than our main m_window to this tooltip.
|
2012-04-05 13:55:51 +00:00
|
|
|
void DoAddHWND(WXHWND hWnd);
|
2010-11-07 13:12:16 +00:00
|
|
|
|
|
|
|
// Perform the specified operation for the given window only.
|
|
|
|
void DoSetTip(WXHWND hWnd);
|
|
|
|
void DoRemove(WXHWND hWnd);
|
|
|
|
|
|
|
|
// Call the given function for all windows we're associated with.
|
|
|
|
void DoForAllWindows(void (wxToolTip::*func)(WXHWND));
|
|
|
|
|
|
|
|
|
2000-01-23 23:23:46 +00:00
|
|
|
// the one and only one tooltip control we use - never access it directly
|
|
|
|
// but use GetToolTipCtrl() which will create it when needed
|
1999-11-25 23:28:41 +00:00
|
|
|
static WXHWND ms_hwndTT;
|
|
|
|
|
|
|
|
// create the tooltip ctrl if it doesn't exist yet and return its HWND
|
2000-01-23 23:23:46 +00:00
|
|
|
static WXHWND GetToolTipCtrl();
|
1999-01-31 23:38:10 +00:00
|
|
|
|
2016-02-13 11:55:17 +00:00
|
|
|
// to be used in wxModule for deleting tooltip ctrl window when exiting mainloop
|
|
|
|
static void DeleteToolTipCtrl();
|
|
|
|
|
2009-01-23 13:26:20 +00:00
|
|
|
// new tooltip maximum width, defaults to min(display width, 400)
|
|
|
|
static int ms_maxWidth;
|
|
|
|
|
1999-01-31 23:38:10 +00:00
|
|
|
// remove this tooltip from the tooltip control
|
|
|
|
void Remove();
|
|
|
|
|
2014-02-01 18:18:47 +00:00
|
|
|
// adjust tooltip max width based on current tooltip text
|
|
|
|
bool AdjustMaxWidth();
|
|
|
|
|
1999-01-31 23:38:10 +00:00
|
|
|
wxString m_text; // tooltip text
|
2010-11-07 13:12:16 +00:00
|
|
|
wxWindow* m_window; // main window we're associated with
|
|
|
|
wxToolTipOtherWindows *m_others; // other windows associated with it or NULL
|
2009-04-26 13:37:16 +00:00
|
|
|
wxRect m_rect; // the rect of the window for which this tooltip is shown
|
|
|
|
// (or a rect with width/height == 0 to show it for the entire window)
|
|
|
|
unsigned int m_id; // the id of this tooltip (ignored when m_rect width/height is 0)
|
2001-07-14 03:23:30 +00:00
|
|
|
|
2015-04-23 11:49:01 +00:00
|
|
|
wxDECLARE_ABSTRACT_CLASS(wxToolTip);
|
2009-02-08 11:45:59 +00:00
|
|
|
wxDECLARE_NO_COPY_CLASS(wxToolTip);
|
1999-01-31 23:38:10 +00:00
|
|
|
};
|
1999-09-13 19:19:57 +00:00
|
|
|
|
2005-09-25 20:49:40 +00:00
|
|
|
#endif // _WX_MSW_TOOLTIP_H_
|