次の方法で共有


CRenderedInputPin.EndOfStream メソッド

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

メソッドは EndOfStream 、フィルターに対して新しい実行コマンドが発行されるまで、追加のデータが必要ないことをピンに通知します。 このメソッドは 、IPin::EndOfStream メソッドを 実装します。

構文

HRESULT EndOfStream();

パラメーター

このメソッドにはパラメーターはありません。

戻り値

成功した場合はS_OKを返し、それ以外の場合はエラー コードを返します。

解説

フィルターが実行されている場合、このメソッドはフィルター グラフ マネージャー にEC_COMPLETE イベントを送信します。 それ以外の場合、 はフラグを設定し、フィルターの次の実行時にEC_COMPLETE イベントが送信されるようにします。 フィルターをフラッシュすると、フラグがクリアされます。

ピンのストリーミング ロックを保持するには、このメソッドをオーバーライドする必要があります。

class CMyInputPin : public CRenderedInputPin
{
private:
    CCritSec * const m_pReceiveLock; // Streaming lock.
public:
    STDMETHODIMP EndOfStream(void);

    /* (Remainder of the class declaration not shown.) */
};

STDMETHODIMP CMyInputPin::EndOfStream(void)
{
    CAutoLock lock(m_pReceiveLock);  
    return CRenderedInputPin::EndOfStream();
} 

また、フィルターが Receive 呼び出しを非同期的に処理する場合、ピンは、保留中のすべてのサンプルがフィルターによって処理されるまで、EC_COMPLETE イベントの送信を待機する必要があります。

要件

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

関連項目

CRenderedInputPin クラス