X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b342f8f0a604f553accba543b7feaf62dcc1df08..261a9107f0ce372c61b1e8c634e98cf7ad59a91e:/src/gtk/tooltip.cpp diff --git a/src/gtk/tooltip.cpp b/src/gtk/tooltip.cpp index ec256d13be..08f55c48f4 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$ @@ -7,29 +7,24 @@ // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ - #pragma implementation "tooltip.h" -#endif - -#include "wx/setup.h" +// For compilers that support precompilation, includes "wx.h". +#include "wx/wxprec.h" #if wxUSE_TOOLTIPS -#include "wx/window.h" #include "wx/tooltip.h" -#include "gtk/gtk.h" -#include "gdk/gdk.h" +#ifndef WX_PRECOMP + #include "wx/window.h" +#endif -extern GdkFont *GtkGetDefaultGuiFont(); +#include "wx/gtk/private.h" //----------------------------------------------------------------------------- // global data //----------------------------------------------------------------------------- -static GtkTooltips *ss_tooltips = (GtkTooltips*) NULL; -static GdkColor ss_bg; -static GdkColor ss_fg; +static GtkTooltips *gs_tooltips = (GtkTooltips*) NULL; //----------------------------------------------------------------------------- // wxToolTip @@ -51,65 +46,61 @@ void wxToolTip::SetTip( const wxString &tip ) void wxToolTip::Apply( wxWindow *win ) { - if (!win) return; - - if (!ss_tooltips) - { - ss_tooltips = gtk_tooltips_new(); - - ss_fg.red = 0; - ss_fg.green = 0; - ss_fg.blue = 0; - gdk_color_alloc( gtk_widget_get_default_colormap(), &ss_fg ); - - ss_bg.red = 65535; - ss_bg.green = 65535; - ss_bg.blue = 50000; - gdk_color_alloc( gtk_widget_get_default_colormap(), &ss_bg ); - -#if (GTK_MINOR_VERSION > 0) - gtk_tooltips_force_window( ss_tooltips ); - - GtkStyle *g_style = - gtk_style_copy( - gtk_widget_get_style( ss_tooltips->tip_window ) ); - - g_style->fg[GTK_STATE_NORMAL] = ss_fg; - g_style->bg[GTK_STATE_NORMAL] = ss_bg; - gdk_font_unref( g_style->font ); - g_style->font = gdk_font_ref( GtkGetDefaultGuiFont() ); + if (!win) + return; - gtk_widget_set_style( ss_tooltips->tip_window, g_style ); -#else - gtk_tooltips_set_colors( ss_tooltips, &ss_bg, &ss_fg ); -#endif - } + if ( !gs_tooltips ) + gs_tooltips = gtk_tooltips_new(); m_window = win; - if (m_text.IsEmpty()) - m_window->ApplyToolTip( ss_tooltips, (wxChar*) NULL ); + if (m_text.empty()) + m_window->ApplyToolTip( gs_tooltips, NULL ); else - m_window->ApplyToolTip( ss_tooltips, m_text ); + m_window->ApplyToolTip( gs_tooltips, wxGTK_CONV_SYS(m_text) ); +} + +/* static */ +void wxToolTip::Apply(GtkWidget *w, const gchar *tip) +{ + if ( !gs_tooltips ) + gs_tooltips = gtk_tooltips_new(); + + gtk_tooltips_set_tip(gs_tooltips, w, tip, NULL); } void wxToolTip::Enable( bool flag ) { - if (!ss_tooltips) return; + if (!gs_tooltips) + return; if (flag) - gtk_tooltips_enable( ss_tooltips ); + gtk_tooltips_enable( gs_tooltips ); else - gtk_tooltips_disable( ss_tooltips ); + 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 (!ss_tooltips) + if (!gs_tooltips) return; - gtk_tooltips_set_delay( ss_tooltips, (int)msecs ); + // 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 ); } -#endif +void wxToolTip::SetAutoPop( long WXUNUSED(msecs) ) +{ +} + +void wxToolTip::SetReshow( long WXUNUSED(msecs) ) +{ +} +#endif // wxUSE_TOOLTIPS