次の方法で共有


CDynamicOutputPin.ChangeMediaType メソッド

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

メソッドは ChangeMediaType 、接続のメディアの種類を動的に変更します。 この変更は、フィルター グラフの実行中に発生する可能性があります。 このメソッドが呼び出されると、古いメディアの種類のサンプルを配信できません。 呼び出し元は、古いサンプルが保留中でないことを確認する必要があります。

構文

HRESULT ChangeMediaType(
   const CMediaType *pmt
);

パラメーター

Pmt

メディアの種類を指定する AM_MEDIA_TYPE 構造体へのポインター。

戻り値

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

リターン コード 説明
S_OK
成功しました。
E_FAIL
失敗しました。 所有フィルターで CDynamicOutputPin::SetConfigInfo が呼び出されなかった可能性があります。
VFW_E_NOT_CONNECTED
ピンが接続されていません。

解説

このメソッドを呼び出す前に 、CDynamicOutputPin::StartUsingOutputPin メソッドを 呼び出します。

このメソッドは、最初にダウンストリーム入力ピンが再接続せずに新しい形式を受け入れられるかどうかを確認します。 IPinConnection インターフェイスの入力ピンに対してクエリを実行します。 入力ピンで IPinConnection がサポートされている場合、メソッドは提案されたメディアの種類を使用 して IPinConnection::D ynamicQueryAccept メソッドを呼び出します。 入力ピンが新しいメディアの種類を受け入れる場合、メソッドは IPin::ReceiveConnection メソッドを呼び出し、アロケーターの要件を再ネゴシエーションします。

一方、ダウンストリーム ピンで IPinConnection がサポートされていない場合、または新しいメディアの種類が拒否された場合、メソッドは CDynamicOutputPin::D ynamicReconnect メソッドを呼び出して動的再接続を実行します。

要件

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

関連項目

CDynamicOutputPin クラス