X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7e99520bd3fc092bbbcbc38bb699a0236618ea40..8913c40c32bf45df97280c5b1e5a542bfc764ca8:/src/os2/settings.cpp diff --git a/src/os2/settings.cpp b/src/os2/settings.cpp index f7394528e1..8370e46b16 100644 --- a/src/os2/settings.cpp +++ b/src/os2/settings.cpp @@ -1,5 +1,5 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: settings.cpp +// Name: src/os2/settings.cpp // Purpose: wxSettings // Author: David Webster // Modified by: @@ -13,299 +13,313 @@ #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/settings.h" -#include "wx/window.h" +#include "wx/fontutil.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; + gs_fontDefault = NULL; +} + +wxColour wxSystemSettingsNative::GetColour( + wxSystemColour nIndex ) { COLORREF vRef; wxColour vCol; + LONG vSysClr; 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) - ); + vSysClr = SYSCLR_WINDOW; break; case wxSYS_COLOUR_WINDOWFRAME: - vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP - ,SYSCLR_WINDOWFRAME - ,0L - ); - vCol.Set( GetRValue(vRef) - ,GetGValue(vRef) - ,GetBValue(vRef) - ); + vSysClr = SYSCLR_WINDOWFRAME; break; case wxSYS_COLOUR_MENUTEXT: - vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP - ,SYSCLR_MENUTEXT - ,0L - ); - vCol.Set( GetRValue(vRef) - ,GetGValue(vRef) - ,GetBValue(vRef) - ); + vSysClr = SYSCLR_MENUTEXT; + break; + + case wxSYS_COLOUR_MENUHILIGHT: + vSysClr = SYSCLR_MENUHILITE; break; case wxSYS_COLOUR_BTNFACE: - vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP - ,SYSCLR_BUTTONDEFAULT - ,0L - ); - vCol.Set( GetRValue(vRef) - ,GetGValue(vRef) - ,GetBValue(vRef) - ); + vSysClr = SYSCLR_BUTTONMIDDLE; break; case wxSYS_COLOUR_BTNSHADOW: - vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP - ,SYSCLR_BUTTONMIDDLE - ,0L - ); - vCol.Set( GetRValue(vRef) - ,GetGValue(vRef) - ,GetBValue(vRef) - ); + vSysClr = SYSCLR_BUTTONDARK; break; case wxSYS_COLOUR_BTNHIGHLIGHT: - vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP - ,SYSCLR_BUTTONLIGHT - ,0L - ); - vCol.Set( GetRValue(vRef) - ,GetGValue(vRef) - ,GetBValue(vRef) - ); + vSysClr = SYSCLR_BUTTONLIGHT; + break; + + case wxSYS_COLOUR_BACKGROUND: + vSysClr = SYSCLR_BACKGROUND; + break; + + case wxSYS_COLOUR_APPWORKSPACE: + vSysClr = SYSCLR_APPWORKSPACE; + break; + + case wxSYS_COLOUR_MENUBAR: + case wxSYS_COLOUR_MENU: + vSysClr = SYSCLR_MENU; + break; + + case wxSYS_COLOUR_INACTIVECAPTION: + vSysClr = SYSCLR_INACTIVETITLE; + break; + + case wxSYS_COLOUR_INACTIVEBORDER: + vSysClr = SYSCLR_INACTIVEBORDER; break; - // - // We'll have to just give values to these - // case wxSYS_COLOUR_LISTBOX: + vSysClr = SYSCLR_ENTRYFIELD; + break; + case wxSYS_COLOUR_CAPTIONTEXT: - return(*wxWHITE); + vSysClr = SYSCLR_TITLETEXT; break; - case wxSYS_COLOUR_WINDOWTEXT: case wxSYS_COLOUR_INACTIVECAPTIONTEXT: + vSysClr = SYSCLR_INACTIVETITLETEXT; + break; + + case wxSYS_COLOUR_WINDOWTEXT: case wxSYS_COLOUR_BTNTEXT: - case wxSYS_COLOUR_INFOTEXT: - vCol = (*wxBLACK); + vSysClr = SYSCLR_WINDOWTEXT; break; - // - // We should customize these to look like other ports - // + case wxSYS_COLOUR_INFOTEXT: + vSysClr = SYSCLR_HELPTEXT; + break; case wxSYS_COLOUR_ACTIVECAPTION: + vSysClr = SYSCLR_ACTIVETITLE; + break; + case wxSYS_COLOUR_ACTIVEBORDER: + vSysClr = SYSCLR_ACTIVEBORDER; + break; + case wxSYS_COLOUR_HIGHLIGHT: - vCol = (*wxBLUE); + vSysClr = SYSCLR_HILITEBACKGROUND; 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: + vSysClr = SYSCLR_SCROLLBAR; + break; + case wxSYS_COLOUR_HIGHLIGHTTEXT: + vSysClr = SYSCLR_HILITEFOREGROUND; + break; + + case wxSYS_COLOUR_INFOBK: + vSysClr = SYSCLR_HELPBACKGROUND; + break; + + // Don't know what these should be, so leave them grey (normally) case wxSYS_COLOUR_GRAYTEXT: case wxSYS_COLOUR_3DDKSHADOW: case wxSYS_COLOUR_3DLIGHT: - case wxSYS_COLOUR_INFOBK: - vCol = (*wxLIGHT_GREY); + case wxSYS_COLOUR_HOTLIGHT: + case wxSYS_COLOUR_GRADIENTACTIVECAPTION: + case wxSYS_COLOUR_GRADIENTINACTIVECAPTION: + vSysClr = SYSCLR_BUTTONMIDDLE; break; default: - vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP - ,SYSCLR_WINDOW - ,0L - ); - vCol.Set( GetRValue(vRef) - ,GetGValue(vRef) - ,GetBValue(vRef) - ); + vSysClr = SYSCLR_WINDOW; break; } + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP, + vSysClr, + 0L ); + vCol.Set( GetRValue(vRef), + GetGValue(vRef), + GetBValue(vRef) ); return(vCol); -} // end of wxSystemSettings::GetSystemColour +} // end of wxSystemSettingsNative::GetColour -wxFont wxSystemSettings::GetSystemFont(int index) +// ---------------------------------------------------------------------------- +// fonts +// ---------------------------------------------------------------------------- + +wxFont wxCreateFontFromStockObject(int WXUNUSED(index)) { - // TODO - switch (index) + wxFont font; + + FONTMETRICS metrics; + HPS hPS = ::WinGetScreenPS(HWND_DESKTOP); + if (::GpiQueryFontMetrics(hPS, sizeof(FONTMETRICS), &metrics)) { - 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; - } + wxNativeFontInfo info; + info.fm = metrics; + font.Create(info); + } + else // GetStockObject() failed + { + wxFAIL_MSG( _T("stock font not found") ); } - if(wxSWISS_FONT) - return *wxSWISS_FONT; - return wxNullFont; + return font; +} + +wxFont wxSystemSettingsNative::GetFont( + wxSystemFont index +) +{ + const bool isDefaultRequested = index == wxSYS_DEFAULT_GUI_FONT; + if ( isDefaultRequested ) + { + 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); + } + + return font; } // Get a system metric, e.g. scrollbar size -int wxSystemSettings::GetSystemMetric(int index) +int wxSystemSettingsNative::GetMetric( wxSystemMetric index, + wxWindow* WXUNUSED(win) ) { switch ( index) { - case wxSYS_MOUSE_BUTTONS: - // TODO - return 0; - case wxSYS_BORDER_X: - // TODO - return 0; - case wxSYS_BORDER_Y: - // TODO - return 0; - case wxSYS_CURSOR_X: - // TODO - return 0; - case wxSYS_CURSOR_Y: - // TODO - return 0; - case wxSYS_DCLICK_X: - // TODO - return 0; - case wxSYS_DCLICK_Y: - // TODO - return 0; - case wxSYS_DRAG_X: - // TODO - return 0; - case wxSYS_DRAG_Y: - // TODO - return 0; - case wxSYS_EDGE_X: - // TODO - return 0; - case wxSYS_EDGE_Y: - // TODO - return 0; - case wxSYS_HSCROLL_ARROW_X: - // TODO - return 0; - case wxSYS_HSCROLL_ARROW_Y: - // TODO - return 0; - case wxSYS_HTHUMB_X: - // TODO - return 0; - case wxSYS_ICON_X: - // TODO - return 0; - case wxSYS_ICON_Y: - // TODO - return 0; - case wxSYS_ICONSPACING_X: - // TODO - return 0; - case wxSYS_ICONSPACING_Y: - // TODO - return 0; - case wxSYS_WINDOWMIN_X: - // TODO - return 0; - case wxSYS_WINDOWMIN_Y: - // TODO - return 0; + // TODO case wxSYS_MOUSE_BUTTONS: + // TODO case wxSYS_BORDER_X: + // TODO case wxSYS_BORDER_Y: + // TODO case wxSYS_CURSOR_X: + // TODO case wxSYS_CURSOR_Y: + // TODO case wxSYS_DCLICK_X: + // TODO case wxSYS_DCLICK_Y: + // TODO case wxSYS_DRAG_X: + // TODO case wxSYS_DRAG_Y: + // TODO case wxSYS_EDGE_X: + // TODO case wxSYS_EDGE_Y: + // TODO case wxSYS_HSCROLL_ARROW_X: + // TODO case wxSYS_HSCROLL_ARROW_Y: + // TODO case wxSYS_HTHUMB_X: + // TODO case wxSYS_ICON_X: + // TODO case wxSYS_ICON_Y: + // TODO case wxSYS_ICONSPACING_X: + // TODO case wxSYS_ICONSPACING_Y: + // TODO case wxSYS_WINDOWMIN_X: + // TODO case wxSYS_WINDOWMIN_Y: + case wxSYS_SCREEN_X: - // TODO - return 0; + return ::WinQuerySysValue(HWND_DESKTOP,SV_CXSCREEN); case wxSYS_SCREEN_Y: - // TODO - return 0; - case wxSYS_FRAMESIZE_X: - // TODO - return 0; - case wxSYS_FRAMESIZE_Y: - // TODO - return 0; - case wxSYS_SMALLICON_X: - // TODO - return 0; - case wxSYS_SMALLICON_Y: - // TODO - return 0; + return ::WinQuerySysValue(HWND_DESKTOP,SV_CYSCREEN); + + // TODO case wxSYS_FRAMESIZE_X: + // TODO case wxSYS_FRAMESIZE_Y: + // TODO case wxSYS_SMALLICON_X: + // TODO case wxSYS_SMALLICON_Y: + case wxSYS_HSCROLL_Y: - // TODO - return 0; + return ::WinQuerySysValue(HWND_DESKTOP,SV_CYHSCROLL); case wxSYS_VSCROLL_X: - // TODO - return 0; - case wxSYS_VSCROLL_ARROW_X: - // TODO - return 0; - case wxSYS_VSCROLL_ARROW_Y: - // TODO - return 0; - case wxSYS_VTHUMB_Y: - // TODO - return 0; - case wxSYS_CAPTION_Y: - // TODO - return 0; - case wxSYS_MENU_Y: - // TODO - return 0; - case wxSYS_NETWORK_PRESENT: - // TODO - return 0; - case wxSYS_PENWINDOWS_PRESENT: - // TODO - return 0; - case wxSYS_SHOW_SOUNDS: - // TODO - return 0; - case wxSYS_SWAP_BUTTONS: - // TODO - return 0; + return ::WinQuerySysValue(HWND_DESKTOP,SV_CXVSCROLL); + + // TODO case wxSYS_VSCROLL_ARROW_X: + // TODO case wxSYS_VSCROLL_ARROW_Y: + // TODO case wxSYS_VTHUMB_Y: + // TODO case wxSYS_CAPTION_Y: + // TODO case wxSYS_MENU_Y: + // TODO case wxSYS_NETWORK_PRESENT: + // TODO case wxSYS_PENWINDOWS_PRESENT: + // TODO case wxSYS_SHOW_SOUNDS: + // TODO case wxSYS_SWAP_BUTTONS: + default: - return 0; + break; } - return 0; + return -1; // unsupported metric } +bool wxSystemSettingsNative::HasFeature( wxSystemFeature index ) +{ + switch (index) + { + case wxSYS_CAN_ICONIZE_FRAME: + return true; + + // TODO case wxSYS_CAN_DRAW_FRAME_DECORATIONS: + // TODO case wxSYS_TABLET_PRESENT: + + default: + break; + } + + return false; +}