X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ef344ff86223f1f0961f025c0b249c898529c095..b916f809336755620b010293637b12763f01455d:/src/mgl/settings.cpp diff --git a/src/mgl/settings.cpp b/src/mgl/settings.cpp index bca51ecd13..a4142e571a 100644 --- a/src/mgl/settings.cpp +++ b/src/mgl/settings.cpp @@ -11,9 +11,41 @@ #pragma implementation "settings.h" #endif +// For compilers that support precompilation, includes "wx.h". +#include "wx/wxprec.h" + +#ifdef __BORLANDC__ + #pragma hdrstop +#endif + #include "wx/settings.h" #include "wx/colour.h" #include "wx/font.h" +#include "wx/module.h" + +// ---------------------------------------------------------------------------- +// global data +// ---------------------------------------------------------------------------- + +static wxFont *gs_fontDefault = NULL; + +class wxSystemSettingsModule : public wxModule +{ +public: + virtual bool OnInit() { return TRUE; } + virtual void OnExit() + { + delete gs_fontDefault; + gs_fontDefault = NULL; + } + +private: + DECLARE_DYNAMIC_CLASS(wxSystemSettingsModule) +}; + +IMPLEMENT_DYNAMIC_CLASS(wxSystemSettingsModule, wxModule) + + wxColour wxSystemSettings::GetSystemColour(int WXUNUSED(index)) { @@ -21,10 +53,25 @@ wxColour wxSystemSettings::GetSystemColour(int WXUNUSED(index)) return wxColour(0,0,0); } -wxFont wxSystemSettings::GetSystemFont(int WXUNUSED(index)) +wxFont wxSystemSettings::GetSystemFont(int index) { + bool isDefaultRequested = (index == wxSYS_DEFAULT_GUI_FONT); + + if ( isDefaultRequested && gs_fontDefault ) + { + return *gs_fontDefault; + } + // FIXME_MGL - return wxFont(9, wxSWISS, wxNORMAL, wxNORMAL); + wxFont font(10, wxSWISS, wxNORMAL, wxNORMAL, FALSE, "Arial"); + + if ( isDefaultRequested ) + { + // if we got here it means we hadn't cached it yet - do now + gs_fontDefault = new wxFont(font); + } + + return font; } int wxSystemSettings::GetSystemMetric(int WXUNUSED(index)) @@ -32,3 +79,16 @@ int wxSystemSettings::GetSystemMetric(int WXUNUSED(index)) // FIXME_MGL return 1; } + +bool wxSystemSettings::GetCapability(int index) +{ + switch (index) + { + case wxSYS_CAN_ICONIZE_FRAME: + return FALSE; break; + case wxSYS_CAN_DRAW_FRAME_DECORATIONS: + return FALSE; break; + default: + return FALSE; + } +}