共用方式為


CSourceStream.DoBufferProcessingLoop 方法

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

方法 DoBufferProcessingLoop 會產生媒體資料,並將它傳遞給下游輸入針腳。

語法

virtual HRESULT DoBufferProcessingLoop();

參數

這個方法沒有任何參數。

傳回值

傳回 HRESULT 值。 可能的值包括下表所示的值。

傳回碼 Description
S_FALSE
執行緒收到停止要求。
S_OK
資料流程結束,或下游篩選不接受範例。

備註

這個方法會實作處理資料並傳遞下游的主要迴圈。 每次透過 迴圈時,方法都會從配置器擷取空的媒體範例。 它會將範例傳遞至 CSourceStream::FillBuffer 方法。 衍生類別必須實作的 FillBuffer 方法會產生媒體資料,並將它放在範例緩衝區中。

當發生下列任一項時,迴圈就會結束:

方法會 DoBufferProcessingLoop 處理資料流程結束通知。 如果發生錯誤,它會將 EC_ERRORABORT 事件傳送至篩選圖形管理員。

規格需求

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

另請參閱

CSourceStream 類別