Share via


CSourceStream.FillBuffer 方法

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

方法 FillBuffer 會以資料填入媒體範例。

語法

virtual HRESULT FillBuffer(
   IMediaSample *pSample
) = 0;

參數

pSample

範例 IMediaSample 介面的指標。

傳回值

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

傳回碼 Description
S_FALSE
資料流程結尾
S_OK
Success

備註

衍生類別必須實作這個方法。

提供給這個方法的媒體範例沒有時間戳記。 衍生類別應該呼叫 IMediaSample::SetTime 方法來設定時間戳記。 如果適用于媒體類型,衍生類別也應該藉由呼叫 IMediaSample::SetMediaTime 方法來設定媒體時間。 如需詳細資訊,請參閱 DirectShow 中的時間和時鐘

傳回資料流程結尾處S_FALSE。 這會導致 CSourceStream 類別傳送串流結束通知,並停止緩衝區處理迴圈。 如需詳細資訊,請參閱 CSourceStream::D oBufferProcessingLoop

規格需求

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

另請參閱

CSourceStream 類別