先介绍一下单词metric,作为名词的时候有“度量标准,度量”的意思。所以system metric的意思是“系统度量单位”。
接下来就要介绍一下
GetSystemMetrics
函数。
功能:得到被定义的系统数据或者系统配置信息。
语法:
int WINAPI GetSystemMetrics(_in int nIndex);
参数:
只有一个参数index,我们称之为索引。这个索引有75个标识符,部分如下:
SM_CXSCREEN = 0 'X Size of screen
SM_CYSCREEN = 1 'Y Size of Screen
SM_CXVSCROLL = 2 'X Size of arrow in vertical scroll bar.
SM_CYHSCROLL = 3 'Y Size of arrow in horizontal scroll bar
SM_CYCAPTION = 4 'Height of windows caption
SM_CXBORDER = 5 'Width of no-sizable borders
SM_CYBORDER = 6 'Height of non-sizable borders
SM_CXDLGFRAME = 7 'Width of dialog box borders
SM_CYDLGFRAME = 8 'Height of dialog box borders
SM_CYHTHUMB = 9 'Height of scroll box on horizontal scroll bar
SM_CXHTHUMB = 10 ' Width of scroll box on horizontal scroll bar
SM_CXICON = 11 'Width of standard icon
SM_CYICON = 12 'Height of standard icon
SM_CXCURSOR = 13 'Width of standard cursor
SM_CYCURSOR = 14 'Height of standard cursor
SM_CYMENU = 15 'Height of menu
SM_CXFULLSCREEN = 16 'Width of client area of maximized window
SM_CYFULLSCREEN = 17 'Height of client area of maximized window
SM_CYKANJIWINDOW = 18 'Height of Kanji window
SM_MOUSEPRESENT = 19 'True is a mouse is present
SM_CYVSCROLL = 20 'Height of arrow in vertical scroll bar
SM_CXHSCROLL = 21 'Width of arrow in vertical scroll bar
SM_DEBUG = 22 'True if deugging version of windows is running
SM_SWAPBUTTON = 23 'True if left and right buttons are swapped.
SM_CXMIN = 28 'Minimum width of window
SM_CYMIN = 29 'Minimum height of window
SM_CXSIZE = 30 'Width of title bar bitmaps
SM_CYSIZE = 31 'height of title bar bitmaps
SM_CXMINTRACK = 34 'Minimum tracking width of window
SM_CYMINTRACK = 35 'Minimum tracking height of window
SM_CXDOUBLECLK = 36 'double click width
SM_CYDOUBLECLK = 37 'double click height
SM_CXICONSPACING = 38 'width between desktop icons
SM_CYICONSPACING = 39 'height between desktop icons
SM_MENUDROPALIGNMENT = 40 'Zero if popup menus are aligned to the left of the memu bar item. True if it is aligned to the right.
SM_PENWINDOWS = 41 'The handle of the pen windows DLL if loaded.
SM_DBCSENABLED = 42 'True if double byte characteds are enabled
SM_CMOUSEBUTTONS = 43 'Number of mouse buttons.
SM_CMETRICS = 44 'Number of system metrics
SM_CLEANBOOT = 67 'Windows 95 boot mode. 0 = normal, 1 = safe, 2 = safe with network
SM_CXMAXIMIZED = 61 'default width of win95 maximised window
SM_CXMAXTRACK = 59 'maximum width when resizing win95 windows
SM_CXMENUCHECK = 71 'width of menu checkmark bitmap
SM_CXMENUSIZE = 54 'width of button on menu bar
SM_CXMINIMIZED = 57 'width of rectangle into which minimised windows must fit.
SM_CYMAXIMIZED = 62 'default height of win95 maximised window
SM_CYMAXTRACK = 60 'maximum width when resizing win95 windows
SM_CYMENUCHECK = 72 'height of menu checkmark bitmap
SM_CYMENUSIZE = 55 'height of button on menu bar
SM_CYMINIMIZED = 58 'height of rectangle into which minimised windows must fit.
SM_CYSMCAPTION = 51 'height of windows 95 small caption
SM_MIDEASTENABLED = 74 'Hebrw and Arabic enabled for windows 95
SM_NETWORK = 63 'bit o is set if a network is present.
SM_SECURE = 44 'True if security is present on windows 95 system
SM_SLOWMACHINE = 73 'true if machine is too slow to run win95.
所以我们就可以通过下面两条代码获得计算机的屏幕分辨率:
int m_nWindwMetricsX = ::GetSystemMetrics(SM_CXSCREEN);
int m_nWindwMetricsY = ::GetSystemMetrics(SM_CYSCREEN);
下面介绍一个结构体
DEVMODE
。
DEVMODE数据结构中包含了有关设备初始化和打印机环境的信息
DEVMODE结构具有如下形式:
typedef struct _devicemode
{
TCHAR dmDeviceName[32];
WORD dmSpecVersion;
WORD dmDriverVersion;
WORD dmSize;
WORD dmDriverExtra;
DWORD dmFields;
short dmOrientation;
short dmPaperSize;
short dmPaperLength;
short dmPaperWidth;
short dmScale;
short dmCopies;
short dmDefaultSource;
short dmPrintQuality;
short dmColor;
short dmDuplex;
short dmYResolution;
short dmTTOption;
short dmCollate;
TCHAR dmFormName[32];
WORD dmUnusedPadding;
USHORT dmBitsPerPel;
DWORD dmPelsWidth;
DWORD dmPelsHeight;
DWORD dmDisplayFlags;
DWORD dmDisplayFrequency;
} DEVMODE;
部分成员介绍:
dmDeviceName 指定了驱动程序支持的设备名称;例如,对于PCL/HP LaserJet系列,会是CL/HP激光打印机。这个字符串在设备驱动程序之间是相互不同的。
dmSpecVersion 指定了初始化数据的版本数字,这个结构就基于这些数据。
dmDriverVersion 指定了打印机驱动程序开发商分配的打印机驱动程序版本号。
dmSize 指定了DEVMODE结构的大小,以字节为单位,不包括dmDriverData(与设备有关)成员。如果应用程序仅操作数据中与驱动程序无关的部分,它就可以使用这个成员以确定该结构的长度,而并不需要有不同版本的记录。
dmDriverExtra 包含了这个结构后面的私有驱动程序数据的数目,以字节为单位。如果设备驱动程序不使用该设备独有的信息,就把这个成员设为零。
dmFields 指定了DEVMODE结构的其余成员中哪些已被初始化。第0位(定义为DM)ORIENTATION)代表dmOrientation,第1位(定义为 DM_PAPERSIZE)代表dmPaperSize等等。打印机驱动出现仅支持那些适合打印技术的成员。
dmOrientation 选择纸的方向。
dmPaperLength 重定义由dmPaperSize成员指定的纸张长度,可用于自定义纸张大小,也可以用于点阵打印机,这种打印机能打出任意长度的纸张。这些值与这个结构中其他指定物理长度的值都是以0.1毫米为单位的。
dmPaperWidth 重载由dmPaperSize成员指定的纸张宽度。
dmScale 指定了打印输出的缩放因子。实际的页面大小为物理纸张的大小乘以dmScale/100。例如,对于信纸大小的纸张,如果dmScale的值为50,它将可以容纳相当于17×22英寸页面的内容,因为输出的文本和图形的宽、高都将是原始大小的一半。
dmCopies 如果设备支持多页拷贝,则选择了要打印的拷贝数目。
dmDefaultSource 保留,必须为0。
dmPrintQuality 指定了打印机的分辨率。有四种预定义的与设备无关的值:
DMRES_HIGH
DMRES_MEDIUM
DMRES_LOW
DMRES_DRAFT
如果给定了一个正值,它就指定了每英寸打印的点数(DPI),因此是与设备有关的。
dmColor 对于彩色打印机,在彩色和单色之间切换。下面是可能的取值:
·DMCOLOR_COLOR
·DMCOLOR_MONOCHROME
dmDuplex 为支持双面打印的打印机选择双面打印方式。可能的取值如下:
·DMDUP_SIMPLEX
·DMDUP_HORIZONTAL
·DMDUP_VERTICAL
dmBitsPerPel 指定了显示设备的颜色分辨率,以像素的位数为单位。例如,16色使用4位,256色使用8位,而65536色使用16位。
dmPelsWidth 指定了可见设备表面的以像素为单位的宽度。
dmPelsHeight指定了可见设备表面的以像素为单位的高度。
dmDisplayFlags 指定了设备的显示模式。下面是有效的标志: · DM_GRAYSCALE 指定显示使用了无颜色设备。如果没有设置这个标志,就假定彩色模式。
· DM_INTERLACED 指定了隔行显示模式。如果没有设置这个标志,就假定非隔行模式。
dmDisplayFrequency 指定了显示设备的特定模式所使用的以赫兹为单位的频率(每秒的周期数)。
修改屏幕分辨率,我们需要设置的参数有
dmBitsPerPel
(指定了显示设备的颜色分辨率)、
dmPelsWidth
(指定了可见设备表面的以像素为单位的宽度)、
dmPelsHeight
(指定了可见设备表面的以像素为单位的高度)、
dmSize
(指定了DEVMODE结构的大小)、
dmFields
(指定了DEVMODE结构的其余成员中哪些已被初始化以字节为单位)。代码如下:
DEVMODE lpDevMode
lpDevMode.dmBitsPerPel=32
lpDevMode.dmPelsWidth=1024
lpDevMode.dmPelsHeight=768
lpDevMode.dmSize=sizeof(lpDevMode)
lpDevMode.dmFields =DM_PELSWIDTH|DM_PELSHEIGHT|DM_BITSPERPEL
下面介绍另一个函数
ChangeDisplaySettings
。
msdn上是这样描述的:change the settings of the default display device to specified graphics mode.
语法:
Long ChangeDisplaySettings(_in DEVMODE *lpDevMode, _in DWORD dwflags);
参数:
lpDevMode 指向DEVMODE结构体的指针。
dwflags 表明了图形模式如何改变,具体取值可以查看msdn。
返回值:
DISP_CHANGE_SUCCESSFUL:设备改变成功。
DISP_CHANGE_RESTART:为使图形模式生效计算机必须重新启动。
DISP_CHANGE_BADFLAGS:标志的无效设置被传送。
DISP_CHANGE_NOTUPDATED:在WindowsNT中不能把设置写入注册表。
DISP_CHANGE_BADPARAM:一个无效的参数被传递。它可以包括一个无效的标志或标志的组合。
DISP_CHANGE_FAILED:指定图形模式的显示驱动失效。
DISP_CHANGE_BADMODE:不支持图形模式。
有了以上基础知识,下面开始我们的程序编写。
首先新建一个win32项目,添加一个.cpp文件,键入代码:
#include<Windows.h>
int CALLBACK WinMain( __in HINSTANCE hInstance, __in_opt HINSTANCE hPrevInstance, __in LPSTR lpCmdLine, __in int nShowCmd )
int m_nWindwMetricsX = ::GetSystemMetrics(SM_CXSCREEN);
int m_nWindwMetricsY = ::GetSystemMetrics(SM_CYSCREEN);
char charX[20];
itoa(m_nWindwMetricsX, charX, 10);
MessageBox(NULL, charX, "分辨率",MB_OK);
DEVMODE lpDevMode;
lpDevMode.dmBitsPerPel=32;
lpDevMode.dmPelsWidth=1024;
lpDevMode.dmPelsHeight=768;
lpDevMode.dmSize=sizeof(lpDevMode);
lpDevMode.dmFields =DM_PELSWIDTH|DM_PELSHEIGHT|DM_BITSPERPEL;
LONG result;
result=ChangeDisplaySettings(&lpDevMode,0);
if (result==DISP_CHANGE_SUCCESSFUL)
MessageBox(NULL,"修改成功!", "修改", MB_OK);
ChangeDisplaySettings(&lpDevMode,CDS_UPDATEREGISTRY);
MessageBox(NULL, "修改失败,恢复原有设置!", "修改", MB_OK);
ChangeDisplaySettings(NULL,0);
return 0;
一、多机型 UI 适配
在 Android 开发的工作日常中,UI 适配是一件比较重要的事情。一般开发新的功能,有新的页面,最终开发完成发布之前,都需要让设计师来审 UI 效果。
而有时候,明明我们已经在一款标准的 3 倍手...
qiAndroid实际开发中会遇到各种各样的机型,所以就需要对多种机型进行适配。常见的适配在这类就不详细介绍了,大家可以参考这里的系列文章Android通用屏幕适配讲解的已经很详细了。下面说的是:当修改系统的字体大小、显示大小、默认分辨率的情况下,如何明智的进行适配。
一、修改系统字体大小与显示大小:
设置--->显示--->字体与显示大小:
会看到有如下两项:
DISPLAY_DEVICE ddDisplay;
ZeroMemory(&ddDisplay, sizeof(ddDisplay));
ddDisplay.cb = sizeof(ddDisplay);
DEVMODE dm;
ZeroMemory(&dm, sizeof(dm));
在头文件中添加
#include <window.h>
DEVMODE DevMode; EnumDisplaySettings(NULL, ENUM_CURRENT_SETTINGS, &DevMode); DevMode.dmFields = DM_PELSWIDTH | DM_PELSHEIGHT; DevMode.dmPelsWidth = 80...
GetSystemMetrics Function详细的说明请看MSDN,这里只给出我用的一些:
int WINAPI GetSystemMetrics( __in int nIndex);
返回的单位都是像数值。
import win32api
print(win32api.GetSystemMetrics(win32con.SM_CXSCREEN))
print(win32api.GetSystemMetrics(win32con.SM_CYSCREEN))
# 1536 864
发现一个很有趣的现象,调用window api ,查看屏幕分辨率,得出的分辨率大小和实际的不相符
这个大小实际上是真实分辨率大小的80%
但是使用tk查看的分辨率大小是和实际分辨率大小一致的。
而tk本质上就是调用了这个api函
//加载系统库user32.dll
HMODULE hUser32 = LoadLibrary(TEXT("user32.dll"));
SetProcessDPIAwareFn *ptr;
int hdpi, vdpi;
HDC desktopDC;
//获取SetProcessDPIAware系统函数地址
ptr ...
使用python中win32api.GetSystemMetrics库获取屏幕分辨率,import时,为防止与其他库冲突,需要将导入的库放置在较前的位置
-- coding: utf-8 --
import datetime
import os
import win32api
fpi=win32api.GetSystemMetrics(0)
from PIL import Image
......
本人机器1920*1080 DPI:150%
GetSystemMetrics 取得的值是1280*720invoke GetSystemMetrics,SM_CXSCREEN ;获取屏幕分辨率
mov resX,eax
invoke GetSystemMetrics,SM_CYSCREEN
mov resY,eax换GetDeviceCaps可以获得物理分辨率
完整代码如下; MASM32 p
所编辑的内容均从该文档中翻译提取,并加上自己的描述:
http://search.cpan.org/~robertmay/Win32-GUI-1.06/docs/GUI/Tutorial/Part1.pod
如果已经安装Win32
今天介绍一下,windows客户端开发中,屏幕分辨率,以及屏幕客户区大小的获得方法。GetSystemMetrics
函数功能:用于得到被定义的系统数据或者系统配置信息函数原型:int WINAPIGetSystemMetrics(int nIndex);nIndex可取值:#define SM_CXSCREEN 0#define SM_CYSCREEN