CSourceStream.GetMediaType メソッド (Source.h) - iPosition パラメーターと pMediaType パラメーター
[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayer、IMFMediaEngine、Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayer、IMFMediaEngine、Audio/Video Capture を使用することを強くお勧めします。 Microsoft は、レガシ API を使用する既存のコードを、可能であれば新しい API を使用するように書き換えるよう提案しています。]
GetMediaType メソッドは、優先されるメディアの種類を取得します。
構文
virtual HRESULT GetMediaType(
int iPosition,
CMediaType *pMediaType
);
パラメーター
-
iPosition
-
0 から始まるインデックス値。
-
pMediaType
-
メディアの種類を受け取る CMediaType オブジェクトへのポインター。
戻り値
次の表に示す HRESULT 値のいずれかを返します。
リターン コード | 説明 |
---|---|
|
成功しました。 |
|
範囲外のインデックス。 |
|
インデックスが 0 未満です。 |
|
予期しないエラー。 |
解説
このメソッドには 2 つのバージョンがあります。 1 つのバージョンで CBasePin::GetMediaType メソッドがオーバーライドされ、インデックス値がパラメーターとして受け取られます。 もう 1 つのバージョンは、単一のメディアの種類を取得するように設計されているため、index パラメーターがありません。
単一パラメーター メソッドは、E_UNEXPECTEDを返します。 2 パラメーター メソッドは 、iPosition パラメーターが 0 であることを確認し、単一パラメーター バージョンを呼び出します。 ピンでサポートされているメディアの種類の数に応じて、次のいずれかの方法をオーバーライドする必要があります。
- ピンが 1 つのメディア の種類をサポートしている場合は、単一パラメーター バージョンをオーバーライドします。 ピンでサポートされているメディアの種類を入力します。
- ピンで複数のメディアの種類がサポートされている場合は、2 パラメーター バージョンをオーバーライドします。 CSourceStream::CheckMediaType メソッドもオーバーライドします。
要件
要件 | 値 |
---|---|
ヘッダー | Source.h (Streams.h を含む) |
ライブラリ | Strmbase.lib (製品版ビルド);Strmbasd.lib (デバッグ ビルド) |