共用方式為


CRenderedInputPin.EndOfStream 方法

[與此頁面 相關的功能 DirectShow是舊版功能。 它已被 MediaPlayerIMFMediaEngineMedia Foundation 中的音訊/視訊擷取取代。 這些功能已針對Windows 10和Windows 11進行優化。 Microsoft 強烈建議新程式碼盡可能使用 MediaPlayerIMFMediaEngine音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議盡可能重寫使用舊版 API 的現有程式碼,以使用新的 API。]

方法 EndOfStream 會通知針腳,直到新的執行命令發出至篩選之前,不會有其他資料。 此方法會實作 IPin::EndOfStream 方法。

語法

HRESULT EndOfStream();

參數

這個方法沒有任何參數。

傳回值

如果成功,則傳回S_OK,否則傳回錯誤碼。

備註

如果篩選正在執行,這個方法會將 EC_COMPLETE 事件傳送至 Filter Graph 管理員。 否則,會設定 旗標,以便在下次執行篩選時傳送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();
} 

此外,如果篩選進程以非同步方式 接收 呼叫,釘選應該等候傳送EC_COMPLETE事件,直到篩選處理所有擱置的樣本為止。

規格需求

需求
標頭
Amextra.h (包含 Streams.h)
程式庫
Strmbase.lib (零售組建) ;
Strmbasd.lib (偵錯組建)

另請參閱

CRenderedInputPin 類別