1 /////////////////////////////////////////////////////////////////////////////
2 // Name: msw/settings.cpp
3 // Purpose: wxSystemSettingsNative implementation for MSW
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart and Markus Holzem
9 // Licence: wxWindows license
10 /////////////////////////////////////////////////////////////////////////////
12 // ============================================================================
14 // ============================================================================
16 // ----------------------------------------------------------------------------
18 // ----------------------------------------------------------------------------
20 // For compilers that support precompilation, includes "wx.h".
21 #include "wx/wxprec.h"
29 #include "wx/gdicmn.h"
32 #include "wx/settings.h"
34 #include "wx/msw/private.h"
36 #ifndef SPI_GETFLATMENU
37 #define SPI_GETFLATMENU 0x1022
40 #include "wx/module.h"
41 #include "wx/fontutil.h"
43 // ----------------------------------------------------------------------------
45 // ----------------------------------------------------------------------------
47 // the module which is used to clean up wxSystemSettingsNative data (this is a
48 // singleton class so it can't be done in the dtor)
49 class wxSystemSettingsModule
: public wxModule
52 virtual bool OnInit();
53 virtual void OnExit();
56 DECLARE_DYNAMIC_CLASS(wxSystemSettingsModule
)
59 // ----------------------------------------------------------------------------
61 // ----------------------------------------------------------------------------
63 // the font returned by GetFont(wxSYS_DEFAULT_GUI_FONT): it is created when
64 // GetFont() is called for the first time and deleted by wxSystemSettingsModule
65 static wxFont
*gs_fontDefault
= NULL
;
67 // ============================================================================
69 // ============================================================================
71 // TODO: see ::SystemParametersInfo for all sorts of Windows settings.
72 // Different args are required depending on the id. How does this differ
73 // from GetSystemMetric, and should it? Perhaps call it GetSystemParameter
74 // and pass an optional void* arg to get further info.
75 // Should also have SetSystemParameter.
76 // Also implement WM_WININICHANGE (NT) / WM_SETTINGCHANGE (Win95)
78 // ----------------------------------------------------------------------------
79 // wxSystemSettingsModule
80 // ----------------------------------------------------------------------------
82 IMPLEMENT_DYNAMIC_CLASS(wxSystemSettingsModule
, wxModule
)
84 bool wxSystemSettingsModule::OnInit()
89 void wxSystemSettingsModule::OnExit()
91 delete gs_fontDefault
;
92 gs_fontDefault
= NULL
;
95 // ----------------------------------------------------------------------------
96 // wxSystemSettingsNative
97 // ----------------------------------------------------------------------------
99 // ----------------------------------------------------------------------------
101 // ----------------------------------------------------------------------------
103 wxColour
wxSystemSettingsNative::GetColour(wxSystemColour index
)
105 // we use 0 as the default value just to avoid compiler warnings, as there
106 // is no invalid colour value we use hasCol as the real indicator of
107 // whether colSys was initialized or not
111 // the default colours for the entries after BTNHIGHLIGHT
112 static const COLORREF s_defaultSysColors
[] =
114 0x000000, // 3DDKSHADOW
116 0x000000, // INFOTEXT
119 0, // filler - no std colour with this index
121 // TODO: please fill in the standard values of those, I don't have them
123 0, // GRADIENTACTIVECAPTION
124 0, // GRADIENTINACTIVECAPTION
126 0, // MENUBAR (unused)
129 if ( index
== wxSYS_COLOUR_LISTBOX
)
131 // there is no standard colour with this index, map to another one
132 index
= wxSYS_COLOUR_WINDOW
;
134 else if ( index
> wxSYS_COLOUR_BTNHIGHLIGHT
)
136 // the indices before BTNHIGHLIGHT are understood by GetSysColor() in
137 // all Windows version, for the other ones we have to check
140 // none of the is supported under Win16 anyhow
143 wxGetOsVersion(&verMaj
, &verMin
);
149 else if ( verMaj
== 4 )
152 useDefault
= index
> wxSYS_COLOUR_INFOBK
;
154 else if ( verMaj
== 5 && verMin
== 0 )
157 useDefault
= index
> wxSYS_COLOUR_GRADIENTINACTIVECAPTION
;
163 // Determine if we are using flat menus, only then allow wxSYS_COLOUR_MENUBAR
164 if ( index
== wxSYS_COLOUR_MENUBAR
)
167 if ( SystemParametersInfo( SPI_GETFLATMENU
, 0 ,&isFlat
, 0 ) )
170 index
= wxSYS_COLOUR_MENU
;
180 // special handling for MENUBAR colour: we use this in wxToolBar
181 // and wxStatusBar to have correct bg colour under Windows XP
182 // (which uses COLOR_MENUBAR for them) but they should still look
183 // correctly under previous Windows versions as well
184 if ( index
== wxSYS_COLOUR_MENUBAR
)
186 index
= wxSYS_COLOUR_3DFACE
;
188 else // replace with default colour
190 unsigned int n
= index
- wxSYS_COLOUR_BTNHIGHLIGHT
;
192 wxASSERT_MSG( n
< WXSIZEOF(s_defaultSysColors
),
193 _T("forgot tp update the default colours array") );
195 colSys
= s_defaultSysColors
[n
];
203 colSys
= ::GetSysColor(index
);
206 return wxRGBToColour(colSys
);
209 // ----------------------------------------------------------------------------
211 // ----------------------------------------------------------------------------
213 wxFont
wxCreateFontFromStockObject(int index
)
217 HFONT hFont
= (HFONT
) ::GetStockObject(index
);
221 if ( ::GetObject(hFont
, sizeof(LOGFONT
), &lf
) != 0 )
223 wxNativeFontInfo info
;
225 // Under MicroWindows we pass the HFONT as well
226 // because it's hard to convert HFONT -> LOGFONT -> HFONT
227 // It's OK to delete stock objects, the delete will be ignored.
228 #ifdef __WXMICROWIN__
229 font
.Create(info
, (WXHFONT
) hFont
);
236 wxFAIL_MSG( _T("failed to get LOGFONT") );
239 else // GetStockObject() failed
241 wxFAIL_MSG( _T("stock font not found") );
247 wxFont
wxSystemSettingsNative::GetFont(wxSystemFont index
)
249 // wxWindow ctor calls GetSystemFont(wxSYS_DEFAULT_GUI_FONT) so we're
250 // called fairly often - this is why we cache this particular font
251 bool isDefaultRequested
= index
== wxSYS_DEFAULT_GUI_FONT
;
252 if ( isDefaultRequested
&& gs_fontDefault
)
254 return *gs_fontDefault
;
257 wxFont font
= wxCreateFontFromStockObject(index
);
259 if ( isDefaultRequested
)
261 // if we got here it means we hadn't cached it yet - do now
262 gs_fontDefault
= new wxFont(font
);
268 // ----------------------------------------------------------------------------
269 // system metrics/features
270 // ----------------------------------------------------------------------------
272 // TODO: some of the "metrics" clearly should be features now that we have
275 // the conversion table from wxSystemMetric enum to GetSystemMetrics() param
277 // if the constant is not defined, put -1 in the table to indicate that it is
279 static const int gs_metricsMap
[] =
281 -1, // wxSystemMetric enums start at 1, so give a dummy value for pos 0.
294 #if defined(__WIN32__) && defined(SM_CXDRAG)
314 #if defined(__WIN32__) && defined(SM_CXSIZEFRAME)
329 #if defined(__WIN32__) && defined(SM_NETWORK)
335 #if defined(__WIN32__) && defined(SM_SHOWSOUNDS)
343 // Get a system metric, e.g. scrollbar size
344 int wxSystemSettingsNative::GetMetric(wxSystemMetric index
)
346 #ifdef __WXMICROWIN__
347 // TODO: probably use wxUniv themes functionality
349 #else // !__WXMICROWIN__
350 wxCHECK_MSG( index
> 0 && (size_t)index
< WXSIZEOF(gs_metricsMap
), 0,
351 _T("invalid metric") );
353 int indexMSW
= gs_metricsMap
[index
];
354 if ( indexMSW
== -1 )
356 // not supported under current system
360 int rc
= ::GetSystemMetrics(indexMSW
);
361 if ( index
== wxSYS_NETWORK_PRESENT
)
363 // only the last bit is significant according to the MSDN
368 #endif // __WXMICROWIN__/!__WXMICROWIN__
371 bool wxSystemSettingsNative::HasFeature(wxSystemFeature index
)
375 case wxSYS_CAN_ICONIZE_FRAME
:
376 case wxSYS_CAN_DRAW_FRAME_DECORATIONS
:
380 wxFAIL_MSG( _T("unknown system feature") );