X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ee453a161fcbcbf74c8359d42ca1aaeb2777c9bb..bee96abfbcf1acd8e0a1d4b7a975f58034b846d5:/src/os2/settings.cpp diff --git a/src/os2/settings.cpp b/src/os2/settings.cpp index c47c24d5c4..b34ca6d079 100644 --- a/src/os2/settings.cpp +++ b/src/os2/settings.cpp @@ -20,12 +20,60 @@ #include "wx/gdicmn.h" #endif +#include "wx/module.h" #include "wx/settings.h" #include "wx/window.h" #include "wx/os2/private.h" -wxColour wxSystemSettings::GetSystemColour( - int nIndex +// the module which is used to clean up wxSystemSettings data (this is a +// singleton class so it can't be done in the dtor) +class wxSystemSettingsModule : public wxModule +{ + friend class wxSystemSettings; +public: + virtual bool OnInit(); + virtual void OnExit(); + +private: + DECLARE_DYNAMIC_CLASS(wxSystemSettingsModule) + + static wxArrayString sm_optionNames; + static wxArrayString sm_optionValues; +}; + +// ---------------------------------------------------------------------------- +// global data +// ---------------------------------------------------------------------------- + +static wxFont *gs_fontDefault = NULL; + +// ============================================================================ +// implementation +// ============================================================================ + +// ---------------------------------------------------------------------------- +// wxSystemSettingsModule +// ---------------------------------------------------------------------------- + +IMPLEMENT_DYNAMIC_CLASS(wxSystemSettingsModule, wxModule) + +wxArrayString wxSystemSettingsModule::sm_optionNames; +wxArrayString wxSystemSettingsModule::sm_optionValues; + +bool wxSystemSettingsModule::OnInit() +{ + return TRUE; +} + +void wxSystemSettingsModule::OnExit() +{ + sm_optionNames.Clear(); + sm_optionValues.Clear(); + delete gs_fontDefault; +} + +wxColour wxSystemSettingsNative::GetColour( + wxSystemColour nIndex ) { COLORREF vRef; @@ -44,7 +92,6 @@ wxColour wxSystemSettings::GetSystemColour( ,GetGValue(vRef) ,GetBValue(vRef) ); - return vCol; break; case wxSYS_COLOUR_WINDOWFRAME: @@ -56,7 +103,6 @@ wxColour wxSystemSettings::GetSystemColour( ,GetGValue(vRef) ,GetBValue(vRef) ); - return vCol; break; case wxSYS_COLOUR_MENUTEXT: @@ -79,7 +125,6 @@ wxColour wxSystemSettings::GetSystemColour( ,GetGValue(vRef) ,GetBValue(vRef) ); - return vCol; break; case wxSYS_COLOUR_BTNSHADOW: @@ -91,7 +136,6 @@ wxColour wxSystemSettings::GetSystemColour( ,GetGValue(vRef) ,GetBValue(vRef) ); - return vCol; break; case wxSYS_COLOUR_BTNHIGHLIGHT: @@ -103,7 +147,17 @@ wxColour wxSystemSettings::GetSystemColour( ,GetGValue(vRef) ,GetBValue(vRef) ); - return vCol; + break; + + case wxSYS_COLOUR_MENUBAR: + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP + ,SYSCLR_MENU + ,0L + ); + vCol.Set( GetRValue(vRef) + ,GetGValue(vRef) + ,GetBValue(vRef) + ); break; // @@ -118,7 +172,7 @@ wxColour wxSystemSettings::GetSystemColour( case wxSYS_COLOUR_INACTIVECAPTIONTEXT: case wxSYS_COLOUR_BTNTEXT: case wxSYS_COLOUR_INFOTEXT: - return(*wxBLACK); + vCol = (*wxBLACK); break; // @@ -128,7 +182,7 @@ wxColour wxSystemSettings::GetSystemColour( case wxSYS_COLOUR_ACTIVECAPTION: case wxSYS_COLOUR_ACTIVEBORDER: case wxSYS_COLOUR_HIGHLIGHT: - return(*wxBLUE); + vCol = (*wxBLUE); break; case wxSYS_COLOUR_SCROLLBAR: @@ -142,7 +196,7 @@ wxColour wxSystemSettings::GetSystemColour( case wxSYS_COLOUR_3DDKSHADOW: case wxSYS_COLOUR_3DLIGHT: case wxSYS_COLOUR_INFOBK: - return(*wxLIGHT_GREY); + vCol = (*wxLIGHT_GREY); break; default: @@ -154,13 +208,14 @@ wxColour wxSystemSettings::GetSystemColour( ,GetGValue(vRef) ,GetBValue(vRef) ); - return vCol; break; } return(vCol); -} // end of wxSystemSettings::GetSystemColour +} // end of wxSystemSettingsNative::GetColour -wxFont wxSystemSettings::GetSystemFont(int index) +wxFont wxSystemSettingsNative::GetFont( + wxSystemFont index +) { // TODO switch (index) @@ -187,12 +242,16 @@ wxFont wxSystemSettings::GetSystemFont(int index) break; } } + if(wxSWISS_FONT) + return *wxSWISS_FONT; - return *wxSWISS_FONT; + return wxNullFont; } // Get a system metric, e.g. scrollbar size -int wxSystemSettings::GetSystemMetric(int index) +int wxSystemSettingsNative::GetMetric( + wxSystemMetric index +) { switch ( index) { @@ -257,11 +316,9 @@ int wxSystemSettings::GetSystemMetric(int index) // TODO return 0; case wxSYS_SCREEN_X: - // TODO - return 0; + return ::WinQuerySysValue(HWND_DESKTOP,SV_CXSCREEN); case wxSYS_SCREEN_Y: - // TODO - return 0; + return ::WinQuerySysValue(HWND_DESKTOP,SV_CYSCREEN); case wxSYS_FRAMESIZE_X: // TODO return 0; @@ -313,3 +370,20 @@ int wxSystemSettings::GetSystemMetric(int index) return 0; } +bool wxSystemSettingsNative::HasFeature( + wxSystemFeature index +) +{ + switch (index) + { + case wxSYS_CAN_ICONIZE_FRAME: + return TRUE; + + case wxSYS_CAN_DRAW_FRAME_DECORATIONS: + return FALSE; + + default: + return FALSE; + } + return FALSE; +}