CreateDCA 函数 (wingdi.h)
CreateDC 函数使用指定名称为设备创建设备上下文(DC)。
语法
HDC CreateDCA(
LPCSTR pwszDriver,
[in] LPCSTR pwszDevice,
LPCSTR pszPort,
[in] const DEVMODEA *pdm
);
参数
pwszDriver
指向以 null 结尾的字符串的指针,该字符串指定 DISPLAY 或特定显示设备的名称。 对于打印,建议将 NULL 传递给 lpszDriver,因为 GDI 会忽略打印机设备的 lpszDriver。
[in] pwszDevice
指向以 null 结尾的字符串的指针,该字符串指定要使用的特定输出设备的名称,如打印管理器(例如 Epson FX-80)。 它不是打印机型号名称。 必须使用 lpszDevice 参数。
若要获取显示的有效名称,请调用 EnumDisplayDevices。
如果 lpszDriver 为 DISPLAY 或特定显示设备的设备名称,则必须 lpszDeviceNULL 或相同的设备名称。 如果 lpszDeviceNULL,则会为主显示设备创建 DC。
如果系统上有多个监视器,则调用 CreateDC(TEXT("DISPLAY"),NULL,NULL,NULL)
将创建涵盖所有监视器的 DC。
pszPort
此参数将被忽略,应设置为 NULL。 它仅用于与 16 位 Windows 的兼容性。
[in] pdm
指向包含设备驱动程序特定于设备的初始化数据的 DEVMODE 结构的指针。 DocumentProperties 函数检索为指定设备填充的此结构。 如果设备驱动程序要使用用户指定的默认初始化(如果有的话),pdm 参数必须 NULL。
如果 lpszDriver 为 DISPLAY,则 pdm必须为 NULL;然后,GDI 使用显示设备的当前 DEVMODE。
返回值
如果函数成功,则返回值是指定设备的 DC 的句柄。
如果函数失败,则返回值 NULL。
言论
请注意,DC 的句柄只能由单个线程一次使用。
对于参数 lpszDriver 和 lpszDevice,请调用 EnumDisplayDevices 以获取显示的有效名称。
不再需要 DC 时,请调用 DeleteDC 函数。
如果 lpszDriver 或 lpszDevice 为 DISPLAY,则调用 Create DC 的线程将拥有创建的 HDC。 销毁此线程后,HDC 不再有效。 因此,如果创建 HDC 并将其传递给另一个线程,则退出第一个线程,第二个线程将无法使用 HDC。
调用
调用 createDC 为打印机设备创建 HDC 时,打印机驱动程序将验证 DEVMODE。 如果打印机驱动程序确定 DEVMODE 无效(即打印机驱动程序无法转换或使用 DEVMODE),打印机驱动程序将提供默认的 DEVMODE 来创建打印机设备的 HDC。
ICM: 若要启用 ICM,请将 DEVMODE 结构的 dmICMMethod 成员(pInitData 参数指向)设置为适当的值。
例子
有关示例,请参阅 捕获图像。
注意
wingdi.h 标头将 CreateDC 定义为一个别名,该别名根据 UNICODE 预处理器常量的定义自动选择此函数的 ANSI 或 Unicode 版本。 将中性编码别名与不中性编码的代码混合使用可能会导致编译或运行时错误不匹配。 有关详细信息,请参阅函数原型的
要求
要求 | 价值 |
---|---|
最低支持的客户端 | Windows 2000 Professional [仅限桌面应用] |
支持的最低服务器 | Windows 2000 Server [仅限桌面应用] |
目标平台 | 窗户 |
标头 | wingdi.h (包括 Windows.h) |
库 | Gdi32.lib |
DLL | Gdi32.dll |