win32 API中GetSystemMetrics函数

1、
SM_ARRANGE:
用于说明系统如何安排最小化窗口,根据显示器的不同系统数据可能有所不同。其包含一个起始位置和方向。关于在程序中怎么使用我还没有见个这样的代码。

起始位置可为下列值之一:
ARW_BOTTOMLEFT:开始在左下角的屏幕(默认值)。
ARW_BOTTOMRIGHT:开始在右下角的屏幕(相当于ARW_STARTRIGHT)。
ARW_HIDE:在屏幕可见区域隐藏并最小化窗口。
ARW_TOPLEFT:从左上角的屏幕上(相当于ARW_STARTTOP)。
ARW_TOPRIGHT:开始在右上角的屏幕上(相当于ARW_STARTTOP |
ARW_STARTRIGHT)。

方向的安排可以为下列值之一:
ARW_DOWN:纵向排列从上到下。
ARW_UP     
:纵向排列从下到上。
ARW_LEFT :水平排列从左到右。
ARW_RIGHT:水平排列从右到左。

2、
SM_CLEANBOOT返回系统的启动方式。
0:正常启动。
1:安全模式启动。
2:网络安全模式启动。
代码例子:
nBoot = GetSystemMetrics(SM_CLEANBOOT);
   switch(nBoot)
   {
   case 0:
   
MessageBox(NULL,TEXT("正常启动系统!"),TEXT("提示"),MB_OK);
   
break;
   case 1:
   
MessageBox(NULL,TEXT("安全模式启动系统!"),TEXT("提示"),MB_OK);
   
break;
   case 2:
   
MessageBox(NULL,TEXT("网络安全模式启动系统!"),TEXT("提示"),MB_OK);
   
break;
   }

3、
SM_CMOUSEBUTTONS:返回值为系统支持的鼠标键数,返回0则系统中没有安装鼠标。
代码:
nMouseButton = GetSystemMetrics(SM_CMOUSEBUTTONS);
  
sprintf(szBuffer,"%d",nMouseButton);
  
MessageBox(NULL,szBuffer,TEXT("系统支持鼠标键数"),MB_OK |
MB_ICONINFORMATION);

4、
SM_CXBORDER、SM_CYBORDER:返回以像素值为单位的WINDOWS边框的宽度和高度,如果是3D形态,则等同于SM_CXEDGE。

代码:
int cxBorder = 0;
int cyBorder = 0;

cxBorder =
GetSystemMetrics(SM_CXBORDER);
   cyBorder =
GetSystemMetrics(SM_CYBORDER);

sprintf(szBuffer,"该窗口的边框长:%d、宽:%d",cxBorder,cyBorder);
  
MessageBox(NULL,szBuffer,TEXT("边框信息"),MB_OK);

5、
SM_CXCURSOR、SM_CYCURSOR:返回以像素为单位的标准光标的宽度和高度。
代码:
   int cxCursor = 0;
   int cyCursor = 0;

cxCursor = GetSystemMetrics(SM_CXCURSOR);
   cyCursor =
GetSystemMetrics(SM_CYCURSOR);

sprintf(szBuffer,"系统标准光标的宽度是:%d、高度是:%d",cxCursor,cyCursor);

MessageBox(NULL,szBuffer,TEXT("光标信息"),MB_OK);

6、
SM_CXDLGFRAME、SM_CYDLGFRAME:等同于SM_CXFIXEDFRAME、SM_CYFIXEDFRAME。

SM_CXFIXEDFRAME、SM_CYFIXEDFRAME:围绕具有标题,但不能改变尺寸的窗口(通常是对话框)的边框厚度。

//这里的厚度和上面边框的长度和宽度分别是窗口的那部分呢
//在我的系统上获得的值分别是cxBorder = cyBorder = 1;cxFrame = cyFrame =
3;
//希望知道的高手指点一下

cxFrame =
GetSystemMetrics(SM_CXDLGFRAME);
   cyFrame =
GetSystemMetrics(SM_CYDLGFRAME);

sprintf(szBuffer,"边框的厚度度是:%d、高度是:%d",cxFrame,cyFrame);
  
MessageBox(NULL,szBuffer,TEXT("边框信息"),MB_OK);

7、
SM_CXDOUBLECLK、SMCYDOUBLECLK:以像素值为单位的双击有效的矩形区域。
代码:
   int cxDoubleRect =
0;
   int cyDoubleRect =
0;

cxDoubleRect = GetSystemMetrics(SM_CXDOUBLECLK);
   cyDoubleRect =
GetSystemMetrics(SM_CYDOUBLECLK);

