extract wrapper for SystemParametersInfo(SPI_GETNONCLIENTMETRICS) in a header so that it could be reused from elsewhere
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@55472 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
49
include/wx/msw/private/metrics.h
Normal file
49
include/wx/msw/private/metrics.h
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Name: wx/msw/private/metrics.h
|
||||||
|
// Purpose: various helper functions to retrieve system metrics
|
||||||
|
// Author: Vadim Zeitlin
|
||||||
|
// Created: 2008-09-05
|
||||||
|
// RCS-ID: $Id$
|
||||||
|
// Copyright: (c) 2008 Vadim Zeitlin <vadim@wxwidgets.org>
|
||||||
|
// Licence: wxWindows licence
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
#ifndef _WX_MSW_PRIVATE_METRICS_H_
|
||||||
|
#define _WX_MSW_PRIVATE_METRICS_H_
|
||||||
|
|
||||||
|
namespace wxMSWImpl
|
||||||
|
{
|
||||||
|
|
||||||
|
// return NONCLIENTMETRICS as retrieved by SystemParametersInfo()
|
||||||
|
//
|
||||||
|
// currently this is not cached as the values may change when system settings
|
||||||
|
// do and we don't react to this to invalidate the cache but it could be done
|
||||||
|
// in the future
|
||||||
|
//
|
||||||
|
// MT-safety: this function is only meant to be called from the main thread
|
||||||
|
inline const NONCLIENTMETRICS& GetNonClientMetrics()
|
||||||
|
{
|
||||||
|
static WinStruct<NONCLIENTMETRICS> nm;
|
||||||
|
if ( !::SystemParametersInfo(SPI_GETNONCLIENTMETRICS, 0, &nm, 0) )
|
||||||
|
{
|
||||||
|
#if WINVER >= 0x0600
|
||||||
|
// a new field has been added to NONCLIENTMETRICS under Vista, so
|
||||||
|
// the call to SystemParametersInfo() fails if we use the struct
|
||||||
|
// size incorporating this new value on an older system -- retry
|
||||||
|
// without it
|
||||||
|
nm.cbSize -= sizeof(int);
|
||||||
|
if ( !::SystemParametersInfo(SPI_GETNONCLIENTMETRICS, 0, &nm, 0) )
|
||||||
|
#endif // WINVER >= 0x0600
|
||||||
|
{
|
||||||
|
// maybe we should initialize the struct with some defaults?
|
||||||
|
wxLogLastError(_T("SystemParametersInfo(SPI_GETNONCLIENTMETRICS)"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return nm;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace wxMSWImpl
|
||||||
|
|
||||||
|
#endif // _WX_MSW_PRIVATE_METRICS_H_
|
||||||
|
|
@@ -35,6 +35,7 @@
|
|||||||
#include "wx/fontutil.h"
|
#include "wx/fontutil.h"
|
||||||
|
|
||||||
#include "wx/msw/private.h"
|
#include "wx/msw/private.h"
|
||||||
|
#include "wx/msw/private/metrics.h"
|
||||||
#include "wx/msw/dc.h"
|
#include "wx/msw/dc.h"
|
||||||
|
|
||||||
#ifndef SPI_GETKEYBOARDCUES
|
#ifndef SPI_GETKEYBOARDCUES
|
||||||
@@ -87,33 +88,11 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static NONCLIENTMETRICS GetNCM()
|
|
||||||
{
|
|
||||||
WinStruct<NONCLIENTMETRICS> nm;
|
|
||||||
if ( !::SystemParametersInfo(SPI_GETNONCLIENTMETRICS, 0, &nm, 0) )
|
|
||||||
{
|
|
||||||
#if WINVER >= 0x0600
|
|
||||||
// a new field has been added to NONCLIENTMETRICS under Vista, so
|
|
||||||
// the call to SystemParametersInfo() fails if we use the struct
|
|
||||||
// size incorporating this new value on an older system -- retry
|
|
||||||
// without it
|
|
||||||
nm.cbSize -= sizeof(int);
|
|
||||||
if ( !::SystemParametersInfo(SPI_GETNONCLIENTMETRICS, 0, &nm, 0) )
|
|
||||||
#endif // WINVER >= 0x0600
|
|
||||||
{
|
|
||||||
// maybe we should initialize the struct with some defaults?
|
|
||||||
wxLogLastError(_T("SystemParametersInfo(SPI_GETNONCLIENTMETRICS)"));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return nm;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void DoInitMetrics()
|
static void DoInitMetrics()
|
||||||
{
|
{
|
||||||
// iMenuHeight is the menu bar height and the menu items are less tall,
|
// iMenuHeight is the menu bar height and the menu items are less tall,
|
||||||
// although I don't know by how much -- below is the value for my system
|
// although I don't know by how much -- below is the value for my system
|
||||||
ms_systemMenuHeight = GetNCM().iMenuHeight - 4;
|
ms_systemMenuHeight = wxMSWImpl::GetNonClientMetrics().iMenuHeight - 4;
|
||||||
|
|
||||||
wxASSERT_MSG( ms_systemMenuHeight > 0,
|
wxASSERT_MSG( ms_systemMenuHeight > 0,
|
||||||
"menu height should be positive" );
|
"menu height should be positive" );
|
||||||
@@ -129,7 +108,8 @@ private:
|
|||||||
|
|
||||||
static void DoInitFont()
|
static void DoInitFont()
|
||||||
{
|
{
|
||||||
ms_systemMenuFont = new wxFont(wxNativeFontInfo(GetNCM().lfMenuFont));
|
ms_systemMenuFont = new
|
||||||
|
wxFont(wxNativeFontInfo(wxMSWImpl::GetNonClientMetrics().lfMenuFont));
|
||||||
}
|
}
|
||||||
|
|
||||||
static wxFont* ms_systemMenuFont;
|
static wxFont* ms_systemMenuFont;
|
||||||
|
Reference in New Issue
Block a user