共用方式為


ISampleGrabber::SetCallback 方法

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

注意

[已被取代。 此 API 可能會從未來的 Windows 版本中移除。]

 

SetCallback方法會指定要在傳入範例上呼叫的回呼方法。

語法

HRESULT SetCallback(
   ISampleGrabberCB *pCallback,
   long             WhichMethodToCallback
);

參數

pCallback

包含回呼方法的 ISampleGrabberCB 介面指標,或 Null 以取消回呼。

WhichMethodToCallback

指定回呼方法的索引。 必須是下列其中一個值。

描述
0 範例抓取器篩選準則會呼叫 ISampleGrabberCB::SampleCB 方法。 這個方法會接收 IMediaSample 指標。
1 範例抓取器篩選準則會呼叫 ISampleGrabberCB::BufferCB 方法。 這個方法會接收媒體範例中包含的緩衝區指標。

 

傳回值

如果此方法成功,則會傳回 S_OK。 否則,它會傳回 HRESULT 錯誤碼。

備註

資料處理執行緒會封鎖,直到回呼方法傳回為止。 如果回呼未快速傳回,它可能會干擾播放。

篩選不會針對預先註冊範例叫用回呼函式,或是AM_SAMPLE2_PROPERTIES結構之 dwStreamId成員不是AM_STREAM_MEDIA以外的範例。

注意

標頭檔 Qedit.h 與 7 版之後的 Direct3D 標頭不相容。

 

注意

若要取得 Qedit.h,請下載Windows Vista Microsoft Windows SDK Update 和 .NET Framework 3.0。 Qedit.h 不適用於 Windows 7 和 .NET Framework 3.5 Service Pack 1 的 Microsoft Windows SDK。

 

規格需求

需求
標頭
Qedit.h
程式庫
Strmiids.lib

另請參閱

使用範例擷取器

ISampleGrabber 介面