sprintf(szBuffer,"有效区域宽:%d、高:%d",cyDoubleRect,cyDoubleRect);

MessageBox(NULL,szBuffer,TEXT("有效区信息"),MB_OK);
//结果是cxDoubleRect = 4,cyDoubleRect = 4;

8、
SM_CXFRAME、SM_CYFRAME:等同于SM_CXSIZEFRAME、SM_CYSIZEFRAME
SM_CXSIZEFRAME、SM_CYSIZEFRAME:围绕可改变大小的窗口边框的厚度。

9、
SM_CXFULLSCREEN、SM_CYFULLSCREEN:全屏幕窗口的窗口区域的宽度和高度。

10、
SM_CXHSCROLL、SM_CYHSCROLL:水平滚动条的宽度和水平滚动条上箭头的高度。
代码:

int cxHscroll = 0;
   int cyHscroll = 0;

cxHscroll = GetSystemMetrics(SM_CXHSCROLL);
   cyHscroll =
GetSystemMetrics(SM_CYHSCROLL);

sprintf(szBuffer,"水平滚动条高度:%d、箭头高度:%d",cxHscroll,cyHscroll);

MessageBox(NULL,szBuffer,TEXT("TIP"),MB_OK);

11、
SM_CXHTHUMB:水平滚动条上滑块的宽度

12、
SM_CXICON、SM_CYICON:系统缺省的图标的宽度和高度(一般是32×32)。

13、
SM_CXICONSPACING、SM_CYICONSPACING:以大图标方式查看item时图标之间的距离,这个距离总是大于SM_CXICON和SM_CYICON。

14、
SM_CXMAXIMIZED、SM_CYMAXIMIZED:处于顶层的最大化窗口的缺省尺寸。

15、
SM_CXMAXTRACK、SM_CYMAXTRACK:具有可改变尺寸边框和标题栏窗口的缺省尺寸,如果窗口尺寸大于这个尺寸,窗口是不可移动的。

16、
SM_CXMENUCHECK、SM_CYMENUCHECK:以像素为单位计算菜单选中标记位图的尺寸。

17.、
SM_CXMENUSIZE、SM_CYMENUSIZE:以像素为单位计算菜单栏按钮的尺寸。

18、
SM_CXMIN、SM_CYMIN:窗口所能达到的最小尺寸。

19、
SM_CXMINIMIZED、SM_CYMINIMIZED、正常的最小化窗口的尺寸。

20、
SM_CXMINTRACK、SM_CYMINTRACK:最小跟踪距离,当拖动窗口距离小于这个值时,窗口不会移动。

21、
SM_CXSCREEN、SM_CYSCREEN:以像素为单位计算屏幕尺寸。

22、
SM_CXSIZE、SM_CYSIZE:以像素为单位计算标题栏按钮的尺寸。

23、
SM_CXSMICON、SM_CYSMICON:以像素计算的小图标的尺寸,小图标一般出现在标题栏上

24、
SM_CXVSCROLL,
SM_CYVSCROLL 以像素计算的垂直滚动条的宽度和垂直滚动条上箭头的高度

25、
SM_CYCAPTION 以像素计算的普通窗口标题的高度

26、
SM_CYMENU 以像素计算的单个菜单条的高度

27、
SM_CYSMCAPTION 以像素计算的窗口小标题栏的高度

28、
SM_CYVTHUMB 以像素计算的垂直滚动条中滚动块的高度

29、
SM_DBCSENABLED
如果为TRUE或不为0的值表明系统安装了双字节版本的USER.EXE,为FALSE或0则不是。

30、
SM_DEBUG
如果为TRUE或不为0的值表明系统安装了debug版本的USER.EXE,为FALSE或0则不是。

31、
SM_MENUDROPALIGNMENT
如果为TRUE或不为0的值下拉菜单是右对齐的否则是左对齐的。

32、
SM_MOUSEPRESENT 如果为TRUE或不为0的值则安装了鼠标,否则没有安装。

33、
SM_MOUSEWHEELPRESENT 如果为TRUE或不为0的值则安装了滚轮鼠标,否则没有安装。(Windows NT
only)。

34、
SM_SWAPBUTTON 如果为TRUE或不为0的值则鼠标左右键交换,否则没有。

时间: 2024-10-15 05:29:56

win32 API中GetSystemMetrics函数的相关文章

windows API中CreateWindow()函数详解

