共用方式為


IMPEG2StreamIdMap::MapStreamId 方法 (strmif.h)

[與此頁面 相關的功能 DirectShow 是舊版功能。 它已被 MediaPlayerIMFMediaEngineMedia Foundation 中的音訊/視訊擷取取代。 這些功能已針對 Windows 10 和 Windows 11 進行優化。 Microsoft 強烈建議新程式代碼盡可能使用 MediaPlayerIMFMediaEngine音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議盡可能重寫使用舊版 API 的現有程式代碼,以使用新的 API。]

方法會將 MapStreamId MPEG-2 程式數據流內基礎數據流的 Stream 標識元對應至媒體內容類型和子數據流篩選資訊。

語法

HRESULT MapStreamId(
  [in] ULONG ulStreamId,
  [in] DWORD MediaSampleContent,
  [in] ULONG ulSubstreamFilterValue,
  [in] int   iDataOffset
);

參數

[in] ulStreamId

PES 數據流的數據流標識碼。

[in] MediaSampleContent

指定數據流的內容。 目前唯一支援的值MPEG2_PROGRAM_ELEMENTARY_STREAM (定义为 axextend.idl) 中的0x00000001。

[in] ulSubstreamFilterValue

指定要在此基礎數據流內傳遞至下游譯碼器的子數據流。 只有低序位元組可以包含有效的篩選值。 如果 iDataOffset = 0,則會忽略此參數。

[in] iDataOffset

子數據流開始的承載位元組位移。

傳回值

如果成功,則傳回S_OK。 如果方法失敗,則會傳回錯誤碼。 如果嘗試MEDIA_PROGRAM_STREAM_MAP MEDIA_PROGRAM_DIRECTORY_PES_PACKET或MEDIA_PROGRAM_PACK_HEADER的 Stream 標識符,此方法會傳回E_NOTIMPL。

備註

這個方法所對應的 Stream標識碼是 PES 標頭中的數據流標識碼。 子數據流篩選最常用來在單一音訊串流上提供多個通道。

規格需求

需求
最低支援的用戶端 Windows XP [僅限傳統型應用程式]
最低支援的伺服器 Windows Server 2003 [僅限桌面應用程式]
目標平台 Windows
標頭 strmif.h (包含 Dshow.h)
程式庫 Strmiids.lib

另請參閱

錯誤和成功碼

IMPEG2StreamIdMap 介面