X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/409c9842c71df526bcfbf1cf5ce80067b09d4d97..19e30148e18cc99296b26503c155e5cef59045f4:/src/os2/settings.cpp diff --git a/src/os2/settings.cpp b/src/os2/settings.cpp index 3dee795eca..1dc15fcfac 100644 --- a/src/os2/settings.cpp +++ b/src/os2/settings.cpp @@ -18,25 +18,193 @@ #include "wx/pen.h" #include "wx/brush.h" #include "wx/gdicmn.h" +#include "wx/module.h" #endif #include "wx/settings.h" #include "wx/window.h" #include "wx/os2/private.h" -// TODO: see ::SystemParametersInfo for all sorts of Windows settings. -// Different args are required depending on the id. How does this differ -// from GetSystemMetric, and should it? Perhaps call it GetSystemParameter -// and pass an optional void* arg to get further info. -// Should also have SetSystemParameter. -// Also implement WM_WININICHANGE (NT) / WM_SETTINGCHANGE (Win95) -wxColour wxSystemSettings::GetSystemColour(int index) +// 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 { - // TODO - return wxColour(); + 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; } -wxFont wxSystemSettings::GetSystemFont(int index) +void wxSystemSettingsModule::OnExit() +{ + sm_optionNames.Clear(); + sm_optionValues.Clear(); + delete gs_fontDefault; +} + +wxColour wxSystemSettingsNative::GetColour( + wxSystemColour nIndex +) +{ + COLORREF vRef; + wxColour vCol; + switch (nIndex) + { + // + // PM actually has values for these + // + case wxSYS_COLOUR_WINDOW: + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP + ,SYSCLR_WINDOW + ,0L + ); + vCol.Set( GetRValue(vRef) + ,GetGValue(vRef) + ,GetBValue(vRef) + ); + break; + + case wxSYS_COLOUR_WINDOWFRAME: + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP + ,SYSCLR_WINDOWFRAME + ,0L + ); + vCol.Set( GetRValue(vRef) + ,GetGValue(vRef) + ,GetBValue(vRef) + ); + break; + + case wxSYS_COLOUR_MENUTEXT: + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP + ,SYSCLR_MENUTEXT + ,0L + ); + vCol.Set( GetRValue(vRef) + ,GetGValue(vRef) + ,GetBValue(vRef) + ); + break; + + case wxSYS_COLOUR_BTNFACE: + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP + ,SYSCLR_BUTTONDEFAULT + ,0L + ); + vCol.Set( GetRValue(vRef) + ,GetGValue(vRef) + ,GetBValue(vRef) + ); + break; + + case wxSYS_COLOUR_BTNSHADOW: + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP + ,SYSCLR_BUTTONMIDDLE + ,0L + ); + vCol.Set( GetRValue(vRef) + ,GetGValue(vRef) + ,GetBValue(vRef) + ); + break; + + case wxSYS_COLOUR_BTNHIGHLIGHT: + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP + ,SYSCLR_BUTTONLIGHT + ,0L + ); + vCol.Set( GetRValue(vRef) + ,GetGValue(vRef) + ,GetBValue(vRef) + ); + break; + + // + // We'll have to just give values to these + // + case wxSYS_COLOUR_LISTBOX: + case wxSYS_COLOUR_CAPTIONTEXT: + return(*wxWHITE); + break; + + case wxSYS_COLOUR_WINDOWTEXT: + case wxSYS_COLOUR_INACTIVECAPTIONTEXT: + case wxSYS_COLOUR_BTNTEXT: + case wxSYS_COLOUR_INFOTEXT: + vCol = (*wxBLACK); + break; + + // + // We should customize these to look like other ports + // + + case wxSYS_COLOUR_ACTIVECAPTION: + case wxSYS_COLOUR_ACTIVEBORDER: + case wxSYS_COLOUR_HIGHLIGHT: + vCol = (*wxBLUE); + break; + + case wxSYS_COLOUR_SCROLLBAR: + case wxSYS_COLOUR_BACKGROUND: + case wxSYS_COLOUR_INACTIVECAPTION: + case wxSYS_COLOUR_MENU: + case wxSYS_COLOUR_INACTIVEBORDER: + case wxSYS_COLOUR_APPWORKSPACE: + case wxSYS_COLOUR_HIGHLIGHTTEXT: + case wxSYS_COLOUR_GRAYTEXT: + case wxSYS_COLOUR_3DDKSHADOW: + case wxSYS_COLOUR_3DLIGHT: + case wxSYS_COLOUR_INFOBK: + vCol = (*wxLIGHT_GREY); + break; + + default: + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP + ,SYSCLR_WINDOW + ,0L + ); + vCol.Set( GetRValue(vRef) + ,GetGValue(vRef) + ,GetBValue(vRef) + ); + break; + } + return(vCol); +} // end of wxSystemSettingsNative::GetColour + +wxFont wxSystemSettingsNative::GetFont( + wxSystemFont index +) { // TODO switch (index) @@ -63,12 +231,16 @@ wxFont wxSystemSettings::GetSystemFont(int index) break; } } + if(wxSWISS_FONT) + return *wxSWISS_FONT; - return wxFont(); + return wxNullFont; } // Get a system metric, e.g. scrollbar size -int wxSystemSettings::GetSystemMetric(int index) +int wxSystemSettingsNative::GetMetric( + wxSystemMetric index +) { switch ( index) { @@ -189,3 +361,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; +}