次の方法で共有


CBasePin.CheckConnect メソッド

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

メソッドは CheckConnect 、ピン接続が適しているかどうかを判断します。

構文

virtual HRESULT CheckConnect(
   IPin *pPin
);

パラメーター

pPin

もう一方のピンの IPin インターフェイスへのポインター。

戻り値

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

リターン コード 説明
S_OK
成功しました。
VFW_E_INVALID_DIRECTION
ピンの方向に互換性がありません。

解説

このメソッドは、接続プロセスの開始時に両方のピンで呼び出されます。 接続ピンは CBasePin::Connect メソッド内から呼び出し、受信ピンは CBasePin::ReceiveConnection メソッド内から呼び出します。

pPin パラメーターで指定されたピンが接続に適しているかどうかを判断するには、このメソッドを使用します。 両方のピンの方向が同じ (両方の入力または両方の出力) 場合、基底クラスはエラーを返します。 派生クラスは、ピン内の他の機能を確認するために、このメソッドをオーバーライドできます。 たとえば、 CBaseOutputPin クラスは、入力ピンの IMemInputPin インターフェイスを照会します。

このメソッドが失敗した場合、接続は失敗し、ピンは CBasePin::BreakConnect メソッドを呼び出します。 BreakConnect を使用して、 でCheckConnect取得したすべてのリソースを解放します。 たとえば、QueryInterface メソッドを呼び出す場合CheckConnectBreakConnect はインターフェイスを解放する必要があります。

要件

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

関連項目

CBasePin クラス