IVMRSurfaceAllocator::AllocateSurface 方法 (strmif.h)
[与此页面关联的功能 DirectShow 是旧版功能。 它已被 MediaPlayer、 IMFMediaEngine 和 Media Foundation 中的音频/视频捕获所取代。 这些功能已针对Windows 10和Windows 11进行了优化。 Microsoft 强烈建议新代码尽可能在 Media Foundation 中使用 MediaPlayer、 IMFMediaEngine 和 音频/视频捕获 ,而不是 DirectShow。 如果可能,Microsoft 建议重写使用旧 API 的现有代码以使用新 API。]
方法 AllocateSurface
分配 DirectDraw 图面。
语法
HRESULT AllocateSurface(
[in] DWORD_PTR dwUserID,
[in] VMRALLOCATIONINFO *lpAllocInfo,
[in] DWORD *lpdwActualBuffers,
[out] LPDIRECTDRAWSURFACE7 *lplpSurface
);
参数
[in] dwUserID
应用程序定义的DWORD_PTR Cookie,用于唯一标识 VMR 的此实例,以便在分配器表示器的一个实例与多个 VMR 实例一起使用时使用。
[in] lpAllocInfo
指定 VMRALLOCATIONINFO 结构。 请参阅“备注”。
[in] lpdwActualBuffers
[out]输入时,此参数用于请求所需的缓冲区数。 在输出时,它接收实际创建的缓冲区数。
[out] lplpSurface
接收 Direct3D 图面的指针的地址。
返回值
如果该方法成功,则它会返回 S_OK。 如果该方法失败,则会返回错误代码。
返回代码 | 说明 |
---|---|
|
其中一个指针无效。 |
|
在 dwFlags 中,AMAP_3D_TARGET与 AMAP_FORCE_SYSMEM 或 AMAP_ALLOW_SYSMEM 结合使用。 |
|
lpAllocInfo-lpHdr> 指定的 BITMAPINFOHEADER 结构的一个或多个成员不正确。 |
注解
在显式调用 AllocateSurface 之前,客户端应用程序应调用 IVMRSurfaceAllocator::FreeSurface ,以确保 DirectDraw 解码图面前端缓冲区为 NULL。 如果应用程序调用 AllocateSurface 时不为 NULL,则 quartz.dll 的调试版本将导致断言。
在自定义分配器-表示器中实现此方法时,必须检查 lpAllocInfo-lpHdr-biBitCount >>的值。 如果 biBitCount 为零,则必须将其设置为当前显示器的像素深度。 如果 BiBitCount 保留为零,则图面分配将失败,并将创建一个新的 (默认) VMR。
要求
要求 | 值 |
---|---|
最低受支持的客户端 | 具有 SP1 的 Windows XP [仅限桌面应用] |
最低受支持的服务器 | Windows Server 2003 [仅限桌面应用] |
目标平台 | Windows |
标头 | strmif.h (包括 Dshow.h) |
Library | Strmiids.lib |