X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/45abfa7137a340f98a0528cde6c49954d4f3013c..eba91e51e8d7cce2c5c9a99d8ddcad5b29a114a8:/src/os2/settings.cpp diff --git a/src/os2/settings.cpp b/src/os2/settings.cpp index c75d66794f..8370e46b16 100644 --- a/src/os2/settings.cpp +++ b/src/os2/settings.cpp @@ -13,16 +13,17 @@ #include "wx/wxprec.h" #ifndef WX_PRECOMP -#include -#include "wx/defs.h" -#include "wx/pen.h" -#include "wx/brush.h" -#include "wx/gdicmn.h" + #include + #include "wx/pen.h" + #include "wx/brush.h" + #include "wx/gdicmn.h" + #include "wx/window.h" + #include "wx/settings.h" + #include "wx/module.h" #endif -#include "wx/module.h" -#include "wx/settings.h" -#include "wx/window.h" +#include "wx/fontutil.h" + #include "wx/os2/private.h" // the module which is used to clean up wxSystemSettings data (this is a @@ -70,6 +71,7 @@ void wxSystemSettingsModule::OnExit() sm_optionNames.Clear(); sm_optionValues.Clear(); delete gs_fontDefault; + gs_fontDefault = NULL; } wxColour wxSystemSettingsNative::GetColour( @@ -201,39 +203,50 @@ wxColour wxSystemSettingsNative::GetColour( return(vCol); } // end of wxSystemSettingsNative::GetColour +// ---------------------------------------------------------------------------- +// fonts +// ---------------------------------------------------------------------------- + +wxFont wxCreateFontFromStockObject(int WXUNUSED(index)) +{ + wxFont font; + + FONTMETRICS metrics; + HPS hPS = ::WinGetScreenPS(HWND_DESKTOP); + if (::GpiQueryFontMetrics(hPS, sizeof(FONTMETRICS), &metrics)) + { + wxNativeFontInfo info; + info.fm = metrics; + font.Create(info); + } + else // GetStockObject() failed + { + wxFAIL_MSG( _T("stock font not found") ); + } + + return font; +} + wxFont wxSystemSettingsNative::GetFont( wxSystemFont index ) { - // TODO - switch (index) + const bool isDefaultRequested = index == wxSYS_DEFAULT_GUI_FONT; + if ( isDefaultRequested ) { - case wxSYS_DEVICE_DEFAULT_FONT: - { - break; - } - case wxSYS_DEFAULT_PALETTE: - { - break; - } - case wxSYS_SYSTEM_FIXED_FONT: - { - break; - } - case wxSYS_SYSTEM_FONT: - { - break; - } - default: - case wxSYS_DEFAULT_GUI_FONT: - { - break; - } + if ( gs_fontDefault ) + return *gs_fontDefault; + } + + wxFont font = wxCreateFontFromStockObject(index); + + if ( isDefaultRequested ) + { + // if we got here it means we hadn't cached it yet - do now + gs_fontDefault = new wxFont(font); } - if(wxSWISS_FONT) - return *wxSWISS_FONT; - return wxNullFont; + return font; } // Get a system metric, e.g. scrollbar size