if ( ret.x < 80 )
ret.x = 80;
- ret.y = 16 + gdk_char_height(GET_STYLE_FONT( m_widget->style ), 'H' );
+ ret.y = 16 + GetCharHeight();
return ret;
}
if (!g_systemFont)
{
#ifdef __WXGTK20__
- GtkWidget *widget = gtk_button_new();
- GtkStyle *def = gtk_rc_get_style( widget );
- if (!def)
- def = gtk_widget_get_default_style();
- if (def)
- {
- wxNativeFontInfo info;
- info.description = def->font_desc;
- g_systemFont = new wxFont(info);
- }
- else
- {
- g_systemFont = new wxFont( 12, wxSWISS, wxNORMAL, wxNORMAL );
- }
- gtk_widget_destroy( widget );
+ const gchar *font_name = _gtk_rc_context_get_default_font_name (gtk_settings_get_default ());
+ g_systemFont = new wxFont( wxString::FromAscii( font_name ) );
#else
g_systemFont = new wxFont( 12, wxSWISS, wxNORMAL, wxNORMAL );
#endif
g_style->bg[GTK_STATE_NORMAL] = *m_bg;
-#ifndef __WXGTK20__
- SET_STYLE_FONT(g_style, GtkGetDefaultGuiFont());
-#endif
-
gtk_widget_set_style( GTK_TOOLBAR(m_toolbar)->tooltips->tip_window, g_style );
m_parent->DoAddChild( this );
g_style->fg[GTK_STATE_NORMAL] = ss_fg;
g_style->bg[GTK_STATE_NORMAL] = ss_bg;
-#ifndef __WXGTK20__
- SET_STYLE_FONT( g_style, GtkGetDefaultGuiFont() );
-#endif
-
gtk_widget_set_style( ss_tooltips->tip_window, g_style );
#else // GTK+ 1.0
gtk_tooltips_set_colors( ss_tooltips, &ss_bg, &ss_fg );
GtkStyle *style = GetWidgetStyle();
-#ifndef __WXGTK20__
if (m_font != wxSystemSettings::GetFont( wxSYS_DEFAULT_GUI_FONT ))
{
- SET_STYLE_FONT(style, m_font.GetInternalFont( 1.0 ));
- }
+#ifdef __WXGTK20__
+ pango_font_description_free( style->font_desc );
+ pango_font_description_copy( m_font.GetNativeFontInfo()->description );
+#else
+ gdk_font_unref( style->font );
+ style->font = gdk_font_ref( m_font.GetInternalFont( 1.0 ) )
#endif
+ }
if (m_foregroundColour.Ok())
{
if ( ret.x < 80 )
ret.x = 80;
- ret.y = 16 + gdk_char_height(GET_STYLE_FONT( m_widget->style ), 'H' );
+ ret.y = 16 + GetCharHeight();
return ret;
}
if (!g_systemFont)
{
#ifdef __WXGTK20__
- GtkWidget *widget = gtk_button_new();
- GtkStyle *def = gtk_rc_get_style( widget );
- if (!def)
- def = gtk_widget_get_default_style();
- if (def)
- {
- wxNativeFontInfo info;
- info.description = def->font_desc;
- g_systemFont = new wxFont(info);
- }
- else
- {
- g_systemFont = new wxFont( 12, wxSWISS, wxNORMAL, wxNORMAL );
- }
- gtk_widget_destroy( widget );
+ const gchar *font_name = _gtk_rc_context_get_default_font_name (gtk_settings_get_default ());
+ g_systemFont = new wxFont( wxString::FromAscii( font_name ) );
#else
g_systemFont = new wxFont( 12, wxSWISS, wxNORMAL, wxNORMAL );
#endif
g_style->bg[GTK_STATE_NORMAL] = *m_bg;
-#ifndef __WXGTK20__
- SET_STYLE_FONT(g_style, GtkGetDefaultGuiFont());
-#endif
-
gtk_widget_set_style( GTK_TOOLBAR(m_toolbar)->tooltips->tip_window, g_style );
m_parent->DoAddChild( this );
g_style->fg[GTK_STATE_NORMAL] = ss_fg;
g_style->bg[GTK_STATE_NORMAL] = ss_bg;
-#ifndef __WXGTK20__
- SET_STYLE_FONT( g_style, GtkGetDefaultGuiFont() );
-#endif
-
gtk_widget_set_style( ss_tooltips->tip_window, g_style );
#else // GTK+ 1.0
gtk_tooltips_set_colors( ss_tooltips, &ss_bg, &ss_fg );
GtkStyle *style = GetWidgetStyle();
-#ifndef __WXGTK20__
if (m_font != wxSystemSettings::GetFont( wxSYS_DEFAULT_GUI_FONT ))
{
- SET_STYLE_FONT(style, m_font.GetInternalFont( 1.0 ));
- }
+#ifdef __WXGTK20__
+ pango_font_description_free( style->font_desc );
+ pango_font_description_copy( m_font.GetNativeFontInfo()->description );
+#else
+ gdk_font_unref( style->font );
+ style->font = gdk_font_ref( m_font.GetInternalFont( 1.0 ) )
#endif
+ }
if (m_foregroundColour.Ok())
{