projects
/
wxWidgets.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
we don't need to override MSWTranslateMessage(), it was a wrong workaround for the...
[wxWidgets.git]
/
src
/
msw
/
tooltip.cpp
diff --git
a/src/msw/tooltip.cpp
b/src/msw/tooltip.cpp
index 71ef1f714e97674299f79425930464db6435f427..8ca70b9ff363b3dc9f4cc3bf9b45d110a8d856bd 100644
(file)
--- a/
src/msw/tooltip.cpp
+++ b/
src/msw/tooltip.cpp
@@
-103,23
+103,20
@@
public:
// private functions
// ----------------------------------------------------------------------------
// private functions
// ----------------------------------------------------------------------------
-// send a message to the tooltip control
-inline LRESULT SendTooltipMessage(WXHWND hwnd,
- UINT msg,
- WPARAM wParam,
- void *lParam)
+// send a message to the tooltip control if it exists
+//
+// NB: wParam is always 0 for the TTM_XXX messages we use
+static inline LRESULT SendTooltipMessage(WXHWND hwnd, UINT msg, void *lParam)
{
{
- return hwnd ? ::SendMessage((HWND)hwnd, msg, wParam, (LPARAM)lParam)
- : 0;
+ return hwnd ? ::SendMessage((HWND)hwnd, msg, 0, (LPARAM)lParam) : 0;
}
// send a message to all existing tooltip controls
}
// send a message to all existing tooltip controls
-static void SendTooltipMessageToAll(WXHWND hwnd,
- UINT msg,
- WPARAM wParam,
- LPARAM lParam)
+static inline void
+SendTooltipMessageToAll(WXHWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
{
{
- (void)SendTooltipMessage((WXHWND)hwnd, msg, wParam, (void *)lParam);
+ if ( hwnd )
+ ::SendMessage((HWND)hwnd, msg, wParam, lParam);
}
// ============================================================================
}
// ============================================================================
@@
-141,7
+138,7
@@
LRESULT APIENTRY wxToolTipWndProc(HWND hwndTT,
{
LPPOINT ppt = (LPPOINT)lParam;
{
LPPOINT ppt = (LPPOINT)lParam;
- // the window on which event occured
+ // the window on which event occur
r
ed
HWND hwnd = ::WindowFromPoint(*ppt);
OutputDebugString("TTM_WINDOWFROMPOINT: ");
HWND hwnd = ::WindowFromPoint(*ppt);
OutputDebugString("TTM_WINDOWFROMPOINT: ");
@@
-197,13
+194,16
@@
void wxToolTip::SetDelay(long milliseconds)
// ---------------------------------------------------------------------------
// create the tooltip ctrl for our parent frame if it doesn't exist yet
// ---------------------------------------------------------------------------
// create the tooltip ctrl for our parent frame if it doesn't exist yet
+/* static */
WXHWND wxToolTip::GetToolTipCtrl()
{
if ( !ms_hwndTT )
{
WXHWND wxToolTip::GetToolTipCtrl()
{
if ( !ms_hwndTT )
{
+ // we want to show the tooltips always (even when the window is not
+ // active) and we don't want to strip "&"s from them
ms_hwndTT = (WXHWND)::CreateWindow(TOOLTIPS_CLASS,
(LPCTSTR)NULL,
ms_hwndTT = (WXHWND)::CreateWindow(TOOLTIPS_CLASS,
(LPCTSTR)NULL,
- TTS_ALWAYSTIP,
+ TTS_ALWAYSTIP
| TTS_NOPREFIX
,
CW_USEDEFAULT, CW_USEDEFAULT,
CW_USEDEFAULT, CW_USEDEFAULT,
NULL, (HMENU)NULL,
CW_USEDEFAULT, CW_USEDEFAULT,
CW_USEDEFAULT, CW_USEDEFAULT,
NULL, (HMENU)NULL,
@@
-225,9
+225,10
@@
WXHWND wxToolTip::GetToolTipCtrl()
return ms_hwndTT;
}
return ms_hwndTT;
}
+/* static */
void wxToolTip::RelayEvent(WXMSG *msg)
{
void wxToolTip::RelayEvent(WXMSG *msg)
{
- (void)SendTooltipMessage(GetToolTipCtrl(), TTM_RELAYEVENT,
0,
msg);
+ (void)SendTooltipMessage(GetToolTipCtrl(), TTM_RELAYEVENT, msg);
}
// ----------------------------------------------------------------------------
}
// ----------------------------------------------------------------------------
@@
-244,21
+245,27
@@
wxToolTip::wxToolTip(const wxString &tip)
wxToolTip::~wxToolTip()
{
wxToolTip::~wxToolTip()
{
- // there is no need to Remove() this tool - it will be done automatically
- // anyhow
+ // the tooltip has to be removed before deleting. Otherwise, if it is visible
+ // while being deleted, there will be a delay before it goes away.
+ Remove();
}
// ----------------------------------------------------------------------------
// others
// ----------------------------------------------------------------------------
}
// ----------------------------------------------------------------------------
// others
// ----------------------------------------------------------------------------
+void wxToolTip::Remove(WXHWND hWnd)
+{
+ wxToolInfo ti((HWND)hWnd);
+ (void)SendTooltipMessage(GetToolTipCtrl(), TTM_DELTOOL, &ti);
+}
+
void wxToolTip::Remove()
{
// remove this tool from the tooltip control
if ( m_window )
{
void wxToolTip::Remove()
{
// remove this tool from the tooltip control
if ( m_window )
{
- wxToolInfo ti(GetHwndOf(m_window));
- (void)SendTooltipMessage(GetToolTipCtrl(), TTM_DELTOOL, 0, &ti);
+ Remove(m_window->GetHWND());
}
}
}
}
@@
-277,7
+284,7
@@
void wxToolTip::Add(WXHWND hWnd)
ti.hwnd = hwnd;
ti.lpszText = (wxChar *)m_text.c_str(); // const_cast
ti.hwnd = hwnd;
ti.lpszText = (wxChar *)m_text.c_str(); // const_cast
- if ( !SendTooltipMessage(GetToolTipCtrl(), TTM_ADDTOOL,
0,
&ti) )
+ if ( !SendTooltipMessage(GetToolTipCtrl(), TTM_ADDTOOL, &ti) )
{
wxLogDebug(_T("Failed to create the tooltip '%s'"), m_text.c_str());
}
{
wxLogDebug(_T("Failed to create the tooltip '%s'"), m_text.c_str());
}
@@
-293,9
+300,9
@@
void wxToolTip::Add(WXHWND hWnd)
{
// use TTM_SETMAXTIPWIDTH to make tooltip multiline using the
// extent of its first line as max value
{
// use TTM_SETMAXTIPWIDTH to make tooltip multiline using the
// extent of its first line as max value
- HFONT hfont = (HFONT)
SendTooltipMessage(GetToolTipCtrl(),
- WM_GETFONT,
- 0, 0);
+ HFONT hfont = (HFONT)
+ SendTooltipMessage(GetToolTipCtrl(), WM_GETFONT, 0);
+
if ( !hfont )
{
hfont = (HFONT)GetStockObject(DEFAULT_GUI_FONT);
if ( !hfont )
{
hfont = (HFONT)GetStockObject(DEFAULT_GUI_FONT);
@@
-317,19
+324,27
@@
void wxToolTip::Add(WXHWND hWnd)
}
SIZE sz;
}
SIZE sz;
- if ( !
GetTextExtentPoint
(hdc, m_text, index, &sz) )
+ if ( !
::GetTextExtentPoint32
(hdc, m_text, index, &sz) )
{
{
- wxLogLastError(wxT("GetTextExtentPoint"));
+ wxLogLastError(wxT("GetTextExtentPoint
32
"));
}
SendTooltipMessage(GetToolTipCtrl(), TTM_SETMAXTIPWIDTH,
}
SendTooltipMessage(GetToolTipCtrl(), TTM_SETMAXTIPWIDTH,
-
0,
(void *)sz.cx);
+
(void *)sz.cx);
}
}
+ else
#endif // comctl32.dll >= 4.70
#endif // comctl32.dll >= 4.70
+ {
+ // replace the '\n's with spaces because otherwise they appear as
+ // unprintable characters in the tooltip string
+ m_text.Replace(_T("\n"), _T(" "));
+ ti.lpszText = (wxChar *)m_text.c_str(); // const_cast
- // replace the '\n's with spaces because otherwise they appear as
- // unprintable characters in the tooltip string
- m_text.Replace(_T("\n"), _T(" "));
+ if ( !SendTooltipMessage(GetToolTipCtrl(), TTM_ADDTOOL, &ti) )
+ {
+ wxLogDebug(_T("Failed to create the tooltip '%s'"), m_text.c_str());
+ }
+ }
}
}
}
}
}
}
@@
-399,7
+414,7
@@
void wxToolTip::SetTip(const wxString& tip)
wxToolInfo ti(GetHwndOf(m_window));
ti.lpszText = (wxChar *)m_text.c_str();
wxToolInfo ti(GetHwndOf(m_window));
ti.lpszText = (wxChar *)m_text.c_str();
- (void)SendTooltipMessage(GetToolTipCtrl(), TTM_UPDATETIPTEXT,
0,
&ti);
+ (void)SendTooltipMessage(GetToolTipCtrl(), TTM_UPDATETIPTEXT, &ti);
}
}
}
}