共用方式為


lineInitializeExA 函式 (tapi.h)

lineInitializeEx 函式會初始化應用程式的TAPI用法,以供後續使用行抽象概念。 它會註冊應用程式的指定通知機制,並傳回應用程式可用的行裝置數目。 線路裝置是任何裝置,可在 Telephony API 中提供行前置函式的實作。

語法

LONG lineInitializeExA(
  LPHLINEAPP               lphLineApp,
  HINSTANCE                hInstance,
  LINECALLBACK             lpfnCallback,
  LPCSTR                   lpszFriendlyAppName,
  LPDWORD                  lpdwNumDevs,
  LPDWORD                  lpdwAPIVersion,
  LPLINEINITIALIZEEXPARAMS lpLineInitializeExParams
);

參數

lphLineApp

指向已填入 TAPI 之應用程式使用句柄的位置指標。

hInstance

用戶端應用程式或 DLL 的實例句柄。 應用程式或 DLL 可以傳遞此參數的 NULL ,在此情況下,TAPI 會使用進程根可執行檔的模組句柄 (,以識別呼叫交接目標和媒體模式優先順序) 。

lpfnCallback

叫用以判斷線路裝置、位址或呼叫上狀態和事件的回呼函式位址,當應用程式使用事件通知的「隱藏視窗」方法時, (如需詳細資訊,請參閱 lineCallbackFunc) 。 當應用程式選擇使用「事件句柄」或「完成埠」事件通知機制時,會忽略此參數,而且應該設定為 NULL

lpszFriendlyAppName

僅包含可顯示字元之 Null 終止文字字串的指標。 如果此參數不是 NULL,它會包含應用程式提供的名稱。 此名稱是在 LINECALLINFO 結構中提供,以使用者易記的方式指出應用程式源自或原本接受或接聽通話。 這項信息對於呼叫記錄用途很有用。 如果 lpszFriendlyAppNameNULL,則會改用應用程式的模組檔名 (,如 GetModuleFileName 函式所傳回) 。

lpdwNumDevs

DWORD 大小的位置指標。 成功完成此要求時,此位置會填入應用程式可用的行裝置數目。

lpdwAPIVersion

DWORD 大小的位置指標。 應用程式在呼叫此函式之前,必須先初始化此 DWORD,才能將它設計為支援 (的最高 API 版本,其會傳入 lineNegotiateAPIVersion) 的 dwAPIHighVersion 參數。 不得使用人工高值;值必須正確設定。 TAPI 會將任何較新的訊息或結構轉譯為應用程式版本所支援的值或格式。 成功完成此要求時,此位置會填入TAPI支援的最高API版本,藉此讓應用程式偵測並適應已安裝於具有不同TAPI版本的系統上。

lpLineInitializeExParams

LINEINITIALIZEEXPARAMS 類型的結構指標,其中包含用來建立應用程式與 TAPI (關聯的其他參數,特別是應用程式的選取事件通知機制和相關聯的參數) 。

傳回值

如果要求成功或發生錯誤,則傳回零。 可能的傳回值為:

LINEERR_INVALAPPNAME、LINEERR_OPERATIONFAILED、LINEERR_INIFILECORRUPT、LINEERR_INVALPOINTER、LINEERR_REINIT、LINEERR_NOMEM、LINEERR_INVALPARAM。

備註

應用程式必須選取三種機制之一,TAPI 會通知電話語音事件的應用程式:隱藏視窗、事件句柄或完成埠。

LINEINITIALIZEEXPARAMS 結構中的 dwOptions 成員中指定LINEINITIALIZEEXOPTION_USEHIDDENWINDOW,即可選取 [隱藏視窗] 機制。 在此機制中 (這是TAPI第1版唯一可用的機制。x 應用程式) ,TAPI 會在 LINEInitializeExlineInitialize (針對 TAPI 1.3 版和 1.4 版應用程式建立視窗) 函式,並子類別化視窗,讓貼到該應用程式的所有訊息都由 TAPI 本身的 WNDPROC 處理。 當 TAPI 有訊息要傳遞至應用程式時,TAPI 會將訊息張貼至隱藏的視窗。 收到訊息 (只有在應用程式呼叫 Windows GetMessage 函式) 時,Windows 才會將進程內容切換至應用程式的內容,並在 TAPI 中叫用 WNDPROC。 TAPI 接著藉由呼叫 lineCallbackProc將訊息傳遞至應用程式,這是應用程式在其 呼叫lineInitializeEx (或 lineInitialize) 中提供做為參數的指標。 此機制需要應用程式具有訊息佇列 (,這不適用於服務進程) ,以及定期服務該佇列,以避免延遲處理電話語音事件。 在 lineShutdown 函式期間,TAPI會終結隱藏的視窗。