CreateWindow函数详解 在注册完窗口类后就需要进行窗口的创建,用到的函数理所当然就是CreateWindow(), 而这个函数是基于窗口类的,所以还需要指定几个参数来制定特定的窗口.而且像一些不带边框的窗口是怎么创建的也是具有相当的技巧的,就是创建的是不带标题和边框的窗口,然后自己在客户区绘制程序的内容,能够制作个性化的应用程序. API解释 该函数创建一个重叠式窗口.弹出式窗口或子窗口.它指定窗口类,窗口标题,窗口风格,以及窗口的初始位置及大小(可选的).函数也指该窗口的父窗口或所属

Win32 API中的user32.dll中的ShowWindow方法参数整理

在使用ShowWindow方法来设置窗体的状态时,由于不知道参数值,用起来非常容易混乱,所以整理了以下其参数的枚举值,方便以后的的使用.   public class User32API { #region ShowWindow 方法窗体状态的参数枚举 /// <summary> /// 隐藏窗口并激活其他窗口 /// </summary> public const int SW_HIDE = 0; /// <summary> /// 激活并显示一个窗口.如果窗口被最小

Win32 API之绘图函数

AbortPath 抛弃选入指定设备场景中的所有路径.也取消目前正在进行的任何路径的创建工作 AngleArc 用一个连接弧画一条线 Arc 画一个圆弧 BeginPath 启动一个路径分支 CancelDC 取消另一个线程里的长时间绘图操作 Chord 画一个弦 CloseEnhMetaFile 关闭指定的增强型图元文件设备场景,并将新建的图元文件返回一个句柄 CloseFigure 描绘到一个路径时,关闭当前打开的图形 CloseMetaFile 关闭指定的图元文件设备场景,并向新建的图元文

C# call Win32 api时,-1如何转换为DWORD

当使用(uint)-1时,编译器会给出警告:常量-1无法转换为uint,使用unchecked语句重写.DWORD在转换为C#类型时为uint,既然无法使用uint强制转型(-1),那就需要其他办法了.既然编译器给出的提示是使用unchecked语句重写,可以一试.之前没有使用过unchecked语句,所以不熟悉其用法.看了下参考文档,MSDN是这样描述unchecked的: The unchecked keyword is used to suppress overflow-checking

深入浅出VC++串口编程之基于Win32 API

1.API描述 在WIN32 API中,串口使用文件方式进行访问,其操作的API基本上与文件操作的API一致. 打开串口 Win32 中用于打开串口的API 函数为CreateFile,其原型为: HANDLE CreateFile ( LPCTSTR lpFileName, //将要打开的串口逻辑名,如COM1 或COM2 DWORD dwAccess, //指定串口访问的类型,可以是读取.写入或两者并列 DWORD dwShareMode, //指定共享属性,由于串口不能共享,该参数必须置为

从.NET平台调用Win32 API

小序        Win32 API可以直接控制Microsoft Windows的核心,因为API(Application Programming Interface)本来就是微软留给我们直接控制Windows的接口.想玩儿吗?呵呵,太难了.        C#使用非常简单,写程序就像打拱猪,Sorry  -_-! ,搭积木一样简单.想玩儿吗?呵呵,没办法直接控制Windows的核心.        难道就没有两全其美的办法吗?当然不是!要不微软的产品早就没人买了.其实从C#(或者说.NET

MATLAB中mexFunction函数的接口规范(转载)

MEX文件的调用极为方便,其调用方式与MATALAB的内建函数完全相同,只需要在命令窗口内输入对应的文件名称即可. C语言MEX程序代码文件有计算子例程(Computational routine)和接口子程序(GatWay routine)两个相互独立的子程序组成.其中,计算子例程的功能是完成所需要的计算,它和具有相同功能的一般C源程序文件相同:接口子程序的功能则是计算子程序和MATALAB的接口,用户实现两个不同内存空间中的通信. void mexFunction(int nlhs, mxA

Detours简介 (拦截x86机器上的任意的win32 API函数)

Detours 当然是用detours,微软明显高腾讯一筹,同上,至今没失败过.写这种HOOK一定要再写个测试程序,不要直接HOOK你的目的程序,例如QQ,因为这样不方面更灵活的测试.说明一下:Detours是微软开发的一个函数库(源代码可在http://research.microsoft.com/sn/detours 免费获得)用于修改运行中的程序在内存中的影像,从而即使没有源代码也能改变程序的行为.具体用途是:拦截WIN32 API调用,将其引导到自己的子程序,从而实现WIN32 API的

Windows API中几个函数的总结

[DllImport("User32.dll", EntryPoint = "FindWindow")] public static extern IntPtr FindWindow(String className, String captionName); [DllImport("User32.dll", EntryPoint = "FindWindowEx")] public static extern IntPtr F