SystemParametersInfoA 函数 (winuser.h)
重要
某些信息与预发行产品相关,该产品在商业发布之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
检索或设置系统范围参数之一的值。 此函数还可以在设置参数时更新用户配置文件。
语法
BOOL SystemParametersInfoA(
[in] UINT uiAction,
[in] UINT uiParam,
[in, out] PVOID pvParam,
[in] UINT fWinIni
);
参数
[in] uiAction
类型: UINT
要检索或设置的系统范围参数。 可能的值按以下相关参数表进行组织:
- 辅助功能参数
- 桌面参数
- 图标参数
- 输入参数
- 菜单参数
- 电源参数
- 屏幕保护程序参数
- 超时参数
- UI 效果参数
- 窗口参数
下面是辅助功能参数。
辅助功能参数 | 含义 |
---|---|
|
检索有关与辅助功能关联的超时期限的信息。
pvParam 参数必须指向接收信息的 ACCESSTIMEOUT 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(ACCESSTIMEOUT) 。
|
|
确定是启用还是禁用音频说明。
pvParam 参数是指向 AUDIODESCRIPTION 结构的指针。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(AUDIODESCRIPTION) 。
虽然有视觉障碍的用户可能会听到视频内容中的音频,但视频中有很多没有相应音频的操作。 视频中发生情况的特定音频说明可帮助这些用户更好地了解内容。 此标志使你能够确定是否启用了音频说明以及使用哪种语言。 Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
确定是启用还是禁用动画。
pvParam 参数必须指向一个 BOOL 变量,该变量在启用动画时接收 TRUE,否则为 FALSE。
显示功能(如闪烁、闪烁、闪烁和移动内容)可能会导致照片敏感癫痫用户癫痫发作。 通过此标志,可以确定是否在工作区中禁用了此类动画。 Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
确定是启用还是禁用重叠内容。
pvParam 参数必须指向一个 BOOL 变量(如果启用)接收 TRUE;否则,该变量必须指向 FALSE。
背景图像、纹理背景、文档上的水印、alpha 混合和透明度等显示功能会降低前景和背景之间的对比度,使视力不佳的用户更难看到屏幕上的对象。 此标志使你能够确定此类重叠内容是否已禁用。 Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
检索有关 FilterKeys 辅助功能的信息。
pvParam 参数必须指向接收信息的 FILTERKEYS 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(FILTERKEYS) 。
|
|
检索使用 DrawFocusRect 绘制的焦点矩形的上边缘和下边缘的高度(以像素为单位)。
pvParam 参数必须指向 UINT 值。
Windows 2000: 不支持此参数。 |
|
检索使用 DrawFocusRect 绘制的焦点矩形的左右边缘的宽度(以像素为单位)。
pvParam 参数必须指向 UINT。
Windows 2000: 不支持此参数。 |
|
检索有关 HighContrast 辅助功能的信息。
pvParam 参数必须指向接收信息的 HIGHCONTRAST 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(HIGHCONTRAST) 。
有关一般讨论,请参阅备注。 |
|
检索一个值,该值确定 Windows 8 是使用硬件的默认缩放平台显示应用,还是转到下一个较高的平台。 此值基于当前“放大屏幕上的所有内容”设置,该设置位于电脑设置的“轻松使用”部分:1 表示打开,0 表示关闭。
应用可以为以下每种缩放平台提供文本和图像资源:100%、140% 和 180%。 提供针对特定规模优化的单独资源可避免因调整大小而失真。 Windows 8 根据多种因素(包括屏幕大小和像素密度)确定适当的缩放平台。 当选择“放大屏幕上的所有内容” (SPI_GETLOGICALDPIOVERRIDE 返回值 1) 时,Windows 将使用下一个较高平台中的资源。 例如,在 Windows 确定应使用 SCALE_100_PERCENT刻度的硬件的情况下,此替代会导致 Windows 使用 SCALE_140_PERCENT 缩放值,前提是它不违反其他约束。
注意 不应使用此值。 它在后续版本的 Windows 中可能已更改或不可用。 请改用 GetScaleFactorForDevice 函数或 DisplayProperties 类来检索首选比例系数。 桌面应用程序应使用桌面逻辑 DPI,而不是比例系数。 可以通过 GetDeviceCaps 函数检索桌面逻辑 DPI。
|
|
检索应显示通知弹出窗口的时间(以秒为单位)。
pvParam 参数必须指向接收消息持续时间的 ULONG。
有视觉障碍或认知障碍(如 ADHD 和阅读障碍)的用户可能需要更长的时间才能阅读通知消息中的文本。 此标志使你能够检索消息持续时间。 Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
检索鼠标 ClickLock 功能的状态。
pvParam 参数必须指向一个 BOOL 变量(如果启用)接收 TRUE;否则,该变量必须指向 FALSE。 有关详细信息,请参阅 鼠标输入概述。
Windows 2000: 不支持此参数。 |
|
检索锁定主鼠标按钮之前的时间延迟。
pvParam 参数必须指向接收时间延迟(以毫秒为单位)的 DWORD。 仅当 SPI_SETMOUSECLICKLOCK 设置为 TRUE 时,才会启用此功能。 有关详细信息,请参阅 鼠标输入概述。
Windows 2000: 不支持此参数。 |
|
检索有关 MouseKeys 辅助功能的信息。
pvParam 参数必须指向接收信息的 MOUSEKEYS 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(MOUSEKEYS) 。
|
|
检索鼠标声纳功能的状态。
pvParam 参数必须指向一个 BOOL 变量,该变量在启用时接收 TRUE,否则接收 FALSE。 有关详细信息,请参阅 鼠标输入概述。
Windows 2000: 不支持此参数。 |
|
检索鼠标消失功能的状态。
pvParam 参数必须指向一个 BOOL 变量,该变量在启用时接收 TRUE,否则接收 FALSE。 有关详细信息,请参阅 鼠标输入概述。
Windows 2000: 不支持此参数。 |
|
确定屏幕审阅者实用工具是否正在运行。 屏幕审阅者实用工具将文本信息定向到输出设备,例如语音合成器或盲文显示器。 设置此标志后,应用程序应在以图形方式呈现信息的情况下提供文本信息。
pvParam 参数是指向 BOOL 变量的指针,该变量在屏幕审阅者实用工具正在运行时接收 TRUE,否则接收 FALSE。
注意 Windows 附带的屏幕阅读器“讲述人”不会设置 SPI_SETSCREENREADER 或 SPI_GETSCREENREADER 标志。
|
|
不支持此参数。
Windows Server 2003 和 Windows XP/2000: 用户应通过控制面板控制此设置。 |
|
确定“显示声音”辅助功能标志是打开还是关闭。 如果它处于打开状态,则用户要求应用程序在仅以有声形式呈现信息的情况下以可视方式呈现信息。
pvParam 参数必须指向一个 BOOL 变量,该变量在功能处于打开状态时接收 TRUE;如果关闭,则为 FALSE。
使用此值等效于使用 SM_SHOWSOUNDS 调用 GetSystemMetrics。 这是建议的调用。 |
|
检索有关 SoundSentry 辅助功能的信息。
pvParam 参数必须指向接收信息的 SOUNDSENTRY 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(SOUNDSENTRY) 。
|
|
检索有关 StickyKeys 辅助功能的信息。
pvParam 参数必须指向接收信息的 STICKYKEYS 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(STICKYKEYS) 。
|
|
检索有关 ToggleKeys 辅助功能的信息。
pvParam 参数必须指向接收信息的 TOGGLEKEYS 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(TOGGLEKEYS) 。
|
|
设置与辅助功能关联的超时期限。
pvParam 参数必须指向包含新参数的 ACCESSTIMEOUT 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(ACCESSTIMEOUT) 。
|
|
打开或关闭音频说明功能。
pvParam 参数是指向 AUDIODESCRIPTION 结构的指针。
虽然视力受损的用户可能会听到视频内容中的音频,但视频中有很多没有相应音频的操作。 视频中发生情况的特定音频说明可帮助这些用户更好地了解内容。 此标志使你能够启用或禁用其提供的语言的音频说明。 Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
打开或关闭工作区动画。
pvParam 参数是 BOOL 变量。 将 pvParam 设置为 TRUE 以在工作区中启用动画和其他暂时性效果,或将 FALSE 设置为禁用它们。
显示功能(如闪烁、闪烁、闪烁和移动内容)可能会导致照片敏感癫痫用户癫痫发作。 此标志使你能够启用或禁用所有此类动画。 Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
打开或关闭重叠内容 (,例如背景图像和水印) 。
pvParam 参数是 BOOL 变量。 将 pvParam 设置为 TRUE 可禁用重叠内容,将 FALSE 设置为启用重叠内容。
背景图像、纹理背景、文档上的水印、alpha 混合和透明度等显示功能会降低前景和背景之间的对比度,使视力不佳的用户更难看到屏幕上的对象。 此标志使你能够启用或禁用所有此类重叠内容。 Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
设置 FilterKeys 辅助功能的参数。
pvParam 参数必须指向包含新参数的 FILTERKEYS 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(FILTERKEYS) 。
|
|
将 使用 DrawFocusRect 绘制的焦点矩形的上边缘和下边缘的高度设置为 pvParam 参数的值。
Windows 2000: 不支持此参数。 |
|
将 使用 DrawFocusRect 绘制的焦点矩形的左边缘和右边缘的高度设置为 pvParam 参数的值。
Windows 2000: 不支持此参数。 |
|
设置 HighContrast 辅助功能的参数。
pvParam 参数必须指向包含新参数的 HIGHCONTRAST 结构。 将此结构的 cbSize 成员和 uiParam 参数设置为 sizeof(HIGHCONTRAST) 。
|
|
请勿使用。 |
|
设置通知弹出窗口应显示的时间(以秒为单位)。
pvParam 参数指定消息持续时间。
有视觉障碍或认知障碍(如 ADHD 和阅读障碍)的用户可能需要更长的时间才能阅读通知消息中的文本。 使用此标志可以设置消息持续时间。 Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
打开或关闭鼠标 ClickLock 辅助功能。 当单击鼠标主按钮并按住 SPI_SETMOUSECLICKLOCKTIME指定的时间时,此功能会暂时锁定该按钮。
pvParam 参数为 on 指定 TRUE,为 off 指定 FALSE。 默认值为 off。 有关详细信息,请参阅备注和 AboutMouse 输入。
Windows 2000: 不支持此参数。 |
|
调整锁定主鼠标按钮之前的时间延迟。
uiParam 参数应设置为 0。
pvParam 参数指向指定以毫秒为单位的时间延迟的 DWORD。 例如,为 1 秒延迟指定 1000。 默认值为 1200。 有关详细信息,请参阅 鼠标输入概述。
Windows 2000: 不支持此参数。 |
|
设置 MouseKeys 辅助功能的参数。
pvParam 参数必须指向包含新参数的 MOUSEKEYS 结构。 将此结构的 cbSize 成员和 uiParam 参数设置为 sizeof(MOUSEKEYS) 。
|
|
打开或关闭 Sonar 辅助功能。 当用户按下并释放 Ctrl 键时,此功能简要显示鼠标指针周围的几个同心圆。
pvParam 参数为 on 指定 TRUE,为 off 指定 FALSE。 默认值为 off。 有关详细信息,请参阅 鼠标输入概述。
Windows 2000: 不支持此参数。 |
|
打开或关闭“消失”功能。 此功能在用户键入时隐藏鼠标指针;当用户移动鼠标时,指针再次出现。
pvParam 参数为 on 指定 TRUE,为 off 指定 FALSE。 默认值为 off。 有关详细信息,请参阅 鼠标输入概述。
Windows 2000: 不支持此参数。 |
|
确定屏幕评审实用工具是否正在运行。
uiParam 参数为 on 指定 TRUE,为 off 指定 FALSE。
注意 Windows 附带的屏幕阅读器“讲述人”未设置 SPI_SETSCREENREADER 或 SPI_GETSCREENREADER 标志。
|
|
不支持此参数。
Windows Server 2003 和 Windows XP/2000: 用户应通过控制面板控制此设置。 |
|
打开或关闭 ShowSounds 辅助功能。 uiParam 参数为 on 指定 TRUE,为 off 指定 FALSE。 |
|
设置 SoundSentry 辅助功能的参数。
pvParam 参数必须指向包含新参数的 SOUNDSENTRY 结构。 将此结构的 cbSize 成员和 uiParam 参数设置为 sizeof(SOUNDSENTRY) 。
|
|
设置 StickyKeys 辅助功能的参数。
pvParam 参数必须指向包含新参数的 STICKYKEYS 结构。 将此结构的 cbSize 成员和 uiParam 参数设置为 sizeof(STICKYKEYS) 。
|
|
设置 ToggleKeys 辅助功能的参数。
pvParam 参数必须指向包含新参数的 TOGGLEKEYS 结构。 将此结构的 cbSize 成员和 uiParam 参数设置为 sizeof(TOGGLEKEYS) 。
|
下面是桌面参数。
桌面参数 | 含义 |
---|---|
|
确定是否启用 ClearType。
pvParam 参数必须指向一个 BOOL 变量,如果启用 ClearType,则接收 TRUE;否则,该变量必须指向 FALSE。
ClearType 是一种软件技术,可提高液晶显示器 (液晶显示器) 显示器上文本的可读性。 Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
检索桌面壁纸的位图文件的完整路径。 pvParam 参数必须指向缓冲区才能接收以 null 结尾的路径字符串。 将 uiParam 参数设置为 pvParam 缓冲区的大小(以字符为单位)。 返回的字符串不超过 MAX_PATH 个字符。 如果没有桌面壁纸,则返回的字符串为空。 |
|
确定是否启用投影效果。
pvParam 参数必须指向一个 BOOL 变量,如果启用,则返回 TRUE;如果禁用,则返回 FALSE。
Windows 2000: 不支持此参数。 |
|
确定本机用户菜单是否具有平面菜单外观。
pvParam 参数必须指向一个 BOOL 变量,如果设置了平面菜单外观,则返回 TRUE,否则返回 FALSE。
Windows 2000: 不支持此参数。 |
|
确定是否启用字体平滑功能。 此功能使用字体抗锯齿,通过绘制不同灰色级别的像素,使字体曲线看起来更平滑。
pvParam 参数必须指向一个 BOOL 变量,该变量在启用该功能时接收 TRUE;如果功能未启用,则为 FALSE。 |
|
检索 在 ClearType 平滑处理中使用的对比度值。
pvParam 参数必须指向接收信息的 UINT。 有效的对比度值为 1000 到 2200。 默认值为 1400。
Windows 2000: 不支持此参数。 |
|
检索字体平滑方向。
pvParam 参数必须指向接收信息的 UINT。 可能 的值FE_FONTSMOOTHINGORIENTATIONBGR ( 蓝-绿-红) 和 FE_FONTSMOOTHINGORIENTATIONRGB (红-绿-蓝) 。
Windows XP/2000: 在 Windows XP SP2 之前不支持此参数。 |
|
检索字体平滑的类型。
pvParam 参数必须指向接收信息的 UINT。 可能的值为 FE_FONTSMOOTHINGSTANDARD 和 FE_FONTSMOOTHINGCLEARTYPE。
Windows 2000: 不支持此参数。 |
|
检索主显示器上工作区的大小。 工作区域是系统任务栏或应用程序桌面工具栏未遮挡的屏幕部分。
pvParam 参数必须指向接收工作区坐标的 RECT 结构,以物理像素大小表示。 调用方的任何 DPI 虚拟化模式都不会影响此输出。
若要获取主显示监视器以外的监视器的工作区域,请调用 GetMonitorInfo 函数。 |
|
打开或关闭 ClearType。
pvParam 参数是 BOOL 变量。 将 pvParam 设置为 TRUE 以启用 ClearType,或 将 FALSE 设置为禁用它。
ClearType 是一种软件技术,可提高 LCD 监视器上文本的可读性。 Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
重新加载系统游标。 将 uiParam 参数设置为零,将 pvParam 参数设置为 NULL。 |
|
通过使 Windows 从 WIN.INI 文件中读取 Pattern= 设置来设置当前桌面模式。 |
|
注意 使用 SPI_SETDESKWALLPAPER 标志时, SystemParametersInfo 返回 TRUE ,除非 (出现错误,例如) 指定的文件不存在时。
|
|
启用或禁用投影效果。 将 pvParam 设置为 TRUE 可启用投影效果,将 设置为 FALSE 以禁用它。 还必须在窗口类样式中 CS_DROPSHADOW 。
Windows 2000: 不支持此参数。 |
|
启用或禁用本机用户菜单的平面菜单外观。 将 pvParam 设置为 TRUE 可启用平面菜单外观,将 设置为 FALSE 以禁用它。
启用后,菜单栏将 COLOR_MENUBAR 用于菜单栏背景, COLOR_MENU 用于菜单弹出背景, COLOR_MENUHILIGHT 填充当前菜单选择, COLOR_HILIGHT 当前菜单选择的轮廓。 如果禁用,则使用与 Windows 2000 中相同的指标和颜色绘制菜单。 Windows 2000: 不支持此参数。 |
|
启用或禁用字体平滑功能,该功能使用字体抗锯齿功能,通过绘制不同灰度级别的像素,使字体曲线看起来更平滑。
若要启用该功能,请将 uiParam 参数设置为 TRUE。 若要禁用该功能,请将 uiParam 设置为 FALSE。 |
|
设置 ClearType 平滑中使用的对比度值。
pvParam 参数是对比度值。 有效的对比度值为 1000 到 2200。 默认值为 1400。
SPI_SETFONTSMOOTHINGTYPE 还必须设置为 FE_FONTSMOOTHINGCLEARTYPE。 Windows 2000: 不支持此参数。 |
|
设置字体平滑方向。
pvParam 参数FE_FONTSMOOTHINGORIENTATIONBGR (蓝-绿-红) 或FE_FONTSMOOTHINGORIENTATIONRGB (红-绿-蓝) 。
Windows XP/2000: 在 Windows XP SP2 之前不支持此参数。 |
|
设置字体平滑类型。 如果使用标准抗锯齿,则 pvParam 参数为FE_FONTSMOOTHINGSTANDARD,如果使用 ClearType,则为FE_FONTSMOOTHINGCLEARTYPE。 默认值为 FE_FONTSMOOTHINGSTANDARD。
还必须设置SPI_SETFONTSMOOTHING 。 Windows 2000: 不支持此参数。 |
|
设置工作区的大小。 工作区域是系统任务栏或应用程序桌面工具栏未遮挡的屏幕部分。 pvParam 参数是指向 RECT 结构的指针,该结构指定以虚拟屏幕坐标表示的新工作区矩形。 在具有多个显示监视器的系统中, 函数设置包含指定矩形的监视器的工作区域。 |
下面是图标参数。
图标参数 | 含义 |
---|---|
|
检索与图标关联的指标。
pvParam 参数必须指向接收信息的 ICONMETRICS 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(ICONMETRICS) 。
|
|
检索当前图标标题字体的逻辑字体信息。 uiParam 参数指定 LOGFONT 结构的大小,pvParam 参数必须指向要填充的 LOGFONT 结构。 |
|
确定是否启用图标标题环绕。 pvParam 参数必须指向一个 BOOL 变量(如果启用)接收 TRUE;否则,该变量必须指向 FALSE。 |
|
设置或检索图标单元格的宽度(以像素为单位)。 系统使用此矩形在大图标视图中排列图标。
若要设置此值,请将 uiParam 设置为新值,并将 pvParam 设置为 NULL。 不能将此值设置为小于 SM_CXICON。 若要检索此值, pvParam 必须指向接收当前值的整数。 |
|
设置或检索图标单元格的高度(以像素为单位)。
若要设置此值,请将 uiParam 设置为新值,并将 pvParam 设置为 NULL。 不能将此值设置为小于 SM_CYICON。 若要检索此值, pvParam 必须指向接收当前值的整数。 |
|
设置与图标关联的指标。
pvParam 参数必须指向包含新参数的 ICONMETRICS 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(ICONMETRICS) 。
|
|
重新加载系统图标。 将 uiParam 参数设置为零,将 pvParam 参数设置为 NULL。 |
|
设置用于图标标题的字体。 uiParam 参数指定 LOGFONT 结构的大小,pvParam 参数必须指向 LOGFONT 结构。 |
|
打开或关闭图标标题环绕。 uiParam 参数为 on 指定 TRUE,为 off 指定 FALSE。 |
下面是输入参数。 它们包括与键盘、鼠标、触摸板、笔、输入语言和警告蜂鸣器相关的参数。
输入参数 | 含义 |
---|---|
|
确定警告蜂鸣器是否已打开。
pvParam 参数必须指向一个 BOOL 变量,该变量在蜂鸣器处于打开状态时接收 TRUE;如果关闭,则为 FALSE。 |
|
检索一个 BOOL ,指示应用程序是否可以通过调用 SendInput 函数来模拟键盘或鼠标输入来重置屏幕保护程序计时器。 如果模拟输入将被阻止,pvParam 参数必须指向接收 TRUE 的 BOOL 变量;否则,该变量必须指向 FALSE。 |
|
检索当前联系人可视化设置。 pvParam 参数必须指向接收设置的 ULONG 变量。 有关详细信息,请参阅 联系人可视化。 |
|
检索系统默认输入语言的输入区域设置标识符。 pvParam 参数必须指向接收此值的 HKL 变量。 有关详细信息,请参阅 语言、区域设置和键盘布局。 |
|
检索当前手势可视化设置。 pvParam 参数必须指向接收设置的 ULONG 变量。 有关详细信息,请参阅 手势可视化。 |
|
确定菜单访问键是否始终带有下划线。 pvParam 参数必须指向一个 BOOL 变量,该变量在菜单访问键始终带有下划线时接收 TRUE;如果仅在键盘激活菜单时才为 FALSE,则为 FALSE。 |
|
检索键盘重复延迟设置,该值范围为 0 (大约 250 毫秒延迟) 到 3 (大约 1 秒延迟) 。 与每个值关联的实际延迟可能因硬件而异。 pvParam 参数必须指向接收设置的整数变量。 |
|
确定用户是否依赖于键盘而不是鼠标,并希望应用程序显示本来隐藏的键盘界面。 如果用户依赖键盘,pvParam 参数必须指向接收 TRUE 的 BOOL 变量;否则为 FALSE。 |
|
检索键盘重复速度设置,该值的范围是从 0 (大约 2.5 次每秒重复) 到 31 (大约每秒 30 次重复) 。 实际重复率取决于硬件,可能与线性比例相差多达 20%。 pvParam 参数必须指向接收设置的 DWORD 变量。 |
|
检索两个鼠标阈值和鼠标加速。 pvParam 参数必须指向接收这些值的三个整数数组。 有关详细信息 ,请参阅mouse_event 。 |
|
检索鼠标指针必须保留的矩形的高度(以像素为单位),以便 TrackMouseEvent 生成 WM_MOUSEHOVER 消息。 pvParam 参数必须指向接收高度的 UINT 变量。 |
|
检索鼠标指针必须停留在悬停矩形中的时间(以毫秒为单位),以便 TrackMouseEvent 生成 WM_MOUSEHOVER 消息。 pvParam 参数必须指向接收时间的 UINT 变量。 |
|
检索鼠标指针必须保留的矩形的宽度(以像素为单位),以便 TrackMouseEvent 生成 WM_MOUSEHOVER 消息。 pvParam 参数必须指向接收宽度的 UINT 变量。 |
|
检索当前鼠标速度。 鼠标速度根据鼠标移动的距离确定指针移动的距离。 pvParam 参数必须指向一个整数,该整数接收的值范围为 1 (最慢) 到 20 (最快) 。 默认值为 10。 该值可由最终用户使用鼠标控制面板应用程序设置,也可以由使用 SPI_SETMOUSESPEED的应用程序设置。 |
|
确定是否启用鼠标跟踪功能。 此功能通过简要显示光标的踪迹并快速擦除它们来提高鼠标光标移动的可见性。
pvParam 参数必须指向接收值的整数变量。 如果值为零或 1,则禁用该功能。 如果值大于 1,则启用该功能,该值指示在跟踪中绘制的游标数。 不使用 uiParam 参数。 Windows 2000: 不支持此参数。 |
|
检索鼠标滚轮输入的路由设置。 路由设置确定是将鼠标滚轮输入发送到具有焦点 (前台) 的应用,还是将鼠标光标下的应用发送到应用。
pvParam 参数必须指向接收路由选项的 DWORD 变量。 不使用 uiParam 参数。 如果值为零 (MOUSEWHEEL_ROUTING_FOCUS) ,则鼠标滚轮输入将传送到具有焦点的应用。 如果值为 1 (MOUSEWHEEL_ROUTING_HYBRID) ,鼠标滚轮输入将传送到具有焦点的应用 (桌面应用) 或鼠标指针下的应用 (Windows 应用商店应用) 。 从 Windows 10 开始: 如果值为 2 (MOUSEWHEEL_ROUTING_MOUSE_POS) ,则鼠标滚轮输入将传送到鼠标指针下的应用。 这是新的默认值,MOUSEWHEEL_ROUTING_HYBRID在“设置”中不再可用。 |
|
检索当前笔手势可视化设置。 pvParam 参数必须指向接收设置的 ULONG 变量。 有关详细信息,请参阅 触控笔可视化。 |
|
确定是否启用对齐到默认按钮功能。 如果启用,鼠标光标会自动移动到对话框的默认按钮,例如 “确定” 或 “应用”。 pvParam 参数必须指向一个 BOOL 变量,如果功能处于打开状态,则接收 TRUE;如果关闭,则为 FALSE。 |
|
从 Windows 8 开始: 确定是启用或禁用系统语言栏。 如果启用语言栏,pvParam 参数必须指向接收 TRUE 的 BOOL 变量;否则,该变量必须指向 FALSE。 |
|
从 Windows 8 开始: 确定活动输入设置是否具有每个线程的本地 (、 TRUE) 或全局 (会话、 FALSE) 范围。 pvParam 参数必须指向 BOOL 变量。 |
|
从 Windows 11 版本 24H2 开始: 检索有关精确式触摸板的详细信息,包括与触摸板相关的用户设置和系统信息。
pvParam 参数必须指向TOUCHPAD_PARAMETERS结构。 uiParam 参数必须指定结构的大小。 必须将 TOUCHPAD_PARAMETERS 结构中的 versionNumber 字段的值设置为所使用的结构版本的适当值。 |
|
检索移动水平鼠标滚轮时要滚动的字符数。 pvParam 参数必须指向接收行数的 UINT 变量。 默认值为 3。 |
|
检索移动垂直鼠标滚轮时要滚动的行数。 pvParam 参数必须指向接收行数的 UINT 变量。 默认值为 3。 |
|
打开或关闭警告蜂鸣器。 uiParam 参数为 on 指定 TRUE,为 off 指定 FALSE。 |
|
通过调用 SendInput 函数来模拟键盘或鼠标输入,确定应用程序是否可以重置屏幕保护程序计时器。 如果屏幕保护程序不会通过模拟输入停用, 则 uiParam 参数指定 TRUE ;如果屏幕保护程序将由模拟输入停用,则指定 FALSE 。 |
|
设置当前联系人可视化设置。
pvParam 参数必须指向标识设置的 ULONG 变量。 有关详细信息,请参阅 联系人可视化。
注意 如果禁用联系人可视化效果,则无法启用手势可视化效果。
|
|
设置系统 shell 和应用程序的默认输入语言。 指定的语言必须使用当前系统字符集显示。 pvParam 参数必须指向包含默认语言的输入区域设置标识符的 HKL 变量。 有关详细信息,请参阅 语言、区域设置和键盘布局。 |
|
将鼠标的双击时间设置为 uiParam 参数的值。 如果 uiParam 值大于 5000 毫秒,系统会将双击时间设置为 5000 毫秒。
双击时间是双击的第一次和第二次单击之间可能发生的最大毫秒数。 还可以调用 SetDoubleClickTime 函数来设置双击时间。 若要获取当前双击时间,请调用 GetDoubleClickTime 函数。 |
|
将双击矩形的高度设置为 uiParam 参数的值。
双击矩形是一个矩形,双击的第二次单击必须属于该矩形,才能将其注册为双击。 若要检索双击矩形的高度,请使用 SM_CYDOUBLECLK 标志调用 GetSystemMetrics。 |
|
将双击矩形的宽度设置为 uiParam 参数的值。
双击矩形是一个矩形,双击的第二次单击必须属于该矩形,才能将其注册为双击。 若要检索双击矩形的宽度,请使用 SM_CXDOUBLECLK 标志调用 GetSystemMetrics。 |
|
设置当前手势可视化设置。
pvParam 参数必须指向标识设置的 ULONG 变量。 有关详细信息,请参阅 手势可视化。
注意 如果禁用联系人可视化效果,则无法启用手势可视化效果。
|
|
设置菜单访问键字母的下划线。 pvParam 参数是 BOOL 变量。 将 pvParam 设置为 TRUE 以始终为菜单访问键添加下划线,将 FALSE 设置为仅在从键盘激活菜单时为菜单访问键添加下划线。 |
|
设置键盘重复延迟设置。 uiParam 参数必须指定 0、1、2 或 3,其中 0 设置最短延迟约 250 毫秒) ,3 设置最长延迟 (大约 1 秒) 。 与每个值关联的实际延迟可能因硬件而异。 |
|
设置键盘首选项。 如果用户依赖于键盘而不是鼠标,并且希望应用程序显示本来隐藏的键盘接口, 则 uiParam 参数指定 TRUE ; 否则,uiParam 为 FALSE 。 |
|
设置键盘重复速度设置。 uiParam 参数必须指定介于 0 (大约每秒 2.5 次重复) 到 31 (大约每秒 30 次重复) 范围内的值。 实际重复率取决于硬件,并且可能从线性刻度变化多达 20%。 如果 uiParam 大于 31,则 参数设置为 31。 |
|
设置用于在输入语言之间切换的热键集。 不使用 uiParam 和 pvParam 参数。 值通过再次读取注册表来设置键盘属性表中的快捷键。 必须先设置注册表,然后才能使用此标志。 注册表中的路径为 HKEY_CURRENT_USER\键盘布局\切换. 有效值为“1”= Alt+SHIFT,“2”= CTRL+SHIFT,“3”= none。 |
|
设置两个鼠标阈值和鼠标加速。 pvParam 参数必须指向指定这些值的三个整数数组。 有关详细信息 ,请参阅mouse_event 。 |
|
交换或还原鼠标左键和右键的含义。
uiParam 参数指定 TRUE 以交换按钮的含义,或指定 FALSE 以还原其原始含义。
若要检索当前设置,请使用 SM_SWAPBUTTON 标志调用 GetSystemMetrics。 |
|
设置鼠标指针必须保留的矩形的高度(以像素为单位),以便 TrackMouseEvent 生成 WM_MOUSEHOVER 消息。 将 uiParam 参数设置为新高度。 |
|
设置鼠标指针必须停留在悬停矩形中的时间(以毫秒为单位),以便 TrackMouseEvent 生成 WM_MOUSEHOVER 消息。 仅当在调用 TrackMouseEvent 时在 dwHoverTime 参数中传递HOVER_DEFAULT时,才使用此选项。 将 uiParam 参数设置为新时间。
指定的时间应介于 USER_TIMER_MAXIMUM 和 USER_TIMER_MINIMUM 之间。 如果 uiParam 小于 USER_TIMER_MINIMUM,函数将使用 USER_TIMER_MINIMUM。 如果 uiParam 大于 USER_TIMER_MAXIMUM,则将 USER_TIMER_MAXIMUM函数。 Windows Server 2003 和 Windows XP: 在 Windows Server 2003 SP1 和 Windows XP 与 SP2 之前,操作系统不会强制使用 USER_TIMER_MAXIMUM 和 USER_TIMER_MINIMUM 。 |
|
设置鼠标指针必须保留的矩形的宽度(以像素为单位),以便 TrackMouseEvent 生成 WM_MOUSEHOVER 消息。 将 uiParam 参数设置为新的宽度。 |
|
设置当前鼠标速度。 pvParam 参数是介于 1 (最慢) 到 20 (最快) 之间的整数。 默认值为 10。 此值通常是使用鼠标控制面板应用程序设置的。 |
|
启用或禁用鼠标跟踪功能,该功能通过简要显示光标跟踪并快速擦除它们来提高鼠标光标移动的可见性。
若要禁用该功能,请将 uiParam 参数设置为零或 1。 若要启用该功能,请将 uiParam 设置为大于 1 的值,以指示在跟踪中绘制的游标数。 Windows 2000: 不支持此参数。 |
|
设置鼠标滚轮输入的路由设置。 路由设置确定是将鼠标滚轮输入发送到具有焦点 (前台) 的应用,还是将鼠标光标下的应用发送到应用。
pvParam 参数必须指向接收路由选项的 DWORD 变量。 将 uiParam 参数设置为零。 如果值为零 (MOUSEWHEEL_ROUTING_FOCUS) ,则鼠标滚轮输入将传送到具有焦点的应用。 如果值为 1 (MOUSEWHEEL_ROUTING_HYBRID) ,鼠标滚轮输入将传送到具有焦点的应用 (桌面应用) 或鼠标指针下的应用 (Windows 应用商店应用) 。 从 Windows 10 开始: 如果值为 2 (MOUSEWHEEL_ROUTING_MOUSE_POS) ,则鼠标滚轮输入将传送到鼠标指针下的应用。 这是新的默认值,MOUSEWHEEL_ROUTING_HYBRID在“设置”中不再可用。 |
|
设置当前笔手势可视化设置。 pvParam 参数必须指向标识设置的 ULONG 变量。 有关详细信息,请参阅 触控笔可视化。 |
|
启用或禁用快照到默认按钮功能。 如果启用,鼠标光标会自动移动到对话框的默认按钮,例如 “确定” 或 “应用”。 将 uiParam 参数设置为 TRUE 以启用该功能,将 设置为 FALSE 以禁用该功能。 应用程序在显示对话框时应使用 ShowWindow 函数,以便对话管理器可以定位鼠标光标。 |
|
从 Windows 8 开始: 打开或关闭旧语言栏功能。 pvParam 参数是指向 BOOL 变量的指针。 将 pvParam 设置为 TRUE 以启用旧语言栏,或 将 FALSE 设置为禁用它。 标志在 Windows 8 上受支持,其中旧语言栏被输入切换器替换,因此默认处于关闭状态。 打开旧语言栏是出于兼容性原因而提供的,对输入切换器没有影响。 |
|
从 Windows 8 开始: 确定活动输入设置是否具有每个线程的本地 (、 TRUE) 或全局 (会话、 FALSE) 范围。 pvParam 参数必须是由 PVOID 强制转换的 BOOL 变量。 |
|
从 Windows 11 版本 24H2 开始: 设置有关精确式触摸板的详细信息,包括与触摸板相关的用户设置和系统信息。
pvParam 参数必须指向TOUCHPAD_PARAMETERS结构。 uiParam 参数必须指定结构的大小。 必须将 TOUCHPAD_PARAMETERS 结构中的 versionNumber 字段的值设置为所使用的结构版本的适当值。 |
|
设置移动水平鼠标滚轮时要滚动的字符数。 从 uiParam 参数设置字符数。 |
|
设置移动垂直鼠标滚轮时要滚动的行数。 从 uiParam 参数设置行数。
行数是在不使用修饰键的情况下滚动鼠标滚轮时要滚动的建议行数。 如果数字为 0,则不应发生滚动。 如果要滚动的行数大于可查看的行数,特别是当它 WHEEL_PAGESCROLL (#defined 为 UINT_MAX) ,则滚动操作应解释为单击滚动条页面向下或向上页区域单击一次。 |
下面是菜单参数。
菜单参数 | 含义 |
---|---|
|
确定弹出菜单相对于相应的菜单栏项是左对齐还是右对齐。 pvParam 参数必须指向接收 TRUE(如果右对齐)的 BOOL 变量;否则,该变量必须指向 FALSE。 |
|
确定是否启用菜单淡出动画。 pvParam 参数必须指向一个 BOOL 变量,该变量在启用淡出动画时接收 TRUE,在可禁用时接收 FALSE。 如果禁用淡出动画,菜单将使用幻灯片动画。 除非启用了菜单动画,否则将忽略此标志,可以使用 SPI_SETMENUANIMATION 标志执行此操作。 有关详细信息,请参阅 AnimateWindow。 |
|
检索鼠标光标位于子菜单项上时系统在显示快捷菜单之前等待的时间(以毫秒为单位)。 pvParam 参数必须指向接收延迟时间的 DWORD 变量。 |
|
设置弹出菜单的对齐值。 uiParam 参数为右对齐指定 TRUE,为左对齐指定 FALSE。 |
|
启用或禁用菜单淡出动画。 将 pvParam 设置为 TRUE 以启用菜单淡出效果,或 将 FALSE 设置为禁用它。 如果禁用淡出动画,菜单将使用幻灯片动画。 仅当系统的颜色深度超过 256 种颜色时,才能实现菜单淡出效果。 除非还设置了 SPI_MENUANIMATION ,否则将忽略此标志。 有关详细信息,请参阅 AnimateWindow。 |
|
将 uiParam 设置为鼠标光标位于子菜单项上时系统在显示快捷菜单之前等待的时间(以毫秒为单位)。 |
下面是电源参数。
从 Windows Server 2008 和 Windows Vista 开始,不支持这些电源参数。 相反,若要确定当前显示电源状态,应用程序应注册 GUID_MONITOR_POWER_STATE 通知。 若要确定当前显示电源关闭超时,应用程序应注册 GUID_VIDEO_POWERDOWN_TIMEOUT 电源设置更改通知。 有关详细信息,请参阅 注册 Power Events。
Windows Server 2003 和 Windows XP/2000: 若要确定当前显示电源状态,请使用以下电源参数。
下面是屏幕保护程序参数。
下面是应用程序和服务的超时参数。
下面是 UI 效果。 SPI_SETUIEFFECTS值用于同时启用或禁用所有 UI 效果。 此表包含 UI 效果值的完整列表。
UI 效果参数 | 含义 |
---|---|
|
确定是否启用组合框的滑动打开效果。 pvParam 参数必须指向一个 BOOL 变量,该变量对于 enabled 接收 TRUE,对于 disabled 接收 FALSE。 |
|
确定光标周围是否有阴影。 pvParam 参数必须指向一个 BOOL 变量,该变量在启用阴影时接收 TRUE;如果禁用,则为 FALSE。 仅当系统的颜色深度超过 256 种颜色时,才会显示此效果。 |
|
确定是否启用窗口标题栏的渐变效果。 pvParam 参数必须指向一个 BOOL 变量,该变量对于 enabled 接收 TRUE,对于 disabled 接收 FALSE。 有关渐变效果的详细信息,请参阅 GetSysColor 函数。 |
|
确定是否启用用户界面元素的热跟踪,例如菜单栏上的菜单名称。
pvParam 参数必须指向一个 BOOL 变量,该变量对于 enabled 接收 TRUE,对于 disabled 接收 FALSE。
热跟踪意味着,当光标移动到某个项上时,它将被突出显示,但未选中。 可以查询此值,以确定是否在应用程序的用户界面中使用热跟踪。 |
|
确定是否启用列表框的平滑滚动效果。 pvParam 参数必须指向一个 BOOL 变量,该变量对于 enabled 接收 TRUE,对于 disabled 接收 FALSE。 |
|
确定是否启用菜单动画功能。 必须打开此主控开关才能启用菜单动画效果。
pvParam 参数必须指向一个 BOOL 变量,该变量在启用动画时接收 TRUE;如果禁用动画,则为 FALSE。
如果启用了动画, SPI_GETMENUFADE 指示菜单是使用淡出动画还是幻灯片动画。 |
|
与 SPI_GETKEYBOARDCUES 相同。 |
|
确定是否启用选择淡化效果。
pvParam 参数必须指向一个 BOOL 变量,如果启用,则接收 TRUE;如果禁用,则接收 FALSE。
选择淡出效果会导致用户选择的菜单项暂时停留在屏幕上,同时在菜单关闭后逐渐消失。 |
|
确定是否启用工具提示动画。 pvParam 参数必须指向一个 BOOL 变量,如果启用,则接收 TRUE;如果禁用,则接收 FALSE。 如果启用了工具提示动画, SPI_GETTOOLTIPFADE 指示工具提示是使用淡出动画还是幻灯片动画。 |
|
如果启用了SPI_SETTOOLTIPANIMATION,SPI_GETTOOLTIPFADE指示工具提示动画是使用淡出效果还是幻灯片效果。 pvParam 参数必须指向一个 BOOL 变量,该变量对于淡出动画接收 TRUE或 FALSE(对于幻灯片动画)。 有关幻灯片和淡化效果的详细信息,请参阅 AnimateWindow。 |
|
确定是启用或禁用 UI 效果。 pvParam 参数必须指向一个 BOOL 变量,如果启用所有 UI 效果,则接收 TRUE;如果禁用,则为 FALSE。 |
|
启用或禁用组合框的幻灯片打开效果。 将 pvParam 参数设置为 TRUE 以启用渐变效果,将 设置为 FALSE 以禁用渐变效果。 |
|
启用或禁用光标周围的阴影。 pvParam 参数是 BOOL 变量。 将 pvParam 设置为 TRUE 以启用阴影,将 FALSE 设置为禁用阴影。 仅当系统的颜色深度超过 256 种颜色时,才会显示此效果。 |
|
启用或禁用窗口标题栏的渐变效果。 将 pvParam 参数设置为 TRUE 以启用它,将 设置为 FALSE 以禁用它。 仅当系统的颜色深度超过 256 种颜色时,才有可能产生渐变效果。 有关渐变效果的详细信息,请参阅 GetSysColor 函数。 |
|
启用或禁用用户界面元素(例如菜单栏上的菜单名称)的热跟踪。 将 pvParam 参数设置为 TRUE 以启用它,将 设置为 FALSE 以禁用它。
热跟踪意味着当光标移动到某个项上时,它将被突出显示,但未选中。 |
|
启用或禁用列表框的平滑滚动效果。 将 pvParam 参数设置为 TRUE 以启用平滑滚动效果,或 将 FALSE 设置为禁用它。 |
|
启用或禁用菜单动画。 此主控开关必须处于打开状态,才能发生任何菜单动画。
pvParam 参数是 BOOL 变量;将 pvParam 设置为 TRUE 以启用动画,将 FALSE 设置为禁用动画。
如果启用了动画, SPI_GETMENUFADE 指示菜单是使用淡出动画还是幻灯片动画。 |
|
与 SPI_SETKEYBOARDCUES 相同。 |
|
将 pvParam 设置为 TRUE 以启用选择淡化效果,将 设置为 FALSE 以禁用它。
选择淡出效果会导致用户选择的菜单项暂时停留在屏幕上,同时在菜单关闭后逐渐消失。 仅当系统的颜色深度超过 256 种颜色时,才能实现选择淡出效果。 |
|
将 pvParam 设置为 TRUE 以启用工具提示动画,或 将 FALSE 设置为禁用它。 如果启用,可以使用 SPI_SETTOOLTIPFADE 指定淡出动画或幻灯片动画。 |
|
如果启用了 SPI_SETTOOLTIPANIMATION 标志,请使用 SPI_SETTOOLTIPFADE 来指示 ToolTip 动画是使用淡化效果还是幻灯片效果。 对于淡化动画,请将 pvParam 设置为 TRUE ,将幻灯片动画设置为 FALSE 。 仅当系统的颜色深度超过 256 种颜色时,才能实现工具提示淡出效果。 有关幻灯片和淡化效果的详细信息,请参阅 AnimateWindow 函数。 |
|
启用或禁用 UI 效果。 将 pvParam 参数设置为 TRUE 可启用所有 UI 效果,将 FALSE 设置为禁用所有 UI 效果。 |
以下是窗口参数。
Window 参数 | 含义 |
---|---|
|
确定活动窗口跟踪 (激活鼠标打开的窗口,) 打开还是关闭。 pvParam 参数必须指向一个 BOOL 变量,该变量对于 on 接收 TRUE,对于 off 接收 FALSE。 |
|
确定是否会将通过活动窗口跟踪激活的窗口带到顶部。 pvParam 参数必须指向一个 BOOL 变量,该变量对于 on 接收 TRUE,对于 off 接收 FALSE。 |
|
检索活动窗口跟踪延迟(以毫秒为单位)。 pvParam 参数必须指向接收时间的 DWORD 变量。 |
|
检索与用户操作关联的动画效果。
pvParam 参数必须指向接收信息的 ANIMATIONINFO 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(ANIMATIONINFO) 。
|
|
检索确定窗口大小边框宽度的边框乘数因子。 pvParam 参数必须指向接收此值的整数变量。 |
|
检索编辑控件中的插入点宽度(以像素为单位)。 pvParam 参数必须指向接收此值的 DWORD 变量。 |
|
确定将窗口移动到监视器或监视器数组的上边缘、左边缘或右边缘时,窗口是否停靠。
pvParam 参数必须指向一个 BOOL 变量(如果启用)接收 TRUE;否则,该变量必须指向 FALSE。
使用 SPI_GETWINARRANGING 确定是否启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
确定拖动标题栏时是否还原最大化窗口。
pvParam 参数必须指向一个 BOOL 变量(如果启用)接收 TRUE;否则,该变量必须指向 FALSE。
使用 SPI_GETWINARRANGING 确定是否启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
确定是否启用拖动整个窗口。 pvParam 参数必须指向一个 BOOL 变量(如果启用)接收 TRUE;否则,该变量必须指向 FALSE。 |
|
检索 SetForegroundWindow 在拒绝前台切换请求时闪烁任务栏按钮的次数。 pvParam 参数必须指向接收值的 DWORD 变量。 |
|
检索用户输入后的时间(以毫秒为单位),在此期间,系统不允许应用程序强制自己进入前台。 pvParam 参数必须指向接收时间的 DWORD 变量。 |
|
检索与最小化窗口关联的指标。
pvParam 参数必须指向接收信息的 MINIMIZEDMETRICS 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(MINIMIZEDMETRICS) 。
|
|
检索使用鼠标将窗口拖动到监视器或监视器阵列边缘触发停靠行为的阈值(以像素为单位)。 默认阈值为 1。
pvParam 参数必须指向接收值的 DWORD 变量。
使用 SPI_GETWINARRANGING 确定是否启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
检索使用鼠标将窗口从监视器边缘或监视器数组向中心拖动来触发取消停靠行为的阈值(以像素为单位)。 默认阈值为 20。
使用 SPI_GETWINARRANGING 确定是否启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
从监视器或监视器数组的顶部检索阈值(以像素为单位),其中使用鼠标拖动时将还原垂直最大化的窗口。 默认阈值为 50。
使用 SPI_GETWINARRANGING 确定是否启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
检索与非最小化窗口的非工作区相关联的度量值。
pvParam 参数必须指向接收信息的 NONCLIENTMETRICS 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(NONCLIENTMETRICS) 。
Windows Server 2003 和 Windows XP/2000: 请参阅 NONCLIENTMETRICS 的备注。 |
|
检索使用笔将窗口拖动到监视器或监视器阵列边缘触发停靠行为的阈值(以像素为单位)。 默认值为 30。
使用 SPI_GETWINARRANGING 确定是否启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
检索使用笔将窗口从监视器或监视器阵列的边缘拖动到其中心,从而触发取消停靠行为的阈值(以像素为单位)。 默认阈值为 30。
使用 SPI_GETWINARRANGING 确定是否启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
检索监视器或监视器数组顶部的阈值(以像素为单位),其中使用鼠标拖动时将还原垂直最大化的窗口。 默认阈值为 50。
使用 SPI_GETWINARRANGING 确定是否启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
确定输入法状态窗口是否以每个用户) (可见。 pvParam 参数必须指向一个 BOOL 变量,该变量在状态窗口可见时接收 TRUE;如果状态窗口不可见,则为 FALSE。 |
|
确定窗口在调整到监视器或监视器数组的顶部或底部时是否垂直最大化。
pvParam 参数必须指向一个 BOOL 变量(如果启用)接收 TRUE;否则,该变量必须指向 FALSE。
使用 SPI_GETWINARRANGING 确定是否启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
确定是否启用窗口排列。
pvParam 参数必须指向一个 BOOL 变量(如果启用)接收 TRUE;否则,该变量必须指向 FALSE。
窗口排列方式通过简化拖动或调整窗口大小时的默认行为,减少了移动顶级窗口和调整窗口大小所需的鼠标、笔或触摸交互次数。 以下参数检索单个窗口排列设置:
|
|
设置活动窗口跟踪 (激活鼠标打开的窗口) 打开或关闭。 对于 on,将 pvParam 设置为 TRUE ,将 FALSE 设置为 off。 |
|
确定是否应将通过活动窗口跟踪激活的窗口带到顶部。 对于 on,将 pvParam 设置为 TRUE ,将 FALSE 设置为 off。 |
|
设置活动窗口跟踪延迟。 将 pvParam 设置为激活鼠标指针下的窗口之前要延迟的毫秒数。 |
|
设置与用户操作关联的动画效果。
pvParam 参数必须指向包含新参数的 ANIMATIONINFO 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(ANIMATIONINFO) 。
|
|
设置确定窗口大小边框宽度的边框乘数因子。 uiParam 参数指定新值。 |
|
设置编辑控件中的插入点宽度。 将 pvParam 设置为所需的宽度(以像素为单位)。 默认值和最小值为 1。 |
|
设置当窗口移动到监视器或监视器阵列上的顶部、左侧或右侧停靠目标时,窗口是停靠的。 对于 on,将 pvParam 设置为 TRUE ,将 FALSE 设置为 off。
SPI_GETWINARRANGING 必须为 TRUE 才能启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
设置拖动最大化窗口标题栏时是否还原其标题栏。 对于 on,将 pvParam 设置为 TRUE ,将 FALSE 设置为 off。
SPI_GETWINARRANGING 必须为 TRUE 才能启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
设置打开或关闭整个窗口的拖动。 uiParam 参数为 on 指定 TRUE,为 off 指定 FALSE。 |
|
设置用于检测拖动操作开始的矩形的高度(以像素为单位)。 将 uiParam 设置为新值。 若要检索拖动高度,请使用SM_CYDRAG标志调用 GetSystemMetrics。 |
|
设置用于检测拖动操作开始的矩形的宽度(以像素为单位)。 将 uiParam 设置为新值。 若要检索拖动宽度,请使用SM_CXDRAG标志调用 GetSystemMetrics。 |
|
设置 SetForegroundWindow 在拒绝前台切换请求时闪烁任务栏按钮的次数。 将 pvParam 设置为闪烁的次数。 |
|
设置用户输入后的时间(以毫秒为单位),在此期间,系统不允许应用程序强制自己进入前台。 将 pvParam 设置为新的超时值。
调用线程必须能够更改前台窗口,否则调用将失败。 |
|
设置与最小化窗口关联的指标。
pvParam 参数必须指向包含新参数的 MINIMIZEDMETRICS 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(MINIMIZEDMETRICS) 。
|
|
设置使用鼠标将窗口拖动到监视器或监视器数组边缘时触发停靠行为的阈值(以像素为单位)。 默认阈值为 1。
pvParam 参数必须指向包含新值的 DWORD 变量。
SPI_GETWINARRANGING 必须为 TRUE 才能启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
设置使用鼠标将窗口从监视器或监视器阵列边缘拖动到其中心时触发取消停靠行为的阈值(以像素为单位)。 默认阈值为 20。
pvParam 参数必须指向包含新值的 DWORD 变量。
SPI_GETWINARRANGING 必须为 TRUE 才能启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
设置从监视器顶部开始的阈值(以像素为单位),在使用鼠标拖动时,垂直最大化窗口将还原到该窗口。 默认阈值为 50。
pvParam 参数必须指向包含新值的 DWORD 变量。
SPI_GETWINARRANGING 必须为 TRUE 才能启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
设置与非小窗口的非工作区关联的指标。
pvParam 参数必须指向包含新参数的 NONCLIENTMETRICS 结构。 将此 结构的 cbSize 成员和 uiParam 参数设置为 sizeof(NONCLIENTMETRICS) 。 此外,LOGFONT 结构的 lfHeight 成员必须是负值。
|
|
设置使用笔将窗口拖动到监视器或监视器阵列边缘时触发停靠行为的阈值(以像素为单位)。 默认阈值为 30。
pvParam 参数必须指向包含新值的 DWORD 变量。
SPI_GETWINARRANGING 必须为 TRUE 才能启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
设置使用笔将窗口从监视器或监视器阵列边缘拖动到其中心时触发取消停靠行为的阈值(以像素为单位)。 默认阈值为 30。
pvParam 参数必须指向包含新值的 DWORD 变量。
SPI_GETWINARRANGING 必须为 TRUE 才能启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
设置监视器顶部的阈值(以像素为单位),在使用笔拖动时,垂直最大化窗口将还原到该窗口。 默认阈值为 50。
pvParam 参数必须指向包含新值的 DWORD 变量。
SPI_GETWINARRANGING 必须为 TRUE 才能启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
设置输入法状态窗口是否以每个用户为基础可见。 uiParam 参数为 on 指定 TRUE,为 off 指定 FALSE。 |
|
设置窗口在调整到监视器的顶部或底部时是垂直最大化的。 对于 on,将 pvParam 设置为 TRUE ,将 FALSE 设置为 off。
SPI_GETWINARRANGING 必须为 TRUE 才能启用此行为。 Windows Server 2008、Windows Vista、Windows Server 2003 和 Windows XP/2000: 不支持此参数。 |
|
设置是否启用窗口排列。 对于 on,将 pvParam 设置为 TRUE ,将 FALSE 设置为 off。
窗口排列方式通过简化拖动或调整窗口大小时的默认行为,减少了移动顶级窗口和调整窗口大小所需的鼠标、笔或触摸交互次数。 以下参数设置单个窗口排列设置:
|
[in] uiParam
类型: UINT
一个参数,其用法和格式取决于要查询或设置的系统参数。 有关系统范围参数的详细信息,请参阅 uiAction 参数。 如果未另行指示,则必须为此参数指定零。
[in, out] pvParam
类型: PVOID
一个参数,其用法和格式取决于要查询或设置的系统参数。 有关系统范围参数的详细信息,请参阅 uiAction 参数。 如果未另行指示,则必须为此参数指定 NULL 。 有关 PVOID 数据类型的信息,请参阅 Windows 数据类型。
[in] fWinIni
类型: UINT
如果正在设置系统参数,则指定是否要更新用户配置文件,如果是,则指定是否将 WM_SETTINGCHANGE 消息广播到所有顶级窗口,以通知他们更改。
如果不想更新用户配置文件或广播 WM_SETTINGCHANGE 消息,此参数可以为零,也可以是以下一个或多个值。
值 | 含义 |
---|---|
|
将新的系统范围参数设置写入用户配置文件。 |
|
在更新用户配置文件后广播 WM_SETTINGCHANGE 消息。 |
|
与 SPIF_SENDCHANGE 相同。 |
返回值
类型: BOOL
如果函数成功,则返回值为非零值。
如果函数失败,则返回值为零。 要获得更多的错误信息,请调用 GetLastError。
注解
此函数适用于允许用户自定义环境的应用程序。
键盘布局名称应派生自对应于布局的语言标识符的十六进制值。 例如,美国英语的语言标识符为 0x0409,因此美国英语的主要布局名为“00000409”。 美国英语版式的变体(如 Dvorak 布局)名为“00010409”、“00020409”等。 有关构成语言标识符的主要语言标识符和子语言标识符的列表,请参阅 MAKELANGID 宏。
高对比度配色方案和高对比度模式之间存在差异。 高对比度配色方案将系统颜色更改为具有明显对比度的颜色;通过使用控制面板中的“显示选项”切换到此配色方案。 高对比度模式使用 SPI_GETHIGHCONTRAST 和 SPI_SETHIGHCONTRAST,建议应用程序修改视觉障碍用户的外观。 它涉及使用控制面板) 中的辅助功能选项 (向用户发出声音警告和自定义配色方案等内容。 有关详细信息,请参阅 HIGHCONTRAST。 有关常规辅助功能的详细信息,请参阅 辅助功能。
在按住主按钮以激活鼠标 ClickLock 功能期间,用户可以移动鼠标。 锁定主按钮后,释放主按钮不会导致 WM_LBUTTONUP 消息。 因此,它会在应用程序上显示主按钮仍处于关闭状态。 任何后续按钮消息都会释放主按钮,向应用程序发送 WM_LBUTTONUP 消息,因此可以通过编程方式或通过用户单击任何按钮来解锁该按钮。
此 API 不可识别 DPI,如果调用线程按监视器感知 DPI,则不应使用此 API。 有关此 API 的 DPI 感知版本,请参阅 SystemParametersInfoForDPI。 有关 DPI 感知的详细信息,请参阅 Windows 高 DPI 文档。
示例
以下示例使用 SystemParametersInfo 将鼠标速度加倍。
#include <windows.h>
#include <stdio.h>
#pragma comment(lib, "user32.lib")
void main()
{
BOOL fResult;
int aMouseInfo[3]; // Array for mouse information
// Get the current mouse speed.
fResult = SystemParametersInfo(SPI_GETMOUSE, // Get mouse information
0, // Not used
&aMouseInfo, // Holds mouse information
0); // Not used
// Double it.
if( fResult )
{
aMouseInfo[2] = 2 * aMouseInfo[2];
// Change the mouse speed to the new value.
SystemParametersInfo(SPI_SETMOUSE, // Set mouse information
0, // Not used
aMouseInfo, // Mouse information
SPIF_SENDCHANGE); // Update Win.ini
}
}
注意
winuser.h 标头将 SystemParametersInfo 定义为别名,该别名根据 UNICODE 预处理器常量的定义自动选择此函数的 ANSI 或 Unicode 版本。 将非特定编码别名的使用与非非特定编码的代码混合使用可能会导致不匹配,从而导致编译或运行时错误。 有关详细信息,请参阅 函数原型的约定。
要求
要求 | 值 |
---|---|
最低受支持的客户端 | Windows 2000 Professional [仅限桌面应用] |
最低受支持的服务器 | Windows 2000 Server [仅限桌面应用] |
目标平台 | Windows |
标头 | winuser.h (包括 Windows.h) |
Library | User32.lib |
DLL | User32.dll |
API 集 | windows 8) 中引入的 ext-ms-win-ntuser-sysparams-ext-l1-1-0 ( |