]> git.saurik.com Git - wxWidgets.git/blobdiff - src/gtk1/settings.cpp
Docview mended (grrr) and OGL studio partially working under wxGTK
[wxWidgets.git] / src / gtk1 / settings.cpp
index 658c74ab4e8d846ac4188c83d46a0e04bda29de7..4a491823fa31ccd8c1a23d1c755e8bd0f509425b 100644 (file)
 #include "wx/settings.h"
 #include "wx/debug.h"
 
+#include "wx/cmndata.h"
+
 #include <gdk/gdk.h>
+#include <gdk/gdkprivate.h>
 #include <gtk/gtk.h>
 
+
 /*
 #define wxSYS_COLOUR_SCROLLBAR         0
 #define wxSYS_COLOUR_BACKGROUND        1
@@ -228,7 +232,35 @@ wxFont wxSystemSettings::GetSystemFont( int index )
         case wxSYS_DEFAULT_GUI_FONT:
         {
             if (!g_systemFont)
-                g_systemFont = new wxFont( 12, wxSWISS, wxNORMAL, wxNORMAL );
+            {
+                GdkFont *gdk_font = (GdkFont*) NULL;
+                GtkWidget *widget = gtk_button_new();
+#if 0
+                GtkStyle *def = gtk_rc_get_style( widget );
+                if (def)
+                    gdk_font =  def->font;
+                else
+                {
+                    def = gtk_widget_get_default_style();
+                    if (def)
+                        gdk_font =  def->font;
+                }
+#endif
+                if (gdk_font)
+                {
+                    GSList *font_list = ((GdkFontPrivate*)gdk_font)->names;
+                    char *name = (char*)font_list->data;
+                    wxString font_string( name );
+                    wxFontData font_data;
+                    g_systemFont = new wxFont( font_string, font_data );
+                }
+                else
+                {
+                    g_systemFont = new wxFont( 12, wxSWISS, wxNORMAL, wxNORMAL );
+                }
+                
+                gtk_widget_destroy( widget );
+            }
             return *g_systemFont;
         }
     }