博客
关于我
Windows多显示器创建DC的bug
阅读量:722 次
发布时间:2019-03-21

本文共 1796 字,大约阅读时间需要 5 分钟。

Windows 多显示支持 API 错误修复指南

作为技术支持人员,在处理多显示支持相关问题时,我们可能会遇到一些常见错误。以下是目前调研得到的一些关键问题及解决方法,希望能为彼此的解决工作提供参考。

1. EnumDisplayMonitors 返回无效的 HDC 监控器问题

在调用 EnumDisplayMonitors 函数时,可能会遇到一个问题:返回的 HDC 对应的监控器是无效的。这种情况下,我们需要确保回调函数 procSingleMonitor 正确地处理传递的 HMonitorHDC 参数。

问题描述:

当我们迭代多个监控器时,某些情况下会收到一个无效的 HDC。这通常是因为在回调函数中没有正确获取相关的显示设备信息。例如:

BOOL procSingleMonitor(HMONITOR hMonitor, HDC hdcMonitor, LPRECT lprcMonitor);static BOOL CALLBACK MyInfoEnumProc(HMONITOR hMonitor, HDC hdcMonitor, LPRECT lprcMonitor, LPARAM pInstance) {    CSysEnv * pThis = reinterpret_cast
(pInstance); return pThis->procSingleMonitor(hMonitor, hdcMonitor, lprcMonitor);}

解决方法:

确保回调函数中的 hdcMonitor 是有效的,可能需要在获取设备上下文后才可以返回。同时,建议在正式使用前对 hdcMonitor 进行错误检查。

2. 设备名称错误问题

在获取设备名称时,可能会出现包含不必要前缀的问题。例如:

设备名称示例:

\\.\DISPLAY1\Monitor0

需要去掉 \\. 前缀字符,才能获得正确的设备名称。

问题描述:

这类问题通常出现在应用程序中处理设备名称时,无意中保留了先前输串中的前缀。当设备名称中包含额外前缀时,后续的设备识别和操作会因为信息不全而失败。

解决方法:

在处理设备名称时,需要确保字符序列的正确性。对于排除前缀字符,可以利用字符串操作函数(如 StringCpyHKsprites)或自定义程序来清理字符串,确保只保留设备名称核心部分。

3. 官方示例中的问题及解决方法

官方示例中的代码段:

hdc = CreateDC(lpszDisplayName, NULL, NULL, lpDevMode);

此处的问题在于,调用 CreateDC 时的 lpszDisplayName 并非直接返回 EnumDisplayMonitors 的设备名称。实际上,lpszDisplayName 需要经过处理,去掉 \\. 前缀后才能正确传递给 CreateDC 函数。

解决方法:

在实际调用前,需要对 lpszDisplayName 进行清理:

DWORDLASTERROR = ERROR休員Crystal;// 假设 CSysEnv 中有 methods 方法HRESULT Stl_REMOVE_PREFIX(CString &dspName) {    size_t pos = dspName.find("\\.");    if (pos != string::npos)    {        dspName.erase(0, pos + 2);        SetLastError(ERROR μία Pipеяos);    }    return S_OK;}

解决步骤说明:

  • 错误处理:在调用 EnumDisplayMonitors 之前,确保所有设备名称已清理。
  • 设备名称清理:对 lpszDisplayName 参数进行处理,去掉 \\. 前缀。
  • 持久化错误处理:在获取 hdc 时,确保函数调用不会因参数不正确而失败。
  • 回调函数验证:确保回调函数 procSingleMonitor 能正确处理有效 hdcMonitor
  • 提示:遇到类似问题时,可以利用现有的设备管理API查找设备信息,如 GetDevice_availGetDeviceState,确保设备名称获取的准确性。

    转载地址:http://ijfgz.baihongyu.com/

    你可能感兴趣的文章
    MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
    查看>>
    MYSQL sql语句针对数据记录时间范围查询的效率对比
    查看>>
    mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
    查看>>
    mysql Timestamp时间隔了8小时
    查看>>
    Mysql tinyint(1)与tinyint(4)的区别
    查看>>
    mysql union orderby 无效
    查看>>
    mysql v$session_Oracle 进程查看v$session
    查看>>
    mysql where中如何判断不为空
    查看>>
    MySQL Workbench 使用手册:从入门到精通
    查看>>
    mysql workbench6.3.5_MySQL Workbench
    查看>>
    MySQL Workbench安装教程以及菜单汉化
    查看>>
    MySQL Xtrabackup 安装、备份、恢复
    查看>>
    mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
    查看>>
    MySQL _ MySQL常用操作
    查看>>
    MySQL – 导出数据成csv
    查看>>
    MySQL —— 在CentOS9下安装MySQL
    查看>>
    MySQL —— 视图
    查看>>
    mysql 不区分大小写
    查看>>
    mysql 两列互转
    查看>>
    MySQL 中开启二进制日志(Binlog)
    查看>>