X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/0e320a79f187558effb04d92020b470372bbe456..8290d43d0d43369d007f1c47abf98a45da461a30:/src/os2/settings.cpp diff --git a/src/os2/settings.cpp b/src/os2/settings.cpp index 2beda5c2a6..55da0d4963 100644 --- a/src/os2/settings.cpp +++ b/src/os2/settings.cpp @@ -1,25 +1,164 @@ ///////////////////////////////////////////////////////////////////////////// // Name: settings.cpp // Purpose: wxSettings -// Author: AUTHOR +// Author: David Webster // Modified by: -// Created: ??/??/98 +// Created: 10/15/99 // RCS-ID: $Id$ -// Copyright: (c) AUTHOR -// Licence: wxWindows licence +// Copyright: (c) David Webster +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ -#pragma implementation "settings.h" +// For compilers that support precompilation, includes "wx.h". +#include "wx/wxprec.h" + +#ifndef WX_PRECOMP +#include +#include "wx/defs.h" +#include "wx/pen.h" +#include "wx/brush.h" +#include "wx/gdicmn.h" #endif #include "wx/settings.h" +#include "wx/window.h" +#include "wx/os2/private.h" -wxColour wxSystemSettings::GetSystemColour(int index) +wxColour wxSystemSettings::GetSystemColour( + int nIndex +) { - // TODO - return wxColour(); -} + 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) + ); + return vCol; + break; + + case wxSYS_COLOUR_WINDOWFRAME: + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP + ,SYSCLR_WINDOWFRAME + ,0L + ); + vCol.Set( GetRValue(vRef) + ,GetGValue(vRef) + ,GetBValue(vRef) + ); + return vCol; + 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) + ); + return vCol; + break; + + case wxSYS_COLOUR_BTNSHADOW: + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP + ,SYSCLR_BUTTONMIDDLE + ,0L + ); + vCol.Set( GetRValue(vRef) + ,GetGValue(vRef) + ,GetBValue(vRef) + ); + return vCol; + break; + + case wxSYS_COLOUR_BTNHIGHLIGHT: + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP + ,SYSCLR_BUTTONLIGHT + ,0L + ); + vCol.Set( GetRValue(vRef) + ,GetGValue(vRef) + ,GetBValue(vRef) + ); + return vCol; + 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: + return(*wxBLACK); + break; + + // + // We should customize these to look like other ports + // + + case wxSYS_COLOUR_ACTIVECAPTION: + case wxSYS_COLOUR_ACTIVEBORDER: + case wxSYS_COLOUR_HIGHLIGHT: + return(*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: + return(*wxLIGHT_GREY); + break; + + default: + vRef = (ULONG)::WinQuerySysColor( HWND_DESKTOP + ,SYSCLR_WINDOW + ,0L + ); + vCol.Set( GetRValue(vRef) + ,GetGValue(vRef) + ,GetBValue(vRef) + ); + return vCol; + break; + } + return(vCol); +} // end of wxSystemSettings::GetSystemColour wxFont wxSystemSettings::GetSystemFont(int index) { @@ -55,122 +194,122 @@ wxFont wxSystemSettings::GetSystemFont(int index) // Get a system metric, e.g. scrollbar size int wxSystemSettings::GetSystemMetric(int index) { - switch ( index) - { + switch ( index) + { case wxSYS_MOUSE_BUTTONS: // TODO - return 0; + return 0; case wxSYS_BORDER_X: // TODO - return 0; + return 0; case wxSYS_BORDER_Y: // TODO - return 0; + return 0; case wxSYS_CURSOR_X: // TODO - return 0; + return 0; case wxSYS_CURSOR_Y: // TODO - return 0; + return 0; case wxSYS_DCLICK_X: // TODO - return 0; + return 0; case wxSYS_DCLICK_Y: // TODO - return 0; + return 0; case wxSYS_DRAG_X: // TODO - return 0; + return 0; case wxSYS_DRAG_Y: // TODO - return 0; + return 0; case wxSYS_EDGE_X: // TODO - return 0; + return 0; case wxSYS_EDGE_Y: // TODO - return 0; + return 0; case wxSYS_HSCROLL_ARROW_X: // TODO - return 0; + return 0; case wxSYS_HSCROLL_ARROW_Y: // TODO - return 0; + return 0; case wxSYS_HTHUMB_X: // TODO - return 0; + return 0; case wxSYS_ICON_X: // TODO - return 0; + return 0; case wxSYS_ICON_Y: // TODO - return 0; + return 0; case wxSYS_ICONSPACING_X: // TODO - return 0; + return 0; case wxSYS_ICONSPACING_Y: // TODO - return 0; + return 0; case wxSYS_WINDOWMIN_X: // TODO - return 0; + return 0; case wxSYS_WINDOWMIN_Y: // TODO - return 0; + return 0; case wxSYS_SCREEN_X: // TODO - return 0; + return 0; case wxSYS_SCREEN_Y: // TODO - return 0; + return 0; case wxSYS_FRAMESIZE_X: // TODO - return 0; + return 0; case wxSYS_FRAMESIZE_Y: // TODO - return 0; + return 0; case wxSYS_SMALLICON_X: // TODO - return 0; + return 0; case wxSYS_SMALLICON_Y: // TODO - return 0; + return 0; case wxSYS_HSCROLL_Y: // TODO - return 0; + return 0; case wxSYS_VSCROLL_X: // TODO - return 0; + return 0; case wxSYS_VSCROLL_ARROW_X: // TODO - return 0; + return 0; case wxSYS_VSCROLL_ARROW_Y: // TODO - return 0; + return 0; case wxSYS_VTHUMB_Y: // TODO - return 0; + return 0; case wxSYS_CAPTION_Y: // TODO - return 0; + return 0; case wxSYS_MENU_Y: // TODO - return 0; + return 0; case wxSYS_NETWORK_PRESENT: // TODO - return 0; + return 0; case wxSYS_PENWINDOWS_PRESENT: // TODO - return 0; + return 0; case wxSYS_SHOW_SOUNDS: // TODO - return 0; + return 0; case wxSYS_SWAP_BUTTONS: // TODO - return 0; - default: - return 0; - } - return 0; + return 0; + default: + return 0; + } + return 0; }