X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/8907154c1a8a6882c6797d1f16393ddfb23e7f3a..8f81f01db3b217e9687859e53f95304d196b7506:/src/gtk/tooltip.cpp?ds=sidebyside diff --git a/src/gtk/tooltip.cpp b/src/gtk/tooltip.cpp index 3b04c2c35d..6004fcc066 100644 --- a/src/gtk/tooltip.cpp +++ b/src/gtk/tooltip.cpp @@ -1,5 +1,5 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: tooltip.cpp +// Name: src/gtk/tooltip.cpp // Purpose: wxToolTip implementation // Author: Robert Roebling // Id: $Id$ @@ -10,12 +10,13 @@ // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" -#include "wx/setup.h" - #if wxUSE_TOOLTIPS #include "wx/tooltip.h" -#include "wx/window.h" + +#ifndef WX_PRECOMP + #include "wx/window.h" +#endif #include "wx/gtk/private.h" @@ -23,7 +24,9 @@ // global data //----------------------------------------------------------------------------- -static GtkTooltips *ss_tooltips = (GtkTooltips*) NULL; +#if !GTK_CHECK_VERSION(3,0,0) && !defined(GTK_DISABLE_DEPRECATED) +static GtkTooltips *gs_tooltips = NULL; +#endif //----------------------------------------------------------------------------- // wxToolTip @@ -32,51 +35,94 @@ static GtkTooltips *ss_tooltips = (GtkTooltips*) NULL; IMPLEMENT_ABSTRACT_CLASS(wxToolTip, wxObject) wxToolTip::wxToolTip( const wxString &tip ) + : m_text(tip) { - m_text = tip; - m_window = (wxWindow*) NULL; + m_window = NULL; } void wxToolTip::SetTip( const wxString &tip ) { m_text = tip; - Apply( m_window ); + if (m_window) + m_window->GTKApplyToolTip(wxGTK_CONV_SYS(m_text)); } -void wxToolTip::Apply( wxWindow *win ) +void wxToolTip::GTKSetWindow(wxWindow* win) { - if (!win) return; - - if (!ss_tooltips) - { - ss_tooltips = gtk_tooltips_new(); - } - + wxASSERT(win); m_window = win; + m_window->GTKApplyToolTip(wxGTK_CONV_SYS(m_text)); +} - if (m_text.IsEmpty()) - m_window->ApplyToolTip( ss_tooltips, (wxChar*) NULL ); +/* static */ +void wxToolTip::GTKApply(GtkWidget* widget, const char* tip) +{ +#if GTK_CHECK_VERSION(2, 12, 0) + if (GTK_CHECK_VERSION(3,0,0) || gtk_check_version(2,12,0) == NULL) + gtk_widget_set_tooltip_text(widget, tip); else - m_window->ApplyToolTip( ss_tooltips, m_text ); +#endif + { +#if !GTK_CHECK_VERSION(3,0,0) && !defined(GTK_DISABLE_DEPRECATED) + if ( !gs_tooltips ) + gs_tooltips = gtk_tooltips_new(); + + gtk_tooltips_set_tip(gs_tooltips, widget, tip, NULL); +#endif + } } void wxToolTip::Enable( bool flag ) { - if (!ss_tooltips) return; - - if (flag) - gtk_tooltips_enable( ss_tooltips ); +#if GTK_CHECK_VERSION(2, 12, 0) + if (GTK_CHECK_VERSION(3,0,0) || gtk_check_version(2,12,0) == NULL) + { + GtkSettings* settings = gtk_settings_get_default(); + if (settings) + gtk_settings_set_long_property(settings, "gtk-enable-tooltips", flag, NULL); + } else - gtk_tooltips_disable( ss_tooltips ); +#endif + { +#if !GTK_CHECK_VERSION(3,0,0) && !defined(GTK_DISABLE_DEPRECATED) + if (!gs_tooltips) + gs_tooltips = gtk_tooltips_new(); + + if (flag) + gtk_tooltips_enable( gs_tooltips ); + else + gtk_tooltips_disable( gs_tooltips ); +#endif + } } void wxToolTip::SetDelay( long msecs ) { - if (!ss_tooltips) - return; +#if GTK_CHECK_VERSION(2, 12, 0) + if (GTK_CHECK_VERSION(3,0,0) || gtk_check_version(2,12,0) == NULL) + { + GtkSettings* settings = gtk_settings_get_default(); + if (settings) + gtk_settings_set_long_property(settings, "gtk-tooltip-timeout", msecs, NULL); + } + else +#endif + { +#if !GTK_CHECK_VERSION(3,0,0) && !defined(GTK_DISABLE_DEPRECATED) + if (!gs_tooltips) + gs_tooltips = gtk_tooltips_new(); - gtk_tooltips_set_delay( ss_tooltips, (int)msecs ); + gtk_tooltips_set_delay( gs_tooltips, (int)msecs ); +#endif + } } -#endif +void wxToolTip::SetAutoPop( long WXUNUSED(msecs) ) +{ +} + +void wxToolTip::SetReshow( long WXUNUSED(msecs) ) +{ +} +#endif // wxUSE_TOOLTIPS