系统信息API

 

  • BOOL WINAPI DnsHostnameToComputerName(
      __in          LPCTSTR
    Hostname,
      __out         LPTSTR
    ComputerName,
      __in_out      LPDWORD
    nSize
    );

     

    说明:

    DNS样式的主机名称转换为NetBIOS样式的主机名称。

     

    注意:

    此函数不能用于把DNS域名称转换为NetBIOS域名称。

     

    参数:

    1DNS名称,如果DNS名称无效,函数运行失败。(常数)

    2:用来接的缓存。【MAX_COMPUTERNAME_LENGTH + 1 】

    3:缓存大小和用来接收实际读取的字节数。(DWORD

     

    返回值:

    成功:非零值。

    失败:0

    GetLastError: 可能返回值为ERROR_MORE_DATA,说明缓存太小,或第二个参数设置值太小。

     

    示例:

     

    =============================================================================================================

     

    //获得环境变量值。

     

    DWORD WINAPI ExpandEnvironmentStrings(
      __in          LPCTSTR
    lpSrc,
      __out         LPTSTR
    lpDst,
      __in          DWORD
    nSize
    );

     

    参数:

    1:指向源地址的指针。

    2:接收地址。

    3:需要接收的大小。

     

     

    返回值:

    成功:返回存储在目标缓存的字节数。

     

    示例:

    TCHAR szResult[100];

    ExpandEnvironmentStrings( TEXT("%PATH%"), szResult, sizeof(TCHAR));

    Printf("%S", szResult);

     

     

    //

    进程方面一个有关函数:

     LPTCH WINAPI GetEnvironmentStrings(void);

     

    此函数获得当前进程的环境变量。

     

    //

    Windows系统的 环境变量:

    %ALLUSERSPROFILE%

    列出所有用户Profile文件位置。

     

    %APPDATA%

    列出应用程序数据的默认存放位置。

     

    %CD%

    列出当前目录。

     

    %CLIENTNAME%

    列出联接到终端服务会话时客户端的NETBIOS名。

     

    %CMDCMDLINE%

    列出启动当前cmd.exe所使用的命令行。

     

    %CMDEXTVERSION%

    命令出当前命令处理程序扩展版本号。

     

    %CommonProgramFiles%

    列出了常用文件的文件夹路径。

     

    %COMPUTERNAME%

    列出了计算机名。

     

    %COMSPEC%

    列出了可执行命令外壳(命令处理程序)的路径。

     

    %DATE%

    列出当前日期。

     

    %ERRORLEVEL%

    列出了最近使用的命令的错误代码。

     

    %HOMEDRIVE%

    列出与用户主目录所在的驱动器盘符。

     

    %HOMEPATH%

    列出用户主目录的完整路径。

     

    %HOMESHARE%

    列出用户共享主目录的网络路径。

     

    %LOGONSEVER%

    列出有效的当前登录会话的域名控制器名。

     

    %NUMBER_OF_PROCESSORS%

    列出了计算机安装的处理器数。

     

    %OS%

    列出操作系统的名字。(WindowsXP和Windows2000列为Windows_NT.)

     

    %Path%

    列出了可执行文件的搜索路径。

     

    %PATHEXT%

    列出操作系统认为可被执行的文件扩展名。

     

    %PROCESSOR_ARCHITECTURE%

    列出了处理器的芯片架构。

     

    %PROCESSOR_IDENTFIER%

    列出了处理器的描述。

     

    %PROCESSOR_LEVEL%

    列出了计算机的处理器的型号。

     

    %PROCESSOR_REVISION%

    列出了处理器的修订号。

     

    %ProgramFiles%

    列出了ProgramFiles文件夹的路径。

     

    %PROMPT%

    列出了当前命令解释器的命令提示设置。

     

    %RANDOM%

    列出界于0和32767之间的随机十进制数。

     

    %SESSIONNAME%

    列出连接到终端服务会话时的连接和会话名。

     

    %SYSTEMDRIVE%

    列出了Windows启动目录所在驱动器。

     

    %SYSTEMROOT%

    列出了Windows启动目录的位置。

     

    %TEMP%and%TMP%

    列出了当前登录的用户可用应用程序的默认临时目录。

     

    %TIME%

    列出当前时间。

     

    %USERDOMAIN%

    列出了包含用户帐号的域的名字。

     

    %USERNAME%

    列出当前登录的用户的名字。

     

    %USERPROFILE%

    列出当前用户Profile文件位置。

     

    %WINDIR%

    列出操作系统目录的位置

     

    ===============================================================================================================

    获得本地计算机的NetBIOS名称。

     

    BOOL WINAPI GetComputerName(
      __out         LPTSTR
    lpBuffer,
      __in_out      LPDWORD
    lpnSize
    );

    参数:

    1:用来接收的缓存的地址。

    2:读入时指定缓存的大小。输出时,指定实际读到的字节数。

     

    返回值:

    成功:非0

    失败:0

     

    ==================================================================================================================

    获得本地计算机的NetBIOS名称或DNS名称。

     

    BOOL WINAPI GetComputerNameEx(
      __in          COMPUTER_NAME_FORMAT
    NameType,
      __out         LPTSTR
    lpBuffer,
      __in_out      LPDWORD
    lpnSize
    );

     

    参数:

    1:枚举值中之一。查看MSDN

    2:同上。

    3:同上。

     

    返回值:

    同上。

     

    ==============================================================================================================

    按指定格式化返回本地计算机的名称。

     

    BOOLEAN WINAPI GetComputerObjectName(
      __in          EXTENDED_NAME_FORMAT
    NameFormat,
      __out         LPTSTR
    lpNameBuffer,
      __in_out      PULONG
    lpnSize
    );

     

    参数:

    1:枚举值之一,用来指定以何种格式化。不能是NameUnknown

    2: 接收地址。

    3:读入时指定缓冲大小。输出时接收读到的字节数。

     

    返回值:

    同上。

     

    ==============================================================================================================

    获得本地计算机的当前硬件信息。

     

    BOOL WINAPI GetCurrentHwProfile(
      __out         LPHW_PROFILE_INFO
    lpHwProfileInfo
    );

     

    参数:

    1:指向HW_PROFIRE_INFO结构的指针。该结构接收此函数返回的信息。

     

    返回值:

    成功:非0

    失败:0

     

    示例:

    void main(void)
    {
       HW_PROFILE_INFO   HwProfInfo;
       if (!GetCurrentHwProfile(&HwProfInfo))
       {
          _tprintf(TEXT("GetCurrentHwProfile failed with error %lx/n"),
                     GetLastError());
          return;
       }
       _tprintf(TEXT("DockInfo = %d/n"), HwProfInfo.dwDockInfo);
       _tprintf(TEXT("Profile Guid = %s/n"), HwProfInfo.szHwProfileGuid);
       _tprintf(TEXT("Friendly Name = %s/n"), HwProfInfo.szHwProfileName);

    }

     

     

    ===============================================================================================================

    获得指定内存的环境变量。

     

    DWORD WINAPI GetFirmwareEnvironmentVariable(
      __in          LPCTSTR
    lpName,
      __in          LPCTSTR
    lpGuid,
      __out         PVOID
    pBuffer,
      __in          DWORD
    nSize
    );

     

     

    ===============================================================================================================

    获得键盘类型。

     

    int WINAPI GetKeyboardType(
      __in          int
    nTypeFlag
    );

    参数:

    1:要接收键盘信息的类型,可以是下列值之一。

     

    Value

    Meaning

    0

    Keyboard type      //

    1

    Keyboard subtype

    2

    The number of function keys on the keyboard

     

     

    返回值:

    成功:为下列值之一。

     

     

    失败:0。如果参数为1,会失败。因为接收的是键盘子类型。

     

    附注:
    如果参数为
    3,则返回:下列第二列的值,对应上图,可知道为什么类型。

     

     

    When a single USB keyboard is connected to the computer, this function returns the code 81.

     

    示例:

    int keyType = GetKeyboardType(0);

    printf("%d", keyType);   //返回值:为1~7

     

    int keyType = GetKeyboardType(3);

    printf("%d", keyType);   //返回值:为上图。

     

     

    ==============================================================================================================

    //获得系统信息。(处理器信息,访问地址,内存分配力度,页大小)

     

    void WINAPI GetNativeSystemInfo(
      __out         LPSYSTEM_INFO
    lpSystemInfo
    );

     

    void WINAPI GetSystemInfo(
      __out         LPSYSTEM_INFO
    lpSystemInfo
    );

     

    参数:

    1:指向SYSTEM_INFO结构的指针。

     

    typedef struct _SYSTEM_INFO {

    union

    {

    DWORD dwOemId;   //已废弃。

    struct

     {

       WORD wProcessorArchitecture;   //处理器体系结构

       WORD wReserved;   //保留供将来使用。

     };

    };

    DWORD dwPageSize; //页面大小

    LPVOID lpMinimumApplicationAddress;  //指向应用程序和动态链接库(DLL)可以访问的最低内存地址。

    LPVOID lpMaximumApplicationAddress;  //指向应用程序和动态链接库(DLL)可以访问的最高内存地址。

    DWORD_PTR dwActiveProcessorMask; //用二进制掩码表示处理器数目,从低位到高位,有几个1,就有几个处理器。如:3个处理器:000000000000000000000000000111

    DWORD dwNumberOfProcessors;  //处理器数目

    DWORD dwProcessorType;  //已废弃。

    DWORD dwAllocationGranularity;  //内存分配粒度。

    WORD wProcessorLevel;  //系统依赖的处理器级别

    WORD wProcessorRevision;  //处理器体系值
    } SYSTEM_INFO;

     

    ====================================================================================================================================

    //BOOL WINAPI GetVersionEx(
      __in_out      LPOSVERSIONINFO
    lpVersionInfo
    );

     

    参数:

    1OSVERSIONINFO OSVERSIONINFOEX  结构的地址。

     

    OSVERSIONINFO 结构。

    {

    DWORD dwOSVersionInfoSize ;  

    DWORD dwMajorVersion ;      

    DWORD dwMinorVersion ;

    DWORD dwBuildNumber ;

    DWORD dwPlatformId ;

    TCHAR szCSDVersion[128] ;

    }

     

    参数:

    1:结构大小。

    2:主版本号。4: 98,ME

               5: 2000, XP, 2003// 

               6: VISTA, 2008

    3:此版本号。0: vista, 2008, 2000, WinNT4.0, 95

               1: XP

               2: 2003, XP64

               10: win98

               90: me

    4: 忽略

     

    5: 平台。  1: win98

              2: NT

     

    6: Servers Pack.

     

    //<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

    OS VersionEx

    //

    OSVERSIONINFOEX

    {

    DWORD dwOSVersionInfoSize ;  // 结构大小

    DWORD dwMajorVersion ;      // 主版本号

    DWORD dwMinorVersion ;       //次版本号

    DWORD dwBuildNumber ;       // 忽略。

    DWORD dwPlatformId ;        // 平台

    TCHAR szCSDVersion[128] ;   //SerivicePack

     

    WORD  wServercePackMajor ; // ServicePack 主版本

    WORD  wServercePackMinor ;  //ServicePack 次版本

    WORD  wSuiteMask ;         // 附加套件 

    BYTE  wProductType ;       // 附加信息。(本地机,服务器,HomeEdition,工作站)

    BYTE  wReserved ;          // 忽略

    }

     

              

     

    ====================================================================================================================================

    //windows vista 上的函数。

    //得到产品类型。( Business Edition, Enterprise Edition, Server Enterprise Edition ,等等)

    BOOL WINAPI GetProductInfo(
      __in          DWORD
    dwOSMajorVersion,
      __in          DWORD
    dwOSMinorVersion,
      __in          DWORD
    dwSpMajorVersion,
      __in          DWORD
    dwSpMinorVersion,
      __out         PDWORD
    pdwReturnedProductType
    );

    ====================================================================================================================================

    //获得与当前线程关联的用户名称

     

    BOOL WINAPI GetUserName(
      __out         LPTSTR
    lpBuffer,
      __in_out      LPDWORD
    lpnSize
    );

     

    参数:

    1:用来接收的缓存地址。

    2:缓存地址的大小。/实际获得的字符数目。

     

    //以指定格式化形式返回用户名。

     

    BOOLEAN WINAPI GetUserNameEx(
      __in          EXTENDED_NAME_FORMAT
    NameFormat,
      __out         LPTSTR
    lpNameBuffer,
      __in_out      PULONG
    lpnSize
    );

     

    参数:

    1:枚举值。EXTENDED_NAME_FORMAT 之一。

    2:同上。

    3:同上。

     

     

    ====================================================================================================================================

    //获得windows目录路径

     

    UINT WINAPI GetWindowsDirectory(    //c:windows
      __out         LPTSTR
    lpBuffer,
      __in          UINT
    uSize
    );

     

    //获得多用户上的共享目录

     

    UINT WINAPI GetSystemWindowsDirectory(   //
      __out         LPTSTR
    lpBuffer,
      __in          UINT
    uSize
    );

     

     

     

    参数:

    1:用来接收的缓存地址。

    2:标记缓存的大小。

     

    返回:

    成功:读到的实际字节数目。

    失败:0

     

    ====================================================================================================================================

    //测试一个处理器特征是否支持当前电脑。

     

     

    BOOL WINAPI IsProcessorFeaturePresent(
      __in          DWORD
    ProcessorFeature
    );

     

    参数:

    1:处理器特征。 查看MSDN

     

    返回:

    成功:非0

    失败:0

     

    =====================================================================================================================

    //获得系统尺寸制度。

     

    int WINAPI GetSystemMetrics(
      __in          int
    nIndex
    );

     

        SM_CLEANBOOT 返回系统启动方式

    0 正常启动

    1 安全模式启动

    2 网络安全模式启动

    SM_CMOUSEBUTTONS 返回值为系统支持的鼠标键数,返回0,则系统中没有安装鼠标。

    SM_CXBORDER,

    SM_CYBORDER 返回以像素值为单位的Windows窗口边框的宽度和高度,如果Windows的为3D形态,则 等同于SM_CXEDGE参数

    SM_CXCURSOR,

    SM_CYCURSOR 返回以像素值为单位的标准光标的宽度和高度

    SM_CXDLGFRAME,

    SM_CYDLGFRAME 等同与SM_CXFIXEDFRAME and SM_CYFIXEDFRAME

    SM_CXDOUBLECLK,

    SM_CYDOUBLECLK 以像素值为单位的双击有效的矩形区域

    SM_CXEDGE,SM_CYEDGE 以像素值为单位的3D边框的宽度和高度

    SM_CXFIXEDFRAME,

    SM_CYFIXEDFRAME 围绕具有标题但无法改变尺寸的窗口(通常是一些对话框)的边框的厚度

    SM_CXFRAME,SM_CYFRAME 等同于SM_CXSIZEFRAME and SM_CYSIZEFRAME

    SM_CXFULLSCREEN,

    SM_CYFULLSCREEN 全屏幕窗口的窗口区域的宽度和高度

    SM_CXHSCROLL,

    SM_CYHSCROLL 水平滚动条的高度和水平滚动条上箭头的宽度

    SM_CXHTHUMB 以像素为单位的水平滚动条上的滑动块宽度

    SM_CXICON,SM_CYICON 系统缺省的图标的高度和宽度(一般为32*32)

    SM_CXICONSPACING,

    SM_CYICONSPACING 以大图标方式查看Item时图标之间的间距,这个距离总是大于等于

    SM_CXICON and SM_CYICON.

    SM_CXMAXIMIZED,

    SM_CYMAXIMIZED 处于顶层的最大化窗口的缺省尺寸

    SM_CXMAXTRACK,

    SM_CYMAXTRACK 具有可改变尺寸边框和标题栏的窗口的缺省最大尺寸,如果窗口大于这个

    尺寸,窗口是不可移动的。

    SM_CXMENUCHECK,

    SM_CYMENUCHECK 以像素为单位计算的菜单选中标记位图的尺寸

    SM_CXMENUSIZE,

    SM_CYMENUSIZE 以像素计算的菜单栏按钮的尺寸

    SM_CXMIN,SM_CYMIN 窗口所能达到的最小尺寸

    SM_CXMINIMIZED,

    SM_CYMINIMIZED 正常的最小化窗口的尺寸

    SM_CXMINTRACK,

    SM_CYMINTRACK 最小跟踪距离,当使用者拖动窗口移动距离小于这个值,窗口不会移动。

    SM_CXSCREEN,

    SM_CYSCREEN 以像素为单位计算的屏幕尺寸。

    SM_CXSIZE,SM_CYSIZE 以像素计算的标题栏按钮的尺寸

    SM_CXSIZEFRAME,

    SM_CYSIZEFRAME 围绕可改变大小的窗口的边框的厚度

    SM_CXSMICON,

    SM_CYSMICON 以像素计算的小图标的尺寸,小图标一般出现在窗口标题栏上。

    SM_CXVSCROLL,

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

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

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

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

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

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

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

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

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

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

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

     

     

    ======================================================================================================================================

    //

    SystemParametersinfo

    函数功能:该函数查询或设置系统级参数。该函数也可以在设置参数中更新用户配置文件。

    函数原型:B00L SystemParametersinfoUINT uiActionUINT uiParamPVOID pvParamUINT fWinlni);

    参数:

    uiAction该参数指定要查询或设置的系统级参数。其取值如下;

    SPI_GETACCESSTIMEOUT:检索与可访问特性相关联的超时段的信息,PvParam参数必须指向某个ACCESSTIMEOUT结构以获得信息,并将该结构中的cbSjze成员和ulParam参数的值设为sizeofACCESSTIMEOUT)。

     

    SPI_GETACTIVEWINDOWTRACKING:用于Windows 98Windows NT 5.0及以后的版本。它表示是否打开活动窗口跟踪(激活该窗口时鼠标置为开状态),pvParam参数必须指向一个BOOL型变量(打开时接收值为TRUE,关闭时为FALSE)。

     

    SPI_GETACTIVEWNDTRKZORDER;用于Windows 98Windows NT 5.0及以后版本。它表示通过活动窗口跟踪开关激活的窗口是否要置于最顶层。pvParam参数必须指向一个BOOL型变量,如果要置于顶层,那么该变量的值为TRUE,否则为FALSE

     

    SPI_GETACTIVEWNDTRKTIMEOUT:用于Windows 98 Windows NT 5.0及以后版本。它指示活动窗口跟踪延迟量,单位为毫秒。pvParam参数必须指向DWORD类型变量,以接收时间量。

     

    SPI_GETANIMATION:检索与用户活动有关的动画效果。pvParam参数必须指向ANIMATIOINFO结构以接收信息。并将该结构的cbSize成员和ulParam参数置为sizeofANIMATIONINFO)。

     

    SPI_GETBEEP:表示警告蜂鸣器是否是打开的。pvParam参数必须指向一个BOOL类型变量,如果蜂鸣器处于打开状态,那么该变量的值为TRUE,否则为FALSE

     

    SpI_GETBORDER:检索决定窗口边界放大宽度的边界放大因子。pvParam参数必须指向一个整型变量以接收该值。

     

    SPI_GETDEFAULTINPUTLANG:返回用于系统缺省输入语言的键盘布局句柄。pvParam参数必须指向一个32位变量,以接收该值。

     

    SPI_GETCOMBOBOXANIMATION:用于Windows 98Windows NT 5.0及以后版本。它表示用于组合柜的动打开效果是否允许。pvParam参数必须指向一个BOOL变量,如果允许,那么变量返回值为TRUE,否则为FALSE

     

    SPI_GETDRAGFULLWINDOWS:确定是否允许拖拉到最大窗口。pvParam参数必须指向BOOL变量,如果允许,返回值为TRUE,否则为FALSE。对于Windows 95系统,该标志只有在安装了Windows plusl才支持。

     

    SPI_GETFASTTASKSWITCH:该标志已不用!以前版本的系统使用该标志来确定是否允许AltTab快速任务切换。对于Windows 95Windows 98Windows NT 4.0版而言,快速任务切换通常是允许的。

     

    SPI_GETFILTERKEYS:检索有关FILTERKEYS(过滤键)易用特征信息。pvParam参数必须指向接收信息的filterkeys结构,并将该结构中的cbSze成员和ulParam参数的值设为sizeofFILTERKEYS)。

     

    SPI_GETFONTSMOOTHING:表示字体平滑处理特征是否允许。该特征使用字体保真技术,通过在不同灰度级上涂上像素使字体曲线显得更加平滑。参数pvParam必须指向BOOL类型变量,如果该特征被允许,那么返回值为TRUE,否则为FALSE。对于Windows 95系统,该标志只有在安装了Windows plusl才支持。

    SPI_GETFOREGROUNDFLASHCOUNT:用于Windows 98Windows NT 5.0及以后版本。它表示在拒绝前台切换申请时系统闪烁任务条按钮的次数。参数pvParam必须指向DWORD变量,以接收该值。

     

    SPI_GETFOREGROUNDLOCKTIMEOUT:用于Windows NT 5.O及以后版本或Windows 98。它表示在系统禁止应用程序强行将自己进入前台期间的时间量,单位为毫秒.参数pvParam必须指向DWORD变量以接收时间值。

     

    SPI_GETGRADIENTCAPTIONS:用于Windows 98Windows NT 5.0及以后版本。它表示是否允许有用于窗口标题栏的倾斜效果。参数pvParam必须指向BOOL变量,其值在允许时为TRUE,禁止时为FALSE

     

    SPL_GETGRIDGRANULARITY:检索桌面大小网格的当前颗粒度值。参数pVparam必须指向一个整型变量以接收该值。

     

    SPI_GETHIGHCONTRAST:用于Windows 95及更高版本、Windows NT 5.0及以后版本。检索与HighContrast易用特征有关的信息。pvParam参数必须指向用于接收该信息的HIGHCONTRAST结构,该结构中的。cbSize成员和ulParam参数的值应设为sizeofNIGHCONTRAST)。

     

    SPI_GETICONMETRICS:检索与图标有关的度量信息。参数pvParam必须指向一个ICONMETRICS结构以接收信息。该结构中的。cbSize成员和ulParam参数的值应设为sizeofICONMETRICS)。

     

    SPI_GETICONTITLELOGFONT:检索当前图标标题字体的逻辑字体信息。参数ulParam规定了logfont结构的大小,参数pvParam必须指向要填充的Iogfont结构。

     

    SPI_GETICONTITLEWRAP:确定是否允许图标标题环绕。pvParam参数必须指向一个BOOL类型变量,该变量的值在允许时为TRUE,否则为FALSE

     

    SPI_GETKEYBOARDDELAY:检索键盘重复击键延迟设置,该值范围从0(大约25Oms延迟)到3(大约1秒延迟)。与该范围里每一个值相关的实际延迟时间可能与硬件有关。pvParam参数必须指向一个整型变量以接收设置值。

     

    SPI_GETKEYBOARDPREF:用于Windows 95及以后版本。Windows NT 5.O及以后版本。它确定用户是否依赖键盘而非鼠标,是否要求应用程序显示键盘接口,以免隐藏。pvParam参数必须指向一个BOOL类型变量,如果用户依赖键盘,那么该变量取值为TRUE,否则为FALSE

     

    SPI_GETKEYBOARDSPEED:检索键盘重复击键速度设置情况,该值范围从0(大约30/秒)至31(大约25/秒)。实际的击键速率与硬件有关,而且变动的线性幅度有可能高达20%。参数pvParam必须指向DWORD变量以接收设置值。

     

    SPI_GETLISTBOXSMOOTHSCROLLING:用于Windows 98Windows NT 5.0及以后版本。表示是否允许有列表栏的平滑滚动效果。pvParam参数必须指向BOOL变量,如果允许,则该值为TRUE,否则为FALSE

     

    SPI_GETLDWPOWERACTIVE:确定是否允许屏幕保护的低电压状态。如果允许,那么指向BOOL变量的pvParam参数会接收到TRUE值,否则为FALSE。对于Windows 98,该标志对16位和32位应用程序都支持。

    对于Windows 95,该标志只支持16位应用程序。对于Windows NT,在Windows NT 5.0及以后版本中支持32位应用程序,对16位应用程序则不支持。

     

    SPI_GETLOWPOWERTIMEOUT:检索用于屏幕保护的低电压状态超时值。pvParam参数必须指向一个整型变量,以接收该值。对于Windows 98该标志支持16位和32位应用程序。对于Windows95,该标志只支持16位应用程序。对于Windows NT,该标志支持Windows NT 5.0及以后版本上的32位应用程序。不支持16位应用程序。

     

    SPI_GETMENUDROPALIGNMENT。确定弹出式菜单相对于相应的菜单条项是左对齐,还是右对齐、参数pvParam必须指向一个BOOL类型变量,如果是左对齐。那么该变量值为TRUE,否则为FALSE

    SPI_GETMINIMIZEDMETRICS:检索最小化窗口有关的度量数据信息。参数pvParam必须指向MINIMIZEDMETRCS结构,以接收信息。该结构中的cbSizeulParam参数的值应设为sizeofMINIMIZEDMETRICS)。

     

    SPI_GETMOUSE:检索鼠标的2个阈值和加速特性。pvParam参数必须指向一个长度为3的整型数组,分别存储此值。

     

    SPI_GETMOUSEHOVERHEGHT:用于Windows NT 4.0及以后版本或Windows 98。获得在TrackMouseEvent事件中,为产生WM_MOUSEOVER消息而鼠标指针必须停留的矩形框的高度,以像素为单位。参数pvParam必须指向一个UINT变量以接收这个高度值。

     

    SPI_GETMOUSEHOVERTIME:用于Windows NT 4.0及以后版本、Windows 98,获得在TrackMouseEvent事件中,为产生WM_MOUSEOVER消息而鼠标指针必须停留在矩形框内的时间,单位为毫秒。参数pvParam必须指向一个UINT变量以接收该时间值。

     

    SPI_GETMOUSEHOVERWIDTH:用于Windows NT 4.0及以后版本、Windows 98。获得在TrackMouseEvent事件中,为产生WM_MOUSEOVER消息而鼠标指针必须停留的矩形框的宽度,以像素为单位。参数pvParam必须指向一个UINT变量以接收这个宽度值。

     

    SPI_GETMOUSEKEYS:检索与MOUSEKEYS易用特征有关的信息,pvParam参数必须指向某个MOUSEKEYS结构,以获取信息。应将结构的cbSize成员和ulParam参数设置为sizeofMOUSEKEYS)。

     

    SPI_GETMOUSESPEED:用于Windows NT 5.0及以后版本、Windows 98。检索当前鼠标速度。鼠标速度决定了鼠标移动多少距离,鼠标的指针将移动多远。参数pvParam指向一个整型变量,该变量接收1(最慢)至20(最快)之间的数值。缺省值为们10。这个值可以由最终用户使用鼠标控制面板应用程序或使用调用了SPI_SETMOUSESPEED的应用程序来设置。

     

    SPI_GETMOUSETRAILS:用于WpvParam必须指向一个BOOL类型变量,如果是左对齐。那么该变量值为TRUE,否则为FALSE

     

    SPI_GETMINIMIZEDMETRICS:检索最小化窗口有关的度量数据信息。参数pvParam必须指向MINIMIZEDMETRCS结构,以接收信息。该结构中的cbSizeulParam参数的值应设为sizeofMINIMIZEDMETRICS)。

     

    SPI_GETMOUSE:检索鼠标的2个阈值和加速特性。pvParam参数必须指向一个长度为3的整型数组,分别存储此值。

     

    SPI_GETMOUSEHOVERHEGHT:用于Windows NT 4.0及以后版本或Windows 98。获得在TrackMouseEvent事件中,为产生WM_MOUSEOVER消息而鼠标指针必须停留的矩形框的高度,以像素为单位。参数pvParam必须指向一个UINT变量以接收这个高度值。

     

    SPI_GETMOUSEHOVERTIME:用于Windows NT 4.0及以后版本、Windows 98,获得在TrackMouseEvent事件中,为产生WM_MOUSEOVER消息而鼠标指针必须停留在矩形框内的时间,单位为毫秒。参数pvParam必须指向一个UINT变量以接收该时间值。

     

    SPI_GETMOUSEHOVERWIDTH:用于Windows NT 4.0及以后版本、Windows 98。获得在TrackMouseEvent事件中,为产生WM_MOUSEOVER消息而鼠标指针必须停留的矩形框的宽度,以像素为单位。参数pvParam必须指向一个UINT变量以接收这个宽度值。

     

    SPI_GETMOUSEKEYS:检索与MOUSEKEYS易用特征有关的信息,pvParam参数必须指向某个MOUSEKEYS结构,以获取信息。应将结构的cbSize成员和ulParam参数设置为sizeofMOUSEKEYS)。

     

    SPI_GETMOUSESPEED:用于Windows NT 5.0及以后版本、Windows 98。检索当前鼠标速度。鼠标速度决定了鼠标移动多少距离,鼠标的指针将移动多远。参数pvParam指向一个整型变量,该变量接收1(最慢)至20(最快)之间的数值。缺省值为们10。这个值可以由最终用户使用鼠标控制面板应用程序或使用调用了SPI_SETMOUSESPEED的应用程序来设置。

     

    SPI_GETMOUSETRAILS:用于Windows 95及更高版本。它用来表示是否允许MouseTrails(鼠标轨迹)。该特征通过简单地显示鼠标轨迹并迅速擦除它们来改善鼠标的可见性。参数prParam必须指向一个整型变量来接收该值。如果这个值为01,那么表示禁止该特征。如果该值大于1,则说明该特征被允许,并且该值表示在鼠标轨迹上画出的光标数目。参数ulParam不用。

     

    SPI_GETNONCLIENTMETRICS:检索与非最小化窗口的非客户区有关的度量信息。参数pvParam必须指向NONCLIENTMETRICS结构,以便接收相应值。该结构的。cbSize成员与ulParam参数值应设为sizeofNONCLIENTMETRICS)。对于Windows 98,该标志支持16位和32位应用程序。对于Windows 95,该标志只支持16位应用程序。对于Windows NT该标志在NT 5.0及以后版本中支持32位应用程序,不支持16位应用程序。

     

    SPI_GETPOWEROFFACTIVE:确定是否允许屏幕保护中关电。TRUE表示允许,FA参数pvParam必须指定SERIALKEYS结构来接收信息。该结构中的cbSize成员和ulParam参数的值要设为sizeofSERIALKEYS)。

     

    SPI_GETSHOWSOUNDS:确定ShowSounds易用特性标志是开或是关。如果是开,那么用户需要一个应用程序来可视化地表达信息,占则只能以听得见的方式来表达。参数pvParam必须指向一个BOOL类型变量。该变量在该特征处于开状态时返回TRUE,否则为FALSE。使用这个值等同于调用GetSystemMetricsSM_SHOWSOUNDS)。后者是推荐使用的调用方式。

     

    SPI_GETSNAPTODEFBUTTON:用于Windows NT 4.0及以后版本、Windows 98:确定 Snap-TO-Default-Button(转至缺省按钮)特征是否允许。如果允许,那么鼠标自动移至缺省按钮上,例如对话框的"Ok""Apply"按钮。pvParam参数必须指向Bool类型变量,如果该特征被允许,则该变量接收到TRUE,否则为FALSE

     

    SPI_GETSOUNDSENTRY:检索与SOUNDSENTRY可访问特征有关的信息。参数pvParam必须指向SOUNDSENTRY结构以接收信息。该结构中的。cbSize或员和ulParam参数的值要设为sizeofSOUNDSENTRY)。

     

    SPI_GETSTICKYKEYS:检索与StickyKeys易用特征有关的信息。参数 pvParam必须指向STICKYKEYS结构以获取信息。该结构中的cbSze成员及ulParam参数的值须设为sizeofSTICKYKEYS)。

     

    SPI_GETSWITCHTASKDISABLE:用于Windows NT 5.0Windows 95及以后版本,确定是否允许AltTabAItEsc任务切换。参数pvParam必须指向UINT类型变量,如果禁止任务切换,那么返回值为1,否则为0。在缺省情况下,是允许进行任务切换的。

     

    SPI_GETTOGGLEKEYS:检索与ToggleKeys易用特性有关的信息。参数pvParam必须指向TOGGLEKEYS结构以获取信息。该结构中的cbSize成员和ulParam参数值要设置sizeofTOGGLEKEYS)。

     

    SPI_GETWHEELSCROLLLINES:用于Windows NT 4.0及以后版本、Windows 98。当前轨迹球转动时,获取滚动的行数。参数pvParam必须指向UINT类型变量以接收行数。缺省值是3

     

    SPI_GETWINDOWSEXTENSION:在Windows 95中指示系统中是否装了Windows ExtensionWindows Plus!。

     

     

     

     

    参数ulParam应设为1。而参数pvParam则不用。如果安装了Windows Extenson,那么该函数返回TRUE,否则为FALSE

     

    SPI_GETWORKAREA:检索主显示器的工作区大小。工作区是指屏幕上不被系统任务条或应用程序桌面工具遮盖的部分。参数pvParam必须指向RECT结构以接收工作区的坐标信息,坐标是用虚拟屏幕坐标来表示的。为了获取非主显示器的工作区信息,请调用GetMonitorlnfo函数。参数ulParam指定宽度,单位是像素。

     

    SPI_ICONVERTICALSPACING:设置图标单元的高度。参数ulParam指定高度,单位是像素。

     

    SPI_LANGDRIVER:未实现。

     

    SPI_SCREENSAVERRUNNING:改名为SPI_SETSCREENSAVERRUNNING

     

    Spl_SETACCESSTIMEOUT:设置与可访问特性有关的时间限度值,参数 pvParam必须指向包含新参数的ACCESSTIMEOUT结构,该结构的cbSize成员与ulParam参数的值要设为sizeofACCESSTMEOUT)。

     

    SPI_SETACTIVEWINDOWTRACKING:用于Windows NT 5.0及以后版本、Windows 98。设置活动窗口追踪的开或关,如果把参数pvParam设为TRUE,则表示开。pvParam参数为FALSE时表示关。

     

    SPI_SETACTIVEWNDTRKZORDER:用于Windows NT 5.0及以后版本、Windows 98。表示是否把通过活动窗口跟踪而激活的窗口推至顶层。参数pvParam设为TRUE表示推至顶层,FALSE则表示不推至顶层。

     

    SPI_SETACTIVEWNDTRKTIMEOUT:用于Wlindows NT 5.0及以后版本、Windows 98。设置活动窗口跟踪延迟。

    参数pvParam设置在用鼠标指针激活窗口前需延迟的时间量,单位为毫秒。

     

    SPI_SETBEEP:将警蜂器打开或关闭。参数ulParam指定为TRUE时表示打开,为FALSE时表示关闭。

     

    SPI_SETBORDER:设置确定窗口缩放边界的边界放大因子。参数ulParam用来指定该值。

     

    SPI_SETCOMBOBOXANIMATION:用于Windows NT 5.0及以后版本和Windows 98。允许或禁止组合滑动打开效果。如果设置pvParam参数为TRUE,则表示允许有倾斜效果,如果设为FALSE则表示禁止。

     

    SPI_SETCURSORS:重置系统光标。将ulParam参数设为0并且pvParam参数设为NULL

     

    SPI_SETDEFAULTINPUTLANG:为系统Shell(命令行解器)和应用程序设置缺省的输入语言。指定的语言必须是可使用当前系统字符集来显示的。pvParam参数必须指向DWORD变量,该变量包含用于缺省语言的键盘布局句柄。

     

    SpI_SETDESKpATTERN:通过使Windows系统从WIN.INI文件中pattern=设置项来设置当前桌面模式。

     

    SPI_SETDESKWALLPAPER:设置桌面壁纸。pvParam参数必须指向一个包含位图文件名,并且以NULL(空)结束的字符串。

     

    SPI_SETDOUBLECLICKTIME:设ulParam参数的值为目标双击时间。双击时间是指双击中的第1次和第2次点击之间的最大时间,单位为毫秒。也可以使用SetDoubleClickTime函数来设置双击时间。为获取当前双击时间,请调用GetDoubleClickTime函数。

     

    SPI_SETDOUBLECLKHEGHT:将ulParam参数的值设为双击矩形区域的高度。双击矩形区域是指双击中的第2次点击时鼠标指针必须落在的区域,这样才能记录为双击。

     

    SPI_SETDOUBLECLKWIDTH:将ulParam参数的值设为双击矩形区域的宽度。

     

    SPI_SETDRAGFULLWINDOWS:设置是否允许拖至最大窗口。参数uIParam指定为TRUE时表示为允许,为FALSE则不可。对于Windows 95,该标志只有在安装了Windows plusl才支持。

     

    SPI_SETDRAGHEIGHT:设置用于检测拖拉操作起点的矩形区域的高度,单位为像素。参考GETSYSTEMMETRICS函数的nlndex参数中的SM_CXDRAGSM_CYDRAG

     

    SPI_SETDRAGWIDTH:设置用于检测拖拉操作起点的矩形区域的宽度,单位为像素。

     

    SPI_SETFASTTASKSWITCH:该标志己不再使用。以前版本的系统使用此标志来允许或不许进行AltTab快速任务切换。对于Windows 95Windows 98Windows NT 4.0,通常都允许进行快速任务切换。参考SPI_SETSWITCHTASKDISABLE

     

    SPI_SETFILTERKEYS:设置FilterKeys易用特性的参数。参数pvParam必须指向包含新参数的FILTERKEYS结构,该结构中的cbSize成员和参数ulParam的值应设为sizeofFILTERKEYS)。

     

    SPI_SETFONTSMOOTHING:允许或禁止有字体平滑特性。该特性使用字体保真技术,通过在不同灰度级上涂画像素点来使得字体曲线显得更加平滑,为了允许有该特性,参数ulParam应设为TRUE值,否则为FALSE。对于Windows 95,只有在安装了Windows plusl才支持该标志。

     

    SPI_SETFOREGROUNDFLASHCOUNT:用于Windows 98Windows NT 5.0及以后版本。设置SetForegroundWindow在拒绝前台切换申请时闪烁任务拦按钮的次数。

     

    SPI_SETFOREGROUNDLOCKTIMEOUT:用于Windows 98Windows NT 5.0及以后版本。它用来设置在用户输入之后,系统禁止应用程序强行将自己进入前台期间的时间长度,单位为毫秒。参数pvParam设置这个新的时间限度值。

     

    SPI_SETGRADIENTCAPTIONS:用于Windows 98Windows NT 5.0及以后版本。允许或禁止窗口标题栏有倾斜效果。如果允许则将参数pvParam设置为TRUE,否则设为FALSE。有关倾斜效果方面更多信息,请参考GetSysColor函数。

     

    SPI_SETGRIDGRANULARITY:将桌面缩放时网格的颗粒度值设置为参数ulParam中的值。

     

    SPI_SETHANDHELD:内部使用,应用程序不应使用该值。

     

    SPI_SETHIGHCONTRAST:用于Windows 95及以后版本、Windows NT 5.0及以后版本。设置HighContrast可访问特性的参数。参数pvParam必须指向HIGHCONTRAST结构,该结构包含新的参数。该结构中的cbSize成员及参数ulParam的值设为sizeofHIGHCONTRAST)。

     

    SPI_SETICONMETRICS:设置与图标有关的信息。参数pvParam必须指向包含新参数的ICONMETRICS结构,另外还要将参数ulParam和该结构中的cbSize成员的值设置为sizeofICONMETRICS)。

     

    SPI_SETICONS:重新加载系统图标。参数ulParam的值应设为0,而pvParam参数应设为NULL

     

    SPI_SETICONTITLELOGFONT:设置用于图标标题的字体。参数ulParam指定为logfont结构的大小,而参数pvParam必须指向一个LOGFONT结构。

     

    SPI_SETICONTITLEWRAP:打开或关闭图标标题折行功能。若想打开折行功能,则把参数ulParam设为TRUE,否则为FALSE

     

    SPI_SETKEYBOARDDELAY:设置键盘重复延迟。参数ulParam必须指定为0123。其中0表示设置为最短延迟(大约 250ms3,表示最大延迟(大约 1 秒)。与每个值对应的实际的延迟时间根据硬件情况有可能有些变化。

     

    SPI_SETKEYBOARDPREF:用于Windows 95及以后版本、Windows NT 5.0及以后版本,设置键盘优先序。如果用户依赖键盘而不是鼠标,那么可将参数ulParam指定为TRUE,否则设为FALSE,并且要求应用程序显示而不隐蔽键盘接口。

     

    SPI_SETKEYBOARDSPEED:设置键盘重击键速度。参数ulParam必须指定一个从031的值,其中0表示设置成最快速度(大约30/秒),31表示设置为最低速度(大约25/秒),实际的重速率与硬件有关,而且可能变动幅度高达20%。如果ulParam大于31,那么该参数仍设置为31

     

    SPI_SETLANGTOGGLE:为输入语言间切换设置热键集。参数ulParampvParam不用。该值通过读取注册表来设置键盘属性表单中的快捷键。在使用该标志之前必须设置注册表,注册表中的路径是"1"=Altshift"2"=Ctrl+shift"3"=none(无)。

     

    SPI_SETLISTBOXSMOOTHSCROLLING:用于Windows 98Windows NT 5.0及以后版本。允许或不许列表栏有平滑滚动效果。参数pvParam设置为TRUE表示允许有平滑滚动效果,为FALSE则表示禁止。

     

    SPI_SETLOWPOWERACTIVE:激活或关闭低电压屏幕保护特性。参数ulParam设为1表示激活,0表示关闭。参数pvParam必须设为NULL。对于Windows 98,该标志支持16位和32位应用程序。对于Windows 95,该标志只支持16位应用程序。对于Windows NT.该标志只支持NT 5.0及以后版本的32位应用程序,不支持16位应用程序。

     

    SPI_SETLOWPOWERTIMEOUT:用于设置低电压屏幕保护中的时间值(也称超时值,即在超过某一时间段后自动进行屏幕保护),单位为秒。uIParam参数用来指定这个新值。参数pvParam必须为NULL。对于Windows98,该标志支持16位和32位应用程序。对于Windows 95,该标志只支持16位应用程序。对于Windows NT该标志只支持NT 5.0及以后版本的32位应用程序,不支持16位应用程序。

     

    SPI_SETMENUDROPALIGNMENT:设置弹出或菜单的对齐方式。参数ulParam指定为TRUE时表示是右对齐,FALSE时为左对齐。

     

    SPI_SETMINIMIZEDMETRICS:设置与最小化窗口有关的数据信息,参数pvParam必须指向包含新参数的MINIMIZEDMETRICS结构。该结构中的cbSize成员与ulParam参数的值应设为sizeofMINMIZEDMETRICS)。

     

    SPI_SETMOUSE:设置鼠标的两个阀值和加速率。参数pvParam必须指向一个长度为3的数组,以指定这些值。详细请参考mouse_event

     

    SPI_SETMOUSEBUTTONSWAP:调换或恢复鼠标左右按钮的含义,为FALSE时表示恢复原来的含义。

     

    SPI_SETMOUSEHOVERHEGHT:用于Windows 98Windows NT 4.0及以后版本。设置鼠标指针停留区域的高度,以像素为单位。鼠标指针在此区域停留是为了让TrackMouseEvent产生一条WM_MUOSEHOVER消息,参数ulParam用来设置此高度值。

     

    SPI_SETMOUSEHOVERTIME:用于Windows 98Windows NT 4.0及以后版本。设置鼠标指针为了让TrackMouseEvent产生WM_MOUSEHOVER事件而在停留区域应停留的时间。该标志只有在将调用dwHoverTime参数中的HOVER_DEFAULT值传送到TrackMouseEvent时才使用。参数ulParam设置这个新的时间值。

     

    SPI_SETMOUSEHOVERWIDTH:用于Windows 98Windows NT 4.0及以后版本。设置鼠标指针停留区域的宽度,以像素为单位。参数ulParam设置该新值。

     

    SPI_SETMOUSEKEYS:设置MouseKeys易用特性的参数。参数pvParam必须指向包含新参数的MOUSEKEYS结构。结构中的cbSize成员与参数ulParam的值应设为sizeofMOUSEKEYS)。

     

    SPI_SETMOUSESPEED:用于Windows NT 5.0及以后的版本和Windows 98,设置当前鼠标速度。参数pvParam必须指向一个1(最慢)至20(最快)之间的整数。缺省值是10。一般可以使用鼠标控制面板应用程序来设置该值。

     

    SPI_SETMOUSETRAILS:用于Windows 95及以后版本:允许或禁止有MoouseTrails(鼠标轨迹)特性。该特性通过简短地显示鼠标光标轨迹,并迅速地擦除它们来提高鼠标的可见度。禁止该特性可将参数ulParam设为01,允许时,ulParam设置为一个大于1的数值,该值表示轨迹中画出的光标个数。

    SPI_SETNONCLIENTMETRICS:设置与非最小化窗口的非客区有关的数据信息,参数pvParam必须指向NONCLIENTMETRICS结构,该结构包含新的参数。其成员cbSzie和参数ulParam的值应设为sizeofNONCLIENTMETRICS)。

     

    SPI_SETPENWINDOWS;用于Windows 95及以后版本:指定是否加载笔窗口,当加载时,参数ulParam设为TRUE,不加载时为FALSE。参数pvParamNULL

     

    SPI_SETPOWEROFFACTIVE:激活或关闭屏幕保护特性参数。ulParam设为1表示激活,0表示关闭。参数pvParam必须为NULL。对于Windows 98,该标志支持16位和32位应用程序。对于Windows 95,该标志只支持16位应用程序。对于Windows NT,该标志支持Windows NT 5.0及以后版本的32位应用程序,不支持16位应用程序。

     

     

    SPI_SETPOWEROFFTIMEOUT:设置用于关闭屏幕保护所需的时间值(也称超时值)。参数ulParam指定该值。参数pvParam必须为NULL。对于Windows 98.该标志支持16位和32位应用程序。对于Windows 95,该标志只支持16位应用程序。对于Windows NT,该标志支持Windows NT 5.0及以后版本上的32位应用程序,不支持16位应用程序。

     

    SPI_SETSCREENREADER;用于Windows 95及以后版本、Windows NT 5.0及以后版本,表示屏幕审阅程序是否运行。参数uiparm指定为TRUE表示运行该程序,FALSE则不运行。

     

    SPI_SETSCREENSAVERRUNNING:用于Windows 95及以后版本,内部使用。应用程序不应该使用此标志SPI_SETSETSCREENSAVETIMEOUT:参数ulParam值为屏幕保护器时间限度值。该值是一个时间量,以秒为单位,在屏幕保护器激活之前,系统应该一直是空闲的,超过这个值就激活屏幕保护器。

     

    SPI_SETSERIALKEYS:用于Windows 95及以后版本:设置SerialKeys易用特性的参数。参数pvParam必须指向包含新参数的SERIALKEYS结构,其成员cbSize和参数ulParam应设为sizeofSERIALKEYS)。

     

    SPI_SETSHOWSOUNDS:将ShowSounds易用特性设置为打开或关闭。参数ulParam指定为TRUE时表示打开,FALSE表示关闭。

     

    SPI_SETSNAPTODEFBUTTON:用于Windows NT 4.0及以后版本、Windows 98。允许或禁止有snap-to-default-button(跳转至缺省按钮)特性。如果允许,那么鼠标光标会自动移至缺省按钮上,例如对话柜中的OK"apply"按钮。参数ulParam设为TRUE表示允许该特性,FALSE表示禁止。

     

    SPI_SETSOUNDSENTRY:设置SOUNDSENTRY易用特性的参数。参数pvParam必须指向SOUNDSENTRY结构,该结构包含新参数,其成员cbSize和参数ulParam的值应设为sizeofSOUNDSENTRY)。

     

    SPI_SETSTICKYKEYS:设置stickykeys可访问特性的参数。参数pvParam必须指向包含新参数的stickykeys结构,其成员cbSizeulParam参数的值要设为sizeofSTICKYKEYS)。

     

    SPI_SETSWITCHTASKDISABLE:用于Windows NT 5.0及以后版本,允许或禁止有AltTabAltEsc任务切换特性。参数ulParam设为1表示允许有该特性,设为0则表示禁止。缺省情况下是允许有任务切换特性的。

     

    SPI_SETTOGGLEKEYS:设置togglekeys可访问特性的参数,参数PvParam必须指向TOGGLEKEYS结构,该结构中包含新的参数。其成员cbSize和参数ulParam的值要设为sizeoftogglekeys)。

     

    SPI_SETWHEELSCROOLLLINES:用于Windows 98Windows NT 4.O及以后版本。设置当鼠标轨迹球转动时

    要滚动的行数,滚动的行数是由参数ulParam设置的,该行数是在鼠标轨迹球滚动,并且没有使用修改键时的滚动行数。如果该数值为0,那么不会发生滚动,如果滚动行数比可见到的行数要大,尤其如果是WHEEL_PAGESCROLL(#defined sa UINT_MAX),那么滚动操作应该被解释成在滚动条的下一页或上一页区点击一次。

     

    SPI_SETWORKAREA:设置工作区域大小。工作区是指屏幕上没有被系统任务栏或桌面应用程序桌面工具遮盖的部分。参数pvParam是一个指针。指向RECT结构,该结构规定新的矩形工作区域,它是以虚拟屏幕坐标来表达的。在多显示器系统中,该函数用来设置包含特定矩形的显示器工作区域。如果PvParamNULL,那么该函数将主显示器的工作区域设为全屏。

     

     

    uiParam:与查询或设置的系统参数有关。关于系统级参数的详情,请参考uiAction参数。否则在没有指明情况下,必须将该参数指定为O

    pvParam:与查询或设置的系统参数有关。关于系统级参数的详情,请参考uiAction参数。否则在没有指明情况下,必须将该参数指定为NULL

     

     

    fWinlni:如果设置系统参数,则它用来指定是否更新用户配置文件(Profile)。亦或是否要将WM_SETTINGCHANGE消息广播给所有顶层窗口,以通知它们新的变化内容。该参数可以是0或下列取值之一:

    SPIF_UPDATEINIFILE:把新的系统参数的设置内容写入用户配置文件。

     

    SPIF_SENDCHANGED:在更新用户配置文件之后广播WM_SETTINGCHANGE消息。

     

    SPI_SENDWININICHANGE SPIF_SENDCHANGE一样。

     

     

     

     

     

     

    返回值:如果函数调用成功,返回值非零:如果函数调用失败,那么返回值为零。若想获取更多错误信息,请调用GetLastError函数。

    备注:该函数一般与应用程序,例如控制面板一起使用。它可以允许用户对Windows任意进行定制。

    盘布局名称是从对应于布局的16进制语言标识符引生而来的。例如,美国英语(U.S.Englisth)的语言标识符为" 0×0409",则主美国英语键盘布局命名为"00000409"其他的键盘布局如Dvotak等,命名为"00010409""00020409"等,关于此的列表参见MAKELANGID宏。

    Wiows CE操作系统只支持下列uiAction值:

    SPI_GETBATTERYIDLETIMEOUT:在WINDOWS CE没有因用户操作而挂起之前,干电池电源能坚持给系统供电的时间量可以使用该标志得到。以秒为单位,如果pvParam0,那么该标志被忽略。

    SPI_GETEXTERNALIDLETIMEOUT:在 Windows CE没有因用户操作而挂起之前,交流电源能坚持给系统供电时间的时间量可以使用该标志得到。参数pvParam指向一个DWORD类型变量,以返回时间值,单位为秒。如果pvParam0,那么该标志被忽略。

    SPI_GETMOUSE:检索鼠标的两个阈值和速度。

    SPI_GETOEMINFO:返回一个字符串,该字符串包含型号和制造商名称。参数ulParam指定为pvParam参数中缓冲区的长度,在成功返回时,参数pvParam中包含Unicode字符集中的字符串。

    SPI_GETPLATFORMTYPE:返回一个指定Windows CE设备类型的字符串,例如"H/PC"。参数ulParam规定pvParam参数缓冲区的长度,后者在成功返回时包含一个Unicode字符集中的字符串。该字符串允许象 H/PC EXPLORER一样的应用程序来确定设备类型。

    SPI_GETWAKEUPDLETIMEOUT:在用户通知重新激活某个挂起的设备之后,可获取的Windows CE延缓响应的时间量。参数pvParam指向一个DWORD类型变量以返回时间值,单位为秒。如果pvParam值为0那么该标志被忽略。

    SPI_GETWORKAREA:检索工作区大小。工作区是指没有被任务遮盖的屏幕部分。

    SPI_SETBATTERYidletimeout:在Windows CE没有因用户操作而挂起之前,电池电源能坚持给系统供电的时间量可以使用该标志来设置。只要键盘或触摸屏处在活动状态(有输入),那么Windows CE操作系统及电池电源仍将工作。参数ulParam指定要设置的时间,单位为秒。如果ulParam设置为0,那么该标志被忽略。

    SPI_SETEXTERNALIDLETIMEOUT:在Windows CE没有因用户操作而挂起之前,交流电源能坚持给系统供电的时间量可以使用该标志来设置。只要键盘或触摸屏幕处在活动状态,那么Windows CE操作系统及AC电源仍将工作。参数ulParam指定要设置的时间,单位为秒。如果ulParam设为0,那么该标志被忽略。SPL_SETMOUSE:设置鼠标的两个阈值和速度。

    SPI_SETWAKEUPIDLETIMEOUT:在用户通知重新激活某个挂起的设备之后,Windows CE延缓响应的时间长度量可使用该标志来设置。参数ulParam指定这个时间量,单位为秒,如果ulParam设置为0,那么该标志被忽略。

    SPI_SETWORKAREA设置工作区大小,工作区是指没有被任务条遮盖的屏幕部分。如果用来获取平台类型或OEM信息串的pvParam缓冲区太小,那么该函数会调用失败,并出现错误值ERROR_INSUFFICENT_BUFFERWindows CE只支持该函数的UNICODE版。Windows CE不支持参数fWinlni的取值为SPIF_SENDWININICHANGE的情形。

     

    源文档 <http://baike.baidu.com/view/1079845.htm?fr=ala0_1>

     

     

     

 

typedef struct tagHW_PROFILE_INFO {

DWORD dwDockInfo;

TCHAR szHwProfileGuid[HW_PROFILE_GUIDLEN];

TCHAR szHwProfileName[MAX_PROFILE_LEN];
} HW_PROFILE_INFO,

*LPHW_PROFILE_INFO;

 

typedef enum
{
 
NameUnknown = 0,
 
NameFullyQualifiedDN= 1,
 
NameSamCompatible= 2,
 
NameDisplay= 3, 

  NameUniqueId= 6,
 
NameCanonical= 7,
 
NameUserPrincipal= 8,
 
NameCanonicalEx= 9,
 
NameServicePrincipal= 10,
 
NameDnsDomain= 12
}EXTENDED_NAME_FORMAT,

*PEXTENDED_NAME_FORMAT;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值