X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/0af4b6e41d2d7a9590282ec620fdbce0bf021f8a..107d0fd493dc4d750ba18518a2eea5b93d988965:/src/motif/settings.cpp?ds=sidebyside diff --git a/src/motif/settings.cpp b/src/motif/settings.cpp index a29bffc9b2..9d48c86052 100644 --- a/src/motif/settings.cpp +++ b/src/motif/settings.cpp @@ -13,15 +13,41 @@ // per-user file, which can be edited using a Windows-control-panel clone. // Also they should be documented better. Some are very MS Windows-ish. -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma implementation "settings.h" #endif +// For compilers that support precompilation, includes "wx.h". +#include "wx/wxprec.h" + #include "wx/settings.h" #include "wx/gdicmn.h" +#include "wx/app.h" + +#ifdef __VMS__ +#pragma message disable nosimpint +#endif +#include +#include +#ifdef __VMS__ +#pragma message enable nosimpint +#endif + +#include "wx/x11/privx.h" + +// To correctly read the resources from the database, we create a +// sample widget. This has the application shell as the parent and +// so will be destroyed when the applicaion is closed. +static Widget but_setting_wid = NULL; wxColour wxSystemSettingsNative::GetColour(wxSystemColour index) { + if (NULL == but_setting_wid && wxTheApp && wxTheApp->GetTopLevelWidget()) + { + but_setting_wid = XtVaCreateWidget("settings_button", xmPushButtonWidgetClass, + (Widget)wxTheApp->GetTopLevelWidget(), NULL); + } + switch (index) { case wxSYS_COLOUR_WINDOW: @@ -34,6 +60,7 @@ wxColour wxSystemSettingsNative::GetColour(wxSystemColour index) case wxSYS_COLOUR_ACTIVECAPTION: case wxSYS_COLOUR_INACTIVECAPTION: case wxSYS_COLOUR_MENU: + case wxSYS_COLOUR_MENUBAR: case wxSYS_COLOUR_WINDOWFRAME: case wxSYS_COLOUR_ACTIVEBORDER: case wxSYS_COLOUR_INACTIVEBORDER: @@ -41,7 +68,18 @@ wxColour wxSystemSettingsNative::GetColour(wxSystemColour index) // case wxSYS_COLOUR_3DFACE: // Same as wxSYS_COLOUR_BTNFACE case wxSYS_COLOUR_GRAYTEXT: { - return wxColour("LIGHT GREY"); + if (but_setting_wid) + { + XColor bg; + XtVaGetValues(but_setting_wid, + XtVaTypedArg, XmNbackground, XtRColor, &bg, sizeof(bg), + NULL); + return wxColor(bg.red >> 8, bg.green >> 8, bg.blue >> 8); + } + else + { + return wxColour("LIGHT GREY"); + } } case wxSYS_COLOUR_BTNSHADOW: // case wxSYS_COLOUR_3DSHADOW: // Same as wxSYS_COLOUR_BTNSHADOW @@ -73,7 +111,18 @@ wxColour wxSystemSettingsNative::GetColour(wxSystemColour index) case wxSYS_COLOUR_BTNTEXT: case wxSYS_COLOUR_INFOTEXT: { - return *wxBLACK; + if (but_setting_wid) + { + XColor fg; + XtVaGetValues(but_setting_wid, + XtVaTypedArg, XmNforeground, XtRColor, &fg, sizeof(fg), + NULL); + return wxColor(fg.red >> 8, fg.green >> 8, fg.blue >> 8); + } + else + { + return *wxBLACK; + } } case wxSYS_COLOUR_HIGHLIGHTTEXT: { @@ -82,14 +131,24 @@ wxColour wxSystemSettingsNative::GetColour(wxSystemColour index) case wxSYS_COLOUR_INFOBK: case wxSYS_COLOUR_APPWORKSPACE: { - return wxColour("LIGHT GREY"); + if (but_setting_wid) + { + XColor bg; + XtVaGetValues(but_setting_wid, + XtVaTypedArg, XmNbackground, XtRColor, &bg, sizeof(bg), + NULL); + return wxColor(bg.red >> 8, bg.green >> 8, bg.blue >> 8); + } + else + { + return wxColour("LIGHT GREY"); + } } case wxSYS_COLOUR_HOTLIGHT: case wxSYS_COLOUR_GRADIENTACTIVECAPTION: case wxSYS_COLOUR_GRADIENTINACTIVECAPTION: case wxSYS_COLOUR_MENUHILIGHT: - case wxSYS_COLOUR_MENUBAR: // TODO return wxColour("LIGHT GREY"); @@ -125,87 +184,60 @@ wxFont wxSystemSettingsNative::GetFont(wxSystemFont index) // Get a system metric, e.g. scrollbar size int wxSystemSettingsNative::GetMetric(wxSystemMetric index) { + int return_value = 0; + switch ( index) { - 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: - // TODO - case wxSYS_SCREEN_X: - // TODO - case wxSYS_SCREEN_Y: - // TODO - case wxSYS_FRAMESIZE_X: - // TODO - case wxSYS_FRAMESIZE_Y: - // TODO - case wxSYS_SMALLICON_X: - // TODO - case wxSYS_SMALLICON_Y: - // TODO case wxSYS_HSCROLL_Y: - // TODO case wxSYS_VSCROLL_X: - // 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: - // TODO + return 15; + + case wxSYS_SCREEN_X: + return_value = DisplayWidth( wxGlobalDisplay(), 0 ); + break; + case wxSYS_SCREEN_Y: + return_value = DisplayHeight( wxGlobalDisplay(), 0 ); + break; + + // 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: + // TODO case wxSYS_FRAMESIZE_X: + // TODO case wxSYS_FRAMESIZE_Y: + // TODO case wxSYS_SMALLICON_X: + // TODO case wxSYS_SMALLICON_Y: + // 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_value = -1; // unsuported metric } - return 0; + return return_value; } bool wxSystemSettingsNative::HasFeature(wxSystemFeature index)