]> git.saurik.com Git - wxWidgets.git/commitdiff
Corrected GTK2 creation of default font.
authorRobert Roebling <robert@roebling.de>
Fri, 31 Jan 2003 10:31:05 +0000 (10:31 +0000)
committerRobert Roebling <robert@roebling.de>
Fri, 31 Jan 2003 10:31:05 +0000 (10:31 +0000)
 Removed ugly SET_STYLE_FONT code.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@19031 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

src/gtk/choice.cpp
src/gtk/settings.cpp
src/gtk/tbargtk.cpp
src/gtk/tooltip.cpp
src/gtk/window.cpp
src/gtk1/choice.cpp
src/gtk1/settings.cpp
src/gtk1/tbargtk.cpp
src/gtk1/tooltip.cpp
src/gtk1/window.cpp

index c9251f3982e87eb94bdf19b0da5848b71beaec8b..4edcdc8b942e7ef2e1f0499a1f784804685b21eb 100644 (file)
@@ -474,7 +474,7 @@ wxSize wxChoice::DoGetBestSize() const
     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;
 }
index 736ed76abaf84cdf45b1439c44ec94f4734aa42e..227599ef0bdd3570ccf4dab34b367c6b9ad58247 100644 (file)
@@ -328,21 +328,8 @@ wxFont wxSystemSettingsNative::GetFont( wxSystemFont index )
             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
index bd6f38fd3b76541f44036dd5996bfd942988bab4..2ce4bc754c4f4dbf112bad344ddcd64afb01029e 100644 (file)
@@ -343,10 +343,6 @@ bool wxToolBar::Create( wxWindow *parent,
 
     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 );
index 03f7ebfe98c266b5bf98adc26a848591f2a6c55e..a8e42e4d07d4d1f2fa1600f55373d9043506a84c 100644 (file)
@@ -76,10 +76,6 @@ void wxToolTip::Apply( wxWindow *win )
         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 );
index 7d50b4b936ab4d859b4ed342e973586732e14b34..a2c0ea57b252a82beb676c4a2d18340c30471ec7 100644 (file)
@@ -4145,12 +4145,16 @@ void wxWindowGTK::SetWidgetStyle()
 
     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())
     {
index c9251f3982e87eb94bdf19b0da5848b71beaec8b..4edcdc8b942e7ef2e1f0499a1f784804685b21eb 100644 (file)
@@ -474,7 +474,7 @@ wxSize wxChoice::DoGetBestSize() const
     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;
 }
index 736ed76abaf84cdf45b1439c44ec94f4734aa42e..227599ef0bdd3570ccf4dab34b367c6b9ad58247 100644 (file)
@@ -328,21 +328,8 @@ wxFont wxSystemSettingsNative::GetFont( wxSystemFont index )
             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
index bd6f38fd3b76541f44036dd5996bfd942988bab4..2ce4bc754c4f4dbf112bad344ddcd64afb01029e 100644 (file)
@@ -343,10 +343,6 @@ bool wxToolBar::Create( wxWindow *parent,
 
     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 );
index 03f7ebfe98c266b5bf98adc26a848591f2a6c55e..a8e42e4d07d4d1f2fa1600f55373d9043506a84c 100644 (file)
@@ -76,10 +76,6 @@ void wxToolTip::Apply( wxWindow *win )
         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 );
index 7d50b4b936ab4d859b4ed342e973586732e14b34..a2c0ea57b252a82beb676c4a2d18340c30471ec7 100644 (file)
@@ -4145,12 +4145,16 @@ void wxWindowGTK::SetWidgetStyle()
 
     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())
     {