CBasePin.AgreeMediaType メソッド

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

メソッドは AgreeMediaType 、メディアの種類を検索してピン接続を行います。

構文

virtual HRESULT AgreeMediaType(
         IPin       *pReceivePin,
   const CMediaType *pmt
);

パラメーター

pReceivePin

受信ピンの IPin インターフェイスへのポインター。

Pmt

メディアの種類 (NULL) を指定する CMediaType オブジェクトへのポインター。

戻り値

HRESULT 値を返します。 次の表に示す値を指定できます。

リターン コード 説明
S_OK
成功しました。
VFW_E_NO_ACCEPTABLE_TYPES
許容されるメディアの種類が見つかりませんでした。

解説

pmt パラメーターが NULL 以外で、メディアの種類を完全に指定している場合、このメソッドはそのメディアの種類を使用して接続を試行します。 試行が失敗した場合、メソッドはエラーを返します。

pmt パラメーターが NULL の場合、または部分的なメディアの種類を指定する場合、このメソッドは次の順序でメディアの種類を試行します。

  1. 受信ピンの優先メディアの種類。
  2. このピンの推奨されるメディアの種類。

推奨されるメディアの種類は CBasePin::EnumMediaTypes メソッドを使用して列挙され、結果の列挙子は CBasePin::TryMediaTypes メソッドに渡されます。

要件

要件
ヘッダー
Amfilter.h (Stream.h を含む)
ライブラリ
Strmbase.lib (小売ビルド);
Strmbasd.lib (デバッグ ビルド)

関連項目

CBasePin クラス