IVMRSurfaceAllocator::AllocateSurface 方法 (strmif.h)

[与此页面关联的功能 DirectShow 是旧版功能。 它已被 MediaPlayerIMFMediaEngineMedia Foundation 中的音频/视频捕获所取代。 这些功能已针对Windows 10和Windows 11进行了优化。 Microsoft 强烈建议新代码尽可能在 Media Foundation 中使用 MediaPlayerIMFMediaEngine音频/视频捕获 ,而不是 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。 如果该方法失败,则会返回错误代码。

返回代码 说明
E_POINTER
其中一个指针无效。
E_INVALIDARG
dwFlags 中,AMAP_3D_TARGET与 AMAP_FORCE_SYSMEM 或 AMAP_ALLOW_SYSMEM 结合使用。
E_FAIL
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

另请参阅

错误和成功代码

IVMRSurfaceAllocator 接口

使用视频混合呈现器