共用方式為


IPinConnection::NotifyEndOfStream 方法 (strmif.h)

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

方法 NotifyEndOfStream 會在下一個串流結束狀況發生時,向針腳要求通知。

語法

HRESULT NotifyEndOfStream(
  [in] HANDLE hNotifyEvent
);

參數

[in] hNotifyEvent

接腳會發出訊號的事件物件句柄。

傳回值

傳回 HRESULT 值。 可能的值如下。

傳回碼 Description
S_FALSE
事件句柄為 NULL,但沒有要重設的現有事件句柄。
S_OK
已設定事件句柄。 (如果事件句柄為 NULL,事件通知已取消。)

備註

這個方法可讓呼叫端透過以這個釘選結尾的篩選圖形部分推送數據。

例如,假設呼叫端正在將數據從一個篩選上名為 「A」 的輸出針腳推送至另一個篩選上稱為 「B」 的輸入針腳,可能連接中繼篩選條件。 會發生下列事件序列。

  1. 呼叫端會在釘選 A 封鎖數據流。
  2. 它會在 Pin B 上呼叫 NotifyEndOfStream
  3. 它會在連接到 PIN A 的輸入釘選上呼叫 IPin::EndOfStream
  4. 當其餘數據透過任何中繼篩選進行下游移動時,這些篩選會傳播串流結束通知。
  5. 當 pin B 收到串流結束通知時,它會向 hNotifyEvent 參數中指定的事件發出訊號。 此時,呼叫端可以安全地重新設定釘選 A 與釘選 B 之間的圖表。
因為這個方法的目的是讓呼叫端動態重建圖形,然後重新啟動連線,所以串流結束通知並不代表數據流的實際結束。 因此,針腳 B 不會傳播串流結束條件或訊號EC_COMPLETE。 這是篩選圖表中數據流的一般規則的例外狀況。

呼叫端必須負責使用 NULL 事件句柄再次呼叫這個方法來取消通知。

篩選圖表會在 IGraphConfig::Reconnect 方法內呼叫這個方法。 如果應用程式或篩選會使用 IGraphConfig::Reconfigure 方法) 對圖形 (執行任何特製化的動態重新設定,它可能會先呼叫此方法,以便透過要重新設定的圖形部分推送數據。

規格需求

需求
最低支援的用戶端 Windows XP [僅限傳統型應用程式]
最低支援的伺服器 Windows Server 2003 [僅限桌面應用程式]
目標平台 Windows
標頭 strmif.h (包含 Dshow.h)
程式庫 Strmiids.lib

另請參閱

動態重新連線

錯誤和成功碼

IPinConnection 介面