CSourceStream.GetMediaType メソッド (Source.h) - iPosition パラメーターと pMediaType パラメーター

[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayer、IMFMediaEngine、Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayerIMFMediaEngineAudio/Video Capture を使用することを強くお勧めします。 Microsoft は、レガシ API を使用する既存のコードを、可能であれば新しい API を使用するように書き換えるよう提案しています。]

GetMediaType メソッドは、優先されるメディアの種類を取得します。

構文

virtual HRESULT GetMediaType(
   int        iPosition,
   CMediaType *pMediaType
);

パラメーター

iPosition

0 から始まるインデックス値。

pMediaType

メディアの種類を受け取る CMediaType オブジェクトへのポインター。

戻り値

次の表に示す HRESULT 値のいずれかを返します。

リターン コード 説明
S_OK
成功しました。
VFW_S_NO_MORE_ITEMS
範囲外のインデックス。
E_INVALIDARG
インデックスが 0 未満です。
E_UNEXPECTED
予期しないエラー。

解説

このメソッドには 2 つのバージョンがあります。 1 つのバージョンで CBasePin::GetMediaType メソッドがオーバーライドされ、インデックス値がパラメーターとして受け取られます。 もう 1 つのバージョンは、単一のメディアの種類を取得するように設計されているため、index パラメーターがありません。

単一パラメーター メソッドは、E_UNEXPECTEDを返します。 2 パラメーター メソッドは 、iPosition パラメーターが 0 であることを確認し、単一パラメーター バージョンを呼び出します。 ピンでサポートされているメディアの種類の数に応じて、次のいずれかの方法をオーバーライドする必要があります。

  • ピンが 1 つのメディア の種類をサポートしている場合は、単一パラメーター バージョンをオーバーライドします。 ピンでサポートされているメディアの種類を入力します。
  • ピンで複数のメディアの種類がサポートされている場合は、2 パラメーター バージョンをオーバーライドします。 CSourceStream::CheckMediaType メソッドもオーバーライドします。

要件

要件
ヘッダー Source.h (Streams.h を含む)
ライブラリ Strmbase.lib (製品版ビルド);Strmbasd.lib (デバッグ ビルド)

関連項目

CSourceStream クラス