X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b11708106f93d28dbb47218b18e02674ad6c0cdb..e8fd252ef87d8ff6409d405218ff02c91b980e0a:/src/gtk/tooltip.cpp diff --git a/src/gtk/tooltip.cpp b/src/gtk/tooltip.cpp index f3e3acb598..53707efbc7 100644 --- a/src/gtk/tooltip.cpp +++ b/src/gtk/tooltip.cpp @@ -1,84 +1,139 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: tooltip.cpp -// Purpose: +// Name: src/gtk/tooltip.cpp +// Purpose: wxToolTip implementation // Author: Robert Roebling // Id: $Id$ // Copyright: (c) 1998 Robert Roebling -// Licence: wxWindows licence +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ -#pragma implementation "tooltip.h" -#endif +// For compilers that support precompilation, includes "wx.h". +#include "wx/wxprec.h" + +#if wxUSE_TOOLTIPS #include "wx/tooltip.h" -#include "gtk/gtk.h" -#include "gdk/gdk.h" +#ifndef WX_PRECOMP + #include "wx/window.h" +#endif + +#include "wx/gtk/private.h" + +//----------------------------------------------------------------------------- +// global data +//----------------------------------------------------------------------------- + +static GtkTooltips *gs_tooltips = NULL; //----------------------------------------------------------------------------- // wxToolTip //----------------------------------------------------------------------------- +IMPLEMENT_ABSTRACT_CLASS(wxToolTip, wxObject) + wxToolTip::wxToolTip( const wxString &tip ) { m_text = tip; - - m_tooltips = (GtkTooltips*) NULL; - - m_fg = new GdkColor; - m_fg->red = 0; - m_fg->green = 0; - m_fg->blue = 0; - - m_bg = new GdkColor; - m_bg->red = 65535; - m_bg->green = 65535; - m_bg->blue = 50000; + m_window = NULL; } -wxToolTip::~wxToolTip() +void wxToolTip::SetTip( const wxString &tip ) { - gtk_object_unref( GTK_OBJECT(m_tooltips) ); - - delete m_fg; - delete m_bg; + m_text = tip; + GTKApply( m_window ); } -bool wxToolTip::Ok() +void wxToolTip::GTKApply( wxWindow *win ) { - return (m_tooltips); + if (!win) + return; + + if ( !gs_tooltips ) + gs_tooltips = gtk_tooltips_new(); + + m_window = win; + + if (m_text.empty()) + m_window->GTKApplyToolTip( gs_tooltips, NULL ); + else + m_window->GTKApplyToolTip( gs_tooltips, wxGTK_CONV_SYS(m_text) ); } -void wxToolTip::Create( GtkWidget *tool ) +/* static */ +void wxToolTip::GTKApply(GtkWidget *w, const gchar *tip) { - if (!m_tooltips) +#if GTK_CHECK_VERSION(2, 12, 0) + if (!gtk_check_version(2, 12, 0)) + { + gtk_widget_set_tooltip_text(w, tip); + } + else +#endif { - m_tooltips = gtk_tooltips_new(); - - gdk_color_alloc( gtk_widget_get_colormap( tool ), m_fg ); - gdk_color_alloc( gtk_widget_get_colormap( tool ), m_bg ); - - gtk_tooltips_set_colors( m_tooltips, m_bg, m_fg ); + if ( !gs_tooltips ) + gs_tooltips = gtk_tooltips_new(); + + gtk_tooltips_set_tip(gs_tooltips, w, tip, NULL); } - - gtk_tooltips_set_tip( m_tooltips, tool, m_text, (gchar*) NULL ); } void wxToolTip::Enable( bool flag ) { - if (!Ok()) return; - - if (flag) - gtk_tooltips_enable( m_tooltips ); +#if GTK_CHECK_VERSION(2, 12, 0) + if (!gtk_check_version(2, 12, 0)) + { + GtkSettings* settings = gtk_settings_get_default(); + if(!settings) + return; + gtk_settings_set_long_property(settings, "gtk-enable-tooltips", flag?TRUE:FALSE, NULL); + } else - gtk_tooltips_disable( m_tooltips ); +#endif + { + if (!gs_tooltips) + return; + + if (flag) + gtk_tooltips_enable( gs_tooltips ); + else + gtk_tooltips_disable( gs_tooltips ); + } } +G_BEGIN_DECLS +void gtk_tooltips_set_delay (GtkTooltips *tooltips, + guint delay); +G_END_DECLS + void wxToolTip::SetDelay( long msecs ) { - if (!Ok()) return; - - gtk_tooltips_set_delay( m_tooltips, msecs ); +#if GTK_CHECK_VERSION(2, 12, 0) + if (!gtk_check_version(2, 12, 0)) + { + GtkSettings* settings = gtk_settings_get_default(); + if(!settings) + return; + gtk_settings_set_long_property(settings, "gtk-tooltip-timeout", msecs, NULL); + } + else +#endif + { + if (!gs_tooltips) + return; + + // FIXME: This is a deprecated function and might not even have an effect. + // Try to not use it, after which remove the prototype above. + gtk_tooltips_set_delay( gs_tooltips, (int)msecs ); + } +} + +void wxToolTip::SetAutoPop( long WXUNUSED(msecs) ) +{ +} + +void wxToolTip::SetReshow( long WXUNUSED(msecs) ) +{ } +#endif // wxUSE_TOOLTIPS