IFileSinkFilter::GetCurFile 方法 (strmif.h)

[与此页面关联的功能 DirectShow 是一项旧功能。 它已被 MediaPlayerIMFMediaEngine媒体基金会中的音频/视频捕获取代。 这些功能已针对Windows 10和Windows 11进行了优化。 Microsoft 强烈建议新代码尽可能使用 MediaPlayerIMFMediaEngineMedia Foundation 中的音频/视频捕获 ,而不是 DirectShow。 如果可能,Microsoft 建议重写使用旧 API 的现有代码以使用新 API。]

方法 GetCurFile 检索当前文件的名称和媒体类型。

语法

HRESULT GetCurFile(
  [out] LPOLESTR      *ppszFileName,
  [out] AM_MEDIA_TYPE *pmt
);

参数

[out] ppszFileName

接收文件名的指针的地址,作为 OLESTR 类型。

[out] pmt

指向接收媒体类型的 AM_MEDIA_TYPE 结构的指针。 此参数可以按 NULL,在这种情况下, 方法不返回媒体类型。

返回值

返回 HRESULT 值。 可能的值包括以下值。

返回代码 说明
S_OK
成功。
E_FAIL
未打开任何文件。
E_OUTOFMEMORY
内存不足。
E_POINTER
ppszFileName 中的 NULL 指针参数。

备注

如果筛选器尚未打开文件,该方法可能会成功,但在 ppszFileName 参数中返回 NULL。 检查方法返回时的值。

方法为 ppszFileName 中返回的字符串分配内存,如果有任何) ,则为媒体类型中的格式块分配内存 (。 调用方必须通过调用 CoTaskMemFree 来释放它们。 对于媒体类型,可以使用基类库中的 FreeMediaType 函数。

要求

   
最低受支持的客户端 Windows 2000 Professional [仅限桌面应用]
最低受支持的服务器 Windows 2000 Server [仅限桌面应用]
目标平台 Windows
标头 strmif.h (包括 Dshow.h)
Library Strmiids.lib

另请参阅

错误和成功代码

IFileSinkFilter 接口