共用方式為


ksGenerateEvents 函式 (ks.h)

KsGenerateEvents 函式會產生存在於 Object 事件清單中的指定類型事件。

語法

void KsGenerateEvents(
  [in]           PVOID                      Object,
  [in, optional] const GUID                 *EventSet,
  [in]           ULONG                      EventId,
  [in]           ULONG                      DataSize,
  [in, optional] PVOID                      Data,
  [in, optional] PFNKSGENERATEEVENTCALLBACK CallBack,
  [in, optional] PVOID                      CallBackContext
);

參數

[in] Object

要在其中產生事件的物件。 這可以是AVStream篩選條件或釘選物件。

[in, optional] EventSet

要比對的事件集 GUID,以判斷要產生的事件。 如果此參數為 NULL,則不會考慮設定 GUID 來判斷比對事件。

[in] EventId

要比對的事件標識碼,以判斷要產生的事件。

[in] DataSize

要用來產生數據事件之數據的大小,以位元組為單位。

[in, optional] Data

要包含在事件通知中的數據緩衝區指標。 如果驅動程式不需要透過通知傳達其他資訊,請將此選擇性參數設定為 NULL

[in, optional] CallBack

呼叫端指定之函式的指標,用來判斷是否應該產生指定的事件。 如果這是 NULL,則不會執行回呼驗證,以判斷是否應該 (只產生事件 *EventSet *,而且 會使用 EventId) 。

[in, optional] CallBackContext

傳遞至回呼函式 CallBack 之呼叫端指定內容的指標。

傳回值

備註

呼叫此函式時,迷你驅動程式必須將 DataCallBackContext 放在鎖定、不可分頁的數據區段中。 此外,請注意, CallBack 是在DISPATCH_LEVEL進行。 回呼函式必須位於鎖定的區段中,而且必須準備好在 IRQL = DISPATCH_LEVEL執行。 請注意, DX8 中還有其他問題: EventSet 必須位於鎖定的數據區段中。

Minidrivers 通常不會直接呼叫此函式,而是改用執行適當轉換的其中一個版本: KsFilterGenerateEventsKsPinGenerateEvents

如果事件出現在 *Object 的 *事件清單中,且 *EventId *符合事件的標識符, EventSet 會比對事件的設定 GUID 或為 NULL,而 *CallBack *為 NULL 或授權相符專案,則會產生事件。

CallBack 是呼叫端指定的回呼,用於其他比對判斷。 其原型如下:

BOOLEAN CallBack (IN PVOID Context, IN PKSEVENT_ENTRY EventEntry);

AVStream 會在此回呼的 Context 參數中傳遞 KsGenerateEvents 例程的參數 CallBackContext 的內容。 EventEntry 是指定產生之事件的 KSEVENT_ENTRY 結構的指標。 如果應該產生此事件,回呼函式應該會傳回 TRUE

如需詳細資訊,請參閱AVStream和 KS 事件中的事件處理

規格需求

需求
最低支援的用戶端 適用於 Microsoft Windows XP 和更新版本的作業系統和 DirectX 8.0 和更新版本的 DirectX。
目標平台 Universal
標頭 ks.h (包含 Ks.h)
程式庫 Ks.lib
IRQL <=DISPATCH_LEVEL

另請參閱

KSEVENT_ENTRY

KsAddEvent

KsFilterGenerateEvents

KsPinGenerateEvents