選取事件句柄機制的方式是在LINEINITIALIZEEXPARAMS結構中的 dwOptions成員中指定LINEINITIALIZEEXOPTION_USEEVENT。 在此機制中,TAPI 會代表應用程式建立事件物件,並傳回LINEINITIALIZEEXPARAMShEvent成員中物件的句柄。 例如,應用程式不得以任何方式操作此事件 (,例如,不得呼叫 SetEventResetEventCloseHandle 等等) 或未定義的行為結果;應用程式只能使用 WaitForSingleObjectMsgWaitForMultipleObjects 等函式來等候此事件。 TAPI 會在應用程式擱置電話語音事件通知時發出此事件訊號;應用程式必須呼叫 lineGetMessage 來擷取訊息的內容。 當沒有擱置的事件時,TAPI 會重設事件。 事件句柄已關閉,而TAPI在 lineShutdown 函式期間終結的事件物件。 應用程式不需要等候所建立的事件句柄;應用程式可以選擇改為呼叫 lineGetMessage ,並讓它封鎖等候訊息排入佇列。

LINEINITIALIZEEXPARAMS 結構中的 dwOptions 成員中指定 LINEINITIALIZEEXOPTION_USECOMPLETION PORT,即可選取 [完成埠] 機制。 在此機制中,每當需要傳送電話語音事件給應用程式時,TAPI 會使用 PostQueuedCompletionStatus 將它傳送至 LINEINITIALIZEEXPARAMShCompletionPort 成員中指定的應用程式所指定的完成埠,並標記了 LINEINITIALIZEEXPARAMSdwCompletionKey 成員中指定的完成密鑰。 應用程式先前必須使用 CreateIoCompletionPort 建立完成埠。 應用程式會使用 GetQueuedCompletionStatus 擷取事件。 從 GetQueuedCompletionStatus 傳回時,應用程式已將指定的 dwCompletionKey 寫入 lpCompletionKey 參數所指向的 DWORD,以及傳回至 lpOverlapped 所指向位置的 LINEMESSAGE 結構的指標。 應用程式處理事件之後,應用程式必須負責呼叫 LocalFree 以釋放用來包含 LINEMESSAGE 結構的記憶體。 由於應用程式已建立完成埠 (因此允許它供其他用途共用) ,因此應用程式必須關閉它;在呼叫 lineShutdown之後,應用程式不得關閉完成埠。

當多線程應用程式使用事件句柄機制,且多個線程正在等候句柄,或完成埠通知機制和一個以上的線程正在等候埠時,可能會讓電話語音事件依序處理。 這不是由於從 TAPI 傳遞事件的順序所造成,但會因為線程的時間分割或個別處理器上的線程執行所造成。

如果傳回LINEERR_REINIT,而且已要求 TAPI 重新初始化,例如新增或移除電話語音服務提供者的結果,則會拒絕 lineInitializeEx 要求,直到最後一個應用程式使用 lineShutdown (使用 lineShutdown) 關閉其使用 API (,此時新的組態會生效,而且再次允許應用程式呼叫 lineInitializeEx

如果傳回LINEERR_INVALPARAM錯誤值,則指定的 hInstance 參數無效。

應用程式可以使用範圍從零到 dwNumDevs 減一的行裝置標識碼來參照個別線路裝置。 應用程式不應該假設這些線路裝置能夠使用任何特定的 TAPI 函式,而不需要先透過 lineGetDevCapslineGetAddressCaps 查詢其裝置功能。

注意

tapi.h 標頭會根據 UNICODE 預處理器常數的定義,將 lineInitializeEx 定義為別名,自動選取此函式的 ANSI 或 Unicode 版本。 混合使用編碼中性別名與非編碼中性的程序代碼,可能會導致編譯或運行時間錯誤不符。 如需詳細資訊,請參閱 函式原型的慣例

規格需求

需求
目標平台 Windows
標頭 tapi.h
程式庫 Tapi32.lib
Dll Tapi32.dll

另請參閱

基本電話語音服務參考

LINECALLINFO

LINEINITIALIZEEXPARAMS

LINEMESSAGE

TAPI 2.2 參考概觀

lineCallbackFunc

lineGetAddressCaps

lineGetDevCaps

lineGetMessage

lineInitialize

lineNegotiateAPIVersion

lineShutdown