欧美在线观看视频网站,亚洲熟妇色自偷自拍另类,啪啪伊人网,中文字幕第13亚洲另类,中文成人久久久久影院免费观看 ,精品人妻人人做人人爽,亚洲a视频

面向對象的電話系統(tǒng)的制作方法

文檔序號:7565156閱讀:346來源:國知局
專利名稱:面向對象的電話系統(tǒng)的制作方法
技術領域
本發(fā)明涉及電話系統(tǒng),尤其涉及用于將應用部件與電話部件接口的系統(tǒng)。
版權通告本專利申請的某些部分受到版權保護。當出現(xiàn)在專利與商標局專利文件或記錄中時,版權所有人不反對任何人對專利文檔或專利公開的傳真復制,除此以外,保留所有一切版權。
與本發(fā)明相關的背景技術當前的電話系統(tǒng)是相當原始的,相對早期電話的基本原理而言其變化甚少。早期的系統(tǒng)通常用交換臺話務員來連通呼叫方與被呼叫方。然而,借助于計算機技術,只在特殊情況下才需要話務員提供幫助。
其它技術進步已將電話系統(tǒng)變成了信息傳遞網絡或數(shù)據高速公路。傳真便是利用電話系統(tǒng)作為信息傳遞網絡的許多實例之一??峙码娫捪到y(tǒng)的最頻繁的使用來自呼叫方與被呼叫方之間的簡單語音電話通話。然而這種交互通話只利用了電話系統(tǒng)優(yōu)越功能性的很少一部分。
再者,典型的用戶只擁有為只進行實時語音傳輸而設計的最基本的設備。然而除了語音以外,電話系統(tǒng)也能傳送其它信息,并且還能提供可以更充分地利用電話系統(tǒng)的可用帶寬與網絡能力的各種各樣的信息傳遞。
典型的PBX(專用小交換機)便是其功能超過可利用的發(fā)送手段的技術的典型實例。普通用戶只利用了大多數(shù)現(xiàn)代電話系統(tǒng)的全部功能的一小部分。標準的電話手機是人機接口的瓶頸。充其量它是以按鈕行為特征的,由于在位置與功能之間沒有約定的映射,這些按鈕行必須加以標記。不幸的是,這些標記對于為了完成給定的操作必須按壓這些按鈕的序列并未給出線索,多功能按鈕(轉接/三路會談)的存在更增加了情況的迷惑性。
雖然電話公司已利用計算機技術來得益與增進電話系統(tǒng)的潛力,單個用戶尚不能利用其潛力到相同的程度。單個用戶對電話系統(tǒng)的潛力的最直接的利用便是遠程訪問與使用電話應答機。
實際上電話只是一個原始的終端。與另一終端的連接是通過拿起接收機來發(fā)信號通知希望網絡服務并然后輸入一序列標識終端連接的號碼而建立的。通過掛機來結束連接。在建立簡單連接中這些操作提供方便,但電話系統(tǒng)的其它方面要求用戶留意各種細節(jié)。
例如,電話號碼通常是憑人腦記憶或保存在手寫記事本中的,這一記事本必須永遠隨身攜帶。還經常使用地址本、索引卡片以及印在便宜的紙上并裝訂成笨重本子的大量表格中,但存儲還只是問題的一部分而已。在能使用它們之前,必須從記錄中訪問檢索號碼,查找卡片文件或目錄。并且由于號碼隨時間改變,必須周期性地更新。將號碼電子地存儲在個人或聯(lián)機數(shù)據庫中能在一定程度上減輕檢索與維護問題,但在定位了號碼之后仍需要人工將其傳遞給電話機。
在比建立簡單的一對一連接更復雜的操作的情況中,電話機也提供不理想的用戶接口。例如在多方交談的情況中,普通用戶需要檢驗參考手冊來確定使用哪些鍵的序列用“*7”還是“*8”?一種替代方案是提供一種裝有一行或兩個附加按鈕的特殊電話機,即計算機鍵盤上的功能鍵的電話等價物,但電話按鈕上的標簽通常稍長“TRNSF”用于通話轉接而不是“F6”。
因此,存在著挖掘當前的電話系統(tǒng)的潛力的要求,尤其是系統(tǒng)的信息傳輸與網絡功能。
本發(fā)明的目的因此,本發(fā)明的一個目的是提供對電話部件的訪問進行的改進。
本發(fā)明的另一目的是將計算機技術應用在電話系統(tǒng)上。
本發(fā)明的又另一目的是提供電話系統(tǒng)部件與應用部件之間的一種接口。
本發(fā)明的又一目的是使電話世界與通用聲音世界之間的邊界平滑無隙。本發(fā)明的技術方案上述目的是通過提供與各種電話系統(tǒng)部件靈活接口的部件而實現(xiàn)的。這些接口部件通常并不取代電話系統(tǒng)部件,而是提供與特定電話系統(tǒng)部件的透明的接口方法。將接口部件設計成與電話系統(tǒng)的特定部件接口,而與電話系統(tǒng)的電話系統(tǒng)部件是硬件部件或者只是協(xié)議無關。例如,一種接口部件可能提供接收一次通話,并通知一次通話正在等待的一個應用部件的簡單接口。
根據本發(fā)明的電話裝置包括一個處理器;連接在該處理器上并受其控制的一個存儲器;位于該存儲器中并控制該處理器的操作的一個面向對象的操作系統(tǒng);連接在該面向對象的操作系統(tǒng)控制下的處理器上的一個顯示器;連接在該處理器上的一個電話部件;存儲在該存儲器中并顯示在該顯示器上并用于表示在該面向對象的操作系統(tǒng)的控制下的電話部件的一個電話對象;以及用于由面向對象的操作系統(tǒng)利用該電話對象控制該電話部件的裝置。
一種根據本發(fā)明用于在一個計算機系統(tǒng)上啟動電話部件的方法,該計算機系統(tǒng)包括一個處理器,該處理器具有與之連接的一個存儲器,一個顯示器,以及一個電話部件,該方法包括用位于該存儲器中的一個面向對象的操作系統(tǒng)控制該處理器的操作;建立一個電話對象,該電話對象存儲在該存儲器中并顯示在該顯示器上,并用于代表在該面向對象的操作系統(tǒng)的控制下的電話部件;以及由該面向對象的操作系統(tǒng)利用該電話對象控制該電話部件。本發(fā)明的有益效果接口部件提供一種靈活與方便的方法,其中,開發(fā)涉及電話的應用程序員能利用電話系統(tǒng)特征而無須考慮如何對一種特定的電話系統(tǒng)訪問該特征的細節(jié)。接口部件對于電話設備的硬件設計人員也是有用的?;谟嬎銠C的電話具有消除電話機的限制的潛力,同時提供基于電話的通信與在桌面計算機上運行的應用程序的緊密合作。系統(tǒng)基礎的主要部分要求能夠實現(xiàn)遠程和實時協(xié)作。
本發(fā)明允許應用使用目標機上可以利用的任何內部電話硬件并提供經由調制解調器或其它外部硬件設備的通用撥號功能。
在一個最佳實施例中,一個面向對象的操作系統(tǒng)是基于計算機的電話應用的主要部件。
從下面用附圖考察的詳細描述中,本發(fā)明的其它目的與優(yōu)點將是顯而易見的。
附圖的簡要說明

圖1示出根據一個最佳實施例的代表性系統(tǒng);圖2示出根據一個最佳實施例的手機與墻壁插座的典型連接;圖3示出根據一個最佳實施例的連接在多條線路與多個插座上的手機;圖4示出根據一個最佳實施例的利用調制解調器的基于計算機的電話系統(tǒng);圖5示出根據一個最佳實施例的在手機與插座之間插入一臺計算機的基于計算機的電話系統(tǒng);圖6示出根據一個最佳實施例的硬件;圖7示出根據一個最佳實施例的一個TTelephoneLineHandle對象的示例;圖8示出根據一個最佳實施例的TTelephoneLineHandle的功能特征;圖9示出根據一個最佳實施例的TTelephoneCallHandle(電話通話管理)的示例;圖10示出根據一個最佳實施例的TTelephoneCallHandle的功能特征;圖11示出根據一個最佳實施例建立一種關心事物(interest)的應用;圖12示出根據一個最佳實施例的發(fā)送信息的電話系統(tǒng);圖13示出根據一個最佳實施例的聲音文件的播放;圖14示出根據一個最佳實施例的與TTelephoneLineHandle(電話線路管理)交互作用來執(zhí)行各種電話業(yè)務的應用;圖15示出根據一個最佳實施例的配置數(shù)據;
圖16示出根據一個最佳實施例的TTelephoneLineHandle的功能;圖17示出根據一個最佳實施例的TTelephoneLineFeatureControl(電話線路特征控制)的功能;圖18示出根據一個最佳實施例的TTelephoneHandsetHandle(電話手機管理)的功能;圖19示出根據一個最佳實施例的TInterest(關心事物)子類;圖20示出根據一個最佳實施例的TNotification(通知)子類;圖21示出根據一個最佳實施例的TTelephoneLine(電話線路)的功能特征;圖22示出根據一個最佳實施例的電話設備的設計人員的開發(fā)周期;圖23示出根據一個最佳實施例的TTelephoneLine的功能特征;圖24示出根據一個最佳實施例的TTelephoneLineHandset(電話線路手機)的功能特征;圖25示出根據一個最佳實施例的TTelephoneLineFeature的功能特征。
本發(fā)明的最佳實施例這里公開了本發(fā)明的詳細實施例,但應理解,所公開的實施例只是本發(fā)明的示范,它們可以以各種形式實現(xiàn)。因此這里公開的細節(jié)不應理解為一種限制,而只是作為權利要求書的基礎,及作為向熟悉本技術的人員教導如何作出與/或使用本發(fā)明的基礎。
這里所使用的“電話系統(tǒng)”包括電話通信的所有方面。
電話標準網絡歷史上,已在逐個國家的基礎上制訂了網絡標準。在許多情況下,它們是有相當大的變化的,從而導致局域化的惡夢,尤其在歐洲。由于諸如ISDN(綜合業(yè)務數(shù)字網絡)等數(shù)字標準的出現(xiàn)以及1992年歐洲共同體的成立,這一情況在不久的將來有望改善。在美國,快速地走向ISDN的動力不夠大,應此,在未來一段時間內,很可能模擬網絡和數(shù)字網絡互相競爭。
在模擬領域內,電話功能的計算機控制通常是經由調制解調器完成的。(注意調制解調器不一定是一種外部硬件。RISC(精簡指令集計算機)及基于芯片的數(shù)字信號處理技術使得全功能內部軟件調制解調器的實現(xiàn)成為可能。)一種計算機到調制解調器通信的廣為流傳的事實上的標準為原先由Hayes公司定義的所謂“AT”命令集。
在數(shù)字領域內,已由CCITT(國際電報與電話咨詢委員會)的一個多國工作組開發(fā)出ISDN標準。在CCITT建議Q.931中定義了建立與拆除連接的ISDN網絡層協(xié)議。(ISDN還包括物理與數(shù)據鏈路層以及高層管理實體的規(guī)程)。開關在電話網絡與電話手機之間存在著某種類型的一個開關,它將一個特定的分機連接在網絡上。在商用市場上,這一開關很可能是一臺PBX(用戶交換機)。除提供通過網絡的簡單連接之外,開關通常提供各式各樣的所謂補充服務,諸如暫時中斷并占線等候,轉接,與多方交談。使用這些服務的協(xié)議不但變化多端,而且在歷史上已為各開關制造商所專有。雖然Q.931中的ISDN網絡層規(guī)程并不建議補充特征,但在特征選擇及用于實現(xiàn)一種給定的特征的報文的實際序列中仍留有相當大的活動余地。音頻數(shù)據格式取決于網絡的類型及計算機與電話網絡之間的接口,有可能從電話線上錄出音頻數(shù)據以供計算機存儲與播放。在模擬數(shù)據的情況中,必須設置一條模/數(shù)轉換服務的通路,然后用對一個給定的設計中心有效的任何內部標準表示該數(shù)據。在數(shù)字數(shù)據的情況中,出現(xiàn)了外部標準問題。CCITT已經定義了與每秒64,000位傳輸率的ISDNB信道兼容的若干數(shù)據格式標準。存在著利用全部可用帶寬的未壓縮語音信號的兩種標準。它們都基于對數(shù)壓擴的PCM(脈沖碼調制)。在第一種情況中,它是北美的主要格式,對數(shù)壓擴是由μ律函數(shù)提供的,而第二種格式主要為歐洲采用,所使用的是A律函數(shù)。每一格式假定8KHZ的取樣率并為每一取樣分配8位,從而提供3.5KHZ的有效信號帶寬。
一方面CCITT采用了若干種音頻壓縮標準,而另一方面數(shù)字蜂窩工業(yè)則采用若干標準。面向對象的編程在一個最佳實施例中,本發(fā)明是用面向對象的編程技術在C++編程語言中實現(xiàn)的。正如熟悉本技術的人員所理解的,面向對象的編程(OOP)的對象為包括數(shù)據結構及在這些數(shù)據上運算的軟件實體。同時,這些元素使對象能根據由其數(shù)據元素所特征化及由其數(shù)據操作函數(shù)所表示的狀態(tài)來塑造任何現(xiàn)實世界的實體。以這一方式,對象能夠塑造象人與計算機等具體事物的模型,也能塑造象數(shù)或幾何概念等抽樣概念的模型。對象技術的好處來自三種基本原理封裝,多形性,及繼承性。
對象隱蔽或封裝它們的數(shù)據的內部結構以及其功能據其用于工作的算法。不暴露這些實現(xiàn)的細節(jié),對象提供簡潔地表示它們的抽象的接口而無額外的信息。多形又將封裝向前推進了一步。這一觀念是多種狀態(tài),一個接口。一個軟件部件能請求另一部件而不必確切知道該部件是什么。接收請求的部件中斷它并根據其變量與數(shù)據計算出如何執(zhí)行該請求。第三種原理為繼承,它容許開發(fā)人員重復使用先前存在的設計與代碼。這一能力使開發(fā)人員能夠避免從草案開始建立軟件。而通過繼承,開發(fā)人員導出繼承行為的子類,然后開發(fā)人員將其定制以符合他們的特殊要求。
先有技術方法為在過程環(huán)境中分層對象與類庫。上市的許多應用框架(framework)采取這一設計方法。在這一設計中,在一個整體操作系統(tǒng)的上面有一個或多個對象層。雖然這種方法在對象層中利用了全部封裝,多形性,和繼承性原理并且是對過程編程技術的實質改進,但這一方法存在相當限制。這些困難起源于這一事實,即開發(fā)人員容易重新使用他們自己的對象,但難于使用來自其它系統(tǒng)的對象,而開發(fā)人員仍需要用過程操作系統(tǒng)(OS)調用來進入較低的非對象層。
面向對象的編程的另一方面為對應用開發(fā)的一種框架方法。最合理的框架定義之一來自Illinois大學的Ralph E.Johnson及Purdue的Vincent F.Russo。在1991年的論文,“重復使用面向對象的設計”,Illinois大學技術報告UTUCDCS91-1696中,他們提出下述定義“一個抽象類是合作完成一組任務的組對象的設計。從而,一個框架是合作執(zhí)行定義的計算任務組的一組對象類?!睆木幊逃^點上,框架主要是提供預制的工作應用的結構的互相聯(lián)系的對象類的群。例如,用戶接口框架可能提供繪圖窗口,卷動條,菜單等的支持與“系統(tǒng)預置”特性。由于框架是基于對象技術的,這一表現(xiàn)能被繼承與替換,以便開發(fā)人員能擴展該框架并在特定的專門技術領域內建立定制的解決方法。由于程序員無須改變原來的代碼,而只是擴展軟件,所以這與傳統(tǒng)的編程相比較是一個主要的優(yōu)點。此外,開發(fā)人員并不盲目地通過代碼層工作,因為框架提供體系結構指導與模型塑造,而同時又允許它們自由地提供對問題域獨有的特定作用。
從商業(yè)觀點上看,可將框架看成是封裝或體現(xiàn)一個特定的知識領域內的專門知識的一種方法。合作開發(fā)組織,獨立軟件經銷商(ISV),及系統(tǒng)綜合人員已在諸如制造,會計,或貨幣交易等特定領域中得到專門知識,如上述實例中。這種專門知識是用它們的代碼體現(xiàn)的。框架通過在組織的代碼中體現(xiàn)它而使組織能捕捉與包裝該專門知識的共同特征。首先,這允許開發(fā)人員建立或擴展利用該專門知識的應用,從而問題一旦得到解決,便能經常性地執(zhí)行與使用這些商業(yè)規(guī)則與設計。同時,框架及框架背后所體現(xiàn)的專門知識對于已在諸如制造,會計,生物技術等垂直市場中的專門知識的組織具有一種戰(zhàn)略性資產的意義,并且提供了一種包裝,轉賣,及開發(fā)它們的專門知識的分配機制并促進技術的提高與普及。
歷史上,框架是最近才作為個人計算平臺上的主流概念出現(xiàn)的。這一出現(xiàn)已受到諸如C++等面向對象的語言的可利用性的協(xié)助。傳統(tǒng)上,C++絕大部分出現(xiàn)在UNIX系統(tǒng)及研究工作者的工作站上,而不是在商業(yè)安裝的個人計算機上。這便是諸如C++和諸如Smalltalk等其它面向對象的語言使得一些大學及科研項目產生今天的商業(yè)框架及類庫的前身。其中的一些實例為來自Stanford大學的InterViews,來自Carnegie-Mellon大學的Andrew工具箱及Zurich大學的ET++框架。
取決于所關心的是系統(tǒng)的哪一級及試圖解決的是哪一類問題而存在許多種框架。框架類型的范圍從協(xié)助開發(fā)用戶接口的應用框架到提供諸如通信,印刷,文件系統(tǒng)支持,圖形等基本系統(tǒng)軟件服務的低級框架。應用框架的商業(yè)實例可包括MacApp(蘋果),Bedrock(Symantec),OWL(Borland),NeXTStep App Kit(NeXT)及Smalltalk-80MVC(ParcPlace)幾種。
對于習慣于其它種類的系統(tǒng)的開發(fā)人員而言,用框架編程需要一種新的思維方式。事實上,它完全不像傳統(tǒng)意義上的“編程”。在諸如DOS或UNIX等老式操作系統(tǒng)中,開發(fā)人員本人的程序提供所有的結構。操作系統(tǒng)通過系統(tǒng)調用提供服務,開發(fā)人員的程序在它需要服務時作出調用而在提供完服務時返回控制。程序結構基于體現(xiàn)在開發(fā)人員編寫的代碼中的控制流程。
在使用框架時,這是顛倒的。開發(fā)人員不再負責控制流程。開發(fā)人員必須摒棄用執(zhí)行流程表示的理解編程任務的趨勢。而代之以思維必須以對象的任務來表示,它必須依靠框架來確定何時應執(zhí)行這些任務。開發(fā)人員編寫的例程是由不是開發(fā)人員編寫的并且開發(fā)人員從未見過的代碼激活的。對于只習慣于過程型編程的開發(fā)人員,控制流程中的這一轉變可能成為明顯的心理障礙。然而,一旦理解了這一點,框架編程比其它種類的編程需要的工作量少得多。
本發(fā)明最好在諸如IBM_PS/2_,或Apple_Macintosh_計算機等個人計算機上常駐的操作系統(tǒng)的環(huán)境中實現(xiàn)。
圖1中描繪了代表性的硬件環(huán)境,它例示了根據本發(fā)明的具有一個諸如傳統(tǒng)的微處理器的中央處理單元100及若干經由一條系統(tǒng)總線132連至其它單元的一臺計算機的典型硬件配置。圖1中所示的計算機包括一個只讀存儲器(ROM)104,一個隨機存取存儲器(RAM)106,一個用于將諸如軟盤單元108及用110表示的其它I/O外圍設備連接在系統(tǒng)總線132上的I/O適配器112,一個用于將鍵盤130,鼠標器126,揚聲器122,麥克風124,和/或諸如觸屏設備(未示出)等其它用戶接口設備連接在總線上的用戶接口適配器128,以及一個用于將工作站連接在用114表示的一個數(shù)據處理網絡上的通信適配器116。一個顯示器適配器120將總線連接在顯示設備118上。工作站上常駐有諸如Apple_系統(tǒng)/7_操作系統(tǒng)之類的操作系統(tǒng)。
基于計算機的電話應用取決于它們的基本要求,基于計算機的電話的面向語音的應用分成三類1)依靠電話特征的軟件控制而無捕捉或使用語音信號的設備的應用2)需要錄制與播放語音數(shù)據的應用;以及3)同時承擔語音與非語音數(shù)據傳輸?shù)膽谩?br> 近年來,已設計出各種各樣的設備來使電話更有用。其中許多涉及計算機控制的電話。虛擬電話機這類應用直接訪問高級電話系統(tǒng)的版本,這種高級電話系統(tǒng)如此復雜,以致只有不到10%的用戶可以利用它的全部潛能。這些系統(tǒng)的基本問題是必須處理普通電話手機是具有非常低的接口帶寬的設備這一事實。加在電話系統(tǒng)上的每一種新的特征導致手機上的一個新的按鈕(或者,在MS-DOS的陰影下,要記住另一個特殊的號碼序列“*3”對轉接,“*5”對轉交)。
來自桌面上的這些功能的軟件控制結合設計完善的圖形用戶接口將幫助終端用戶繞過他們的本地PBX的神秘特性而使他們開始從自AlexanderGraham Bell的日子以來電話設備制造商設法達到的技術進步中得益。這一概念的一個很好的實例便是北方電訊的Meridian TeleCenter,它運行在當前的Macintosh_上,但當然只與北方電訊自己的PBX一起工作。電話銷售在其最簡單的形式中,計算機控制的電話銷售工具只允許從一個電話號碼的數(shù)據庫中自動撥號。較完善的改型可在多條線路上撥號并檢測何時有人在連接的另一端上應答,或者在屏幕上提供各被撥號方的詳細客戶信息。
語音I/O桌面應答機這里的概念是為了將其提高到己能從文字郵件系統(tǒng)所期望的功能水平而將語音郵件放置在桌面計算機。今天的典型語音郵件系統(tǒng)是與其它形式的電子通信平行并完全隔離的集中服務。
即使它們是能夠得到的,諸如成組尋址與聯(lián)機目錄等特征也很難通過標準按鈕電話機使用,并且即使它們包含重復的信息也必須與電子郵件數(shù)據庫分開建立與維護。呼叫進來檢驗自己的語音信箱只是通過辦公室與家里的信息流中又一種不必要的彎路。本年代的語音郵件系統(tǒng)與七十年代的集中計算機系統(tǒng)相類似。
把語音通訊聯(lián)系與桌面計算機結合將極大地改進當前剛成為廣泛可利用的現(xiàn)有電話服務。例如,接受方檢驗進入的呼叫方的電話號碼的能力(所謂呼叫方識別)將允許用戶在其他事件中確定針對個人的問候詞。例如,如果我正在等待來自我的兄弟John的一個重要電話并且我知道他呼叫我時我可能不在,我便能錄制一則報文,當我的計算機應答來自列在我的電子地址本中的他的電話號碼之一的任何呼叫時而予播放。
在一個通話的接收端上連有一臺計算機可以在一旦錄制了報文時提高處理報文的潛力。如果僅有的終端只是一臺按鈕手機,則顯然毫無可能對任何音步頻數(shù)據進行編輯。在語音數(shù)據傳輸中增加了數(shù)字格式的使用(如ISDN),不在音頻信號流過時設置捕捉它的設備便是極大的浪費。遠程訪問為了從家里訪問辦公室的計算機系統(tǒng),所需要的只是一條電話線,一臺調制解調器,及另一臺計算機。如果你到了機場但是你想起忘記帶了你要訪問的客戶的地址,你將怎么辦?如果你到達了目的地發(fā)現(xiàn)航空公司丟失了你的調制解調器連同你其它的行李時,你將怎么辦?如果你買不起第二臺計算機,你將怎么辦?這時你需要能夠從一臺標準電話機撥通你的辦公室系統(tǒng)并通過要求計算機以讀給你聽的方式而訪問存儲在你的硬盤上的信息。你還需要在你的辦公室機器上有文本到語音的合成軟件以及用DTMF(雙音調多頻率)鍵或語音命令(即自動語言識別)來控制桌面極算機的方法。交互式語音應答這一術語復蓋允許遠程呼叫者聽取從事先錄制的報文的集合中選擇的報文的大范圍應用。這些應用可以是單純專用于信息發(fā)布(諸如IRS的Teletax服務),或者它們可綜合信息交互作用業(yè)務處理(諸如,郵購目錄的定購單輸入服務,或者允許存款人檢查帳戶余額,資金轉帳,以及進行借款支付的電話銀行服務)。
傳統(tǒng)上,即使將一個直觀的信息發(fā)布系統(tǒng)組合在一起也需要程序員及系統(tǒng)綜合人員的專業(yè)化隊伍。至少一個提供這種服務的第三方已在Macintosh_上開發(fā)了一種面向圖形的工具用于生成一組控制文件,然后將其上裝到一個獨立的語音應答系統(tǒng)。語音布告板服務這是熟悉的電子BBS的一種語音中介版本。它實際上是語音郵件與交互式語音應答的混合物。呼叫者瀏覽其它呼叫者留下的各種語音報文,隨后錄制他們自己的應答報文。
同時的語音與數(shù)據合作電話服務在合作中扮演的角色當然取決于我們所討論的合作類型。平淡無奇的語音郵件可包含在順序的異步合作中(諸如書評人接收文件的拷貝,私下閱讀該拷貝,并用語音報文應答)。同時的異步合作包含對文件的作者發(fā)出一次呼叫(從附在文件上的“名片”對象上自動抽取電話號碼),從而當作者正在顯示該文件的一個獨立拷貝時書評作者能發(fā)布個人評論。第三種合作是同時的實時合作方式CHER,其中,一份文件同時由作者與書評者更新。在最后一種合作中,組員之間交互作用的增進程度無疑是與他們之間物理上互相靠近程度成反比變化的。這便是電話在地理上分散的工作組之間的遠程合作中起作用的情況?;靖拍钍窃谝粭l數(shù)據連接線上傳輸與接收文件更新的同時,保持標準的語音聯(lián)系。這種交互作用可在兩條標準電話線上或一條單一的ISDN連接線上進行。廉價可視電話同時的語音與數(shù)據傳輸?shù)牧硪环N有趣的應用涉及采用一臺廉價的攝象機連同一個視頻數(shù)字化器卡將一條標準的ISDN連接線變換成低收入人員的可視電話。換言之,通過把顯示通話人的面部和/或抓攝到的舉到攝象機前面的物體的視頻幀進行周期性的雙向傳輸,可以增強語音連接。即使幀速率極低時,最后的結果也是相當有趣的。
本發(fā)明是設計成使應用編寫人員有能力在全部三個領域內創(chuàng)建新的里程碑。
電話對象本發(fā)明設計用于實現(xiàn)基于計算機的電話應用的開發(fā),并允許電話設計人員利用這些新開發(fā)的應用。通過拿起受話器來發(fā)信號通知要求網絡服務,電話本質上是用于建立對另一終端的聯(lián)系的一個原始終端。然后輸入標識你要連接的終端的一序列號碼。通過掛機來切斷連接。本發(fā)明通過提供一個面向語音的電話功能的高級接口來支持基于計算機的電話。這些功能包含通常的電話配置中的性能的“最小公分母”。本發(fā)明旨在將應用級代碼與通過它們對這些功能進行訪問的設備之間的差別分隔開。同時,本發(fā)明提供一個靈活的框架,能容易地將它擴展成包含新的特征或提供電話機,本地硬件與軟件平臺,網絡類型,以及開關信令協(xié)議的各種組合的特征。
當提供了這樣一種靈活的接口框架時,許多應用程序編寫人員將利用這一接口的可用性來開發(fā)軟件。依次,電話系統(tǒng)設計人員要求利用新的應用部件,因此也需要接口部件進行工作。因此,討論兩種對象是有用的一方面是應用編寫人員的對象,另一方面是對基本接口的擴展的開發(fā)人員的對象。通常,應用開發(fā)人員感興趣的對象也是電話系統(tǒng)開發(fā)人員所感興趣的。各種類型將在下面討論。但是應記住下面的標題僅用于討論的目的,無論如何不應認為是限制性的。I.應用開發(fā)人員的對象電話系統(tǒng)由許多對接口有用的部件構成。通常存在著兩類這些部件。第一類包含用于實現(xiàn)電話系統(tǒng)的物理設備,而第二類則包含由電話系統(tǒng)處理的業(yè)務。下面將討論各類的對象,并將提供概述接口部件的可能類型的實例。
A.硬件類型部件的對象從應用編程人員的觀點,本發(fā)明方便了基于計算機的電話應用的簡單與直觀的用戶接口的實現(xiàn)。對象的硬件獨立性允許一個應用程序運行,而與連接在計算機上的電話系統(tǒng)或當前最終用戶所能利用的電話特征無關。標準協(xié)議使應用一開始就能判定它所知道的有關特征中哪些是有效的而哪些是無效的。
圖2示出最終用戶最熟悉的現(xiàn)實世界電話對象插入一個墻上插座204以連接在一條電話線202上的單線電話手機200。事實上,在墻上插座背后有并未由普通用戶所意識到的線路,光纖,開關,和總局等的龐大“網絡景色(netscape)”。重要的是現(xiàn)在可通過一個特定的手機訪問一條特定的線路202。然而手機與線路之間的對應并不一定是一對一的。
單一的電話線路可分成若干分機,各帶有其本身的手機(未示出)或者如圖3所示,一個單一的手機300可提供對若干條線路302的順序訪問,各條線路連接在獨立的插座304上。前一情況是典型的住宅裝機。反之,多線路手機可由小型商家或為三個總裁工作的行政助理所用。通常,用戶通過按下手機300上某處的一個帶標記的按鈕而選擇一條線路。
圖2與圖3沒有標識為先有技術,因為手機200可以實現(xiàn)成包含本發(fā)明的特征。
圖4表示實現(xiàn)根據本發(fā)明的基于計算機的電話的一種可能的系統(tǒng)。在基于計算機的電話所需的實際電話設備配置中,電話線404不連接在手機400上,而是通過諸如調制解調器408等外部設備的媒介而連接到計算機412上。線路410將計算機412連接在調制解調器408上,而線路404則將調制解調器408連接在插座406上。甚至對許多應用并無必要的手機400也連接在外部設備408或電話接口上,并且通常能獨立于計算機412啟動或終止連接。計算機能夠或不能控制和/或查詢手機均可。
計算機412可與圖1中所示的相同,包括一臺個人計算機或甚至一臺工作站。計算機412可包括一個鍵盤414,一個顯示器416,以及一個軟盤驅動器418。
圖5展示圖4中的系統(tǒng)的一種變型,示出具有用于經由線路502與504將手機500連接在插座506上的電話接口的計算機508。計算機508和圖4中所示的一樣,包括鍵盤512,顯示器512,及軟盤驅動器514。計算機508能夠響應手機500及經由線路502從電話線進來的信號兩者。計算機508也能不加修改地在手機500與插座506之間傳遞信號。
以上的討論概述了可用來實現(xiàn)本發(fā)明的某些特定硬件。然而應記住,這些硬件只是示例性的,而本發(fā)明能在連接到電話網絡上的各式各樣的系統(tǒng)與設備上實現(xiàn)。圖6展示了實施本發(fā)明的至少某些原理的一種設備。設備600利用對象與經由線路602與其連接的電話系統(tǒng)604的各種部件接口。設備600可以或不可以連接在一個或多個設備606上。
還應指出,設備600可很好地連接在插座以外的系統(tǒng)中的點上。即,面向對象的設備可從網絡中接出而與電話系統(tǒng)的部件接口。
在其上實現(xiàn)本發(fā)明的系統(tǒng)應能執(zhí)行多重任務或多重處理。這可提供應用和通過對象的系統(tǒng)資源的利用的最佳性能。
體系結構概況在連接到電話系統(tǒng)上的設備上運行的應用利用專門設計的接口部件與電話系統(tǒng)的部件進行交互。應指出,術語“應用運行”意味著不僅包含在計算機上運行的軟件程序,并且還包含可執(zhí)行特定應用的硬件。這些接口部件使得在各種電話系統(tǒng)部件之間互相傳遞信息所用的方法標準化。在一個最佳實施例中,接口部件是用對象有利地實現(xiàn)的。電話線路管理圖7為始于步驟700的展示多個TTelephoneLineHandle的例子的流程圖。如步驟702與704所示,只要電話線路事先未曾為數(shù)據通信保留,本發(fā)明便將其看成為可在面向語音的應用之間共享的系統(tǒng)資源。這些應用實際上通過代理類TTelephoneLineHandle訪問電話服務(步驟706)。例如為了允許用戶在前臺發(fā)出重復的自動撥號應用事例的同時而在后臺保持應答機應用的操作,可將多個TTelephoneLineHandle例示在同一條線路上并且跨越組的邊界分布(步驟706與708)。當不再需要TTelephoneLineHandle時,示例過程便在步驟710處結束,但每當需要TTelephoneLineHandle事例時便可重復。
圖8示出了TTelephoneLineHandle所執(zhí)行的功能的操作特征的可能流程。除了允許修改(步驟802與804)與查詢(步驟806與808)電話線的狀態(tài)之外,TTelephoneLineHandle提供建立表示線路的音頻輸入或輸出能力(如果有的話)的TMicrophone(麥克風)(步驟810與812)或TSpeaker(揚聲器)(步驟814與816)對象的部件功能。TTelephoneLineHandle的功能流程由步驟800與818描述。
注意從語音應用的觀點,“實際”電話線是通過圖4中所示的物理調制解調器設備還是通過圖4中所示的某種內部接口連接在計算機上是無關緊要的。在任何一種配置中,所有應用所“見到”的只是一個TTelephoneLineHandle。電話手機管理TTelephoneHandsetHandle表示與電話線路對立的物理電話設備。標準的TTelephoneHandsetHandle類具有用于報告其掛鉤開關狀態(tài)及用于建立表示手機的音頻輸入或輸出能力(如果有的話)的標準TMicrophone或TSpeaker對象的部件功能。如果存在這種能力,手機通常在兩種模式中工作,一種模式將音頻直接引導到并來自物理電話線,它完全繞過計算機;而在第二種模式中,則將音頻引導到并來自計算機,從而將物理線路留在回路之外。然而,在手機能用作一個本地揚聲器或麥克風之前,必須明確地將其從物理線路上“斷開”。注意TTelephoneHandsetHandle所建立的揚聲器和麥克風完全與TTelephoneLineHandle所建立的無關。播放音頻數(shù)據到手機揚聲器導致手機發(fā)出聲音。播放數(shù)據到線路揚聲器導致在電話網絡上發(fā)送聲音。
子類中可包括帶有按鈕的物理手機,顯示器,或帶在相關增益控制的外部揚聲器與麥克風。當然有一個“較低”的公分母一臺不能監(jiān)視其開關狀態(tài)的電話設備。在這一情況中,TTelephoneHandsetHandle對象不會被過度使用。即使開關狀態(tài)可用,TTelephoneHandsetHandle的標準版本對于典型的基于計算機的電話應用也完全是供選用的。
B.電話服務對象除了與電話網絡的使用相關聯(lián)的硬件類型實體之外(上面描述的),還有比較無形的對象。例如,連接本身,或者如最終用戶所想象的,電話通話可認為是無形的。一次通話具有與電話線路無關的存在和狀態(tài)。為了進行通話,用戶必須首先“找到”一條電話線。(“什么地方我能找到一臺電話?我要打一個電話。”)為了接受一次通話,用戶需要知道是從哪一條線路上進入的。(“史密司先生,線路1上有你一個電話?!?一條線路是摘機或掛機的,而一次通話在其生命周期中要經過各種狀態(tài)。在許多情況中,當用戶為了打出第二個電話而仍然保持當前通話不掛機時,要求一條單一的線路能支持多個同時通話。替換之,用戶可在一個已存在的連接加入一個通話而形成三方的電話會談。
在現(xiàn)實世界中,有關一次通話的進行的信息是通過音頻信道反饋給用戶的一種連續(xù)的聲調表示能撥號,一種斷續(xù)的聲調表示目的地線路忙音,“振鈴”聲調表示目的地電話正在振鈴等。在基于計算機的電話接口中可以得到這些相同的信號,以及以數(shù)字字母狀態(tài)說明形式的關于通話狀態(tài)的更有辨別力的細節(jié)。電話通話如圖9中所示,在步驟900與910之間,應用通過請求(步驟902·)TTelephoneLineHandle的一個實例來建立一個TTelephoneCallHandle(步驟904)而啟動與結束電話連接。
圖10示出TTelephoneCallHandle的功能流程。如步驟1000與1010之間所示,TTelephoneCallHandle提供確定連接的狀態(tài)的訪問方法(步驟1002與1004)以及返回遠程端點的電話號碼的方法(步驟1006與1008)。電話特征控制由于TTelephoneLineHandle只允許放置,答復,及掛斷通話,已提供了一族的類來方便對更普遍的補充語音特征的訪問。除了建立通話,線路管理能在遇到可利用高級特征的電話機時建立單個特征的控制對象。這些特征的實例中可包含下述特征集暫時中斷并占線等候,轉接,多方交談,放棄,及轉交。注意特征的可利用性不僅取決于電話硬件平臺潛在能夠提供的特征,還取決于用戶實際訂購的特征。電話通知圖11示出應用1100如何建立接收某些關于電話系統(tǒng)的通知的流程圖。想要接收任何下面討論的通知的客戶1100必須用標準通知框架登記對它們關心。必須通過調用TTelephoneLineHandle與TTelephoneHandsetHandle 1102所提供的“建立關心事物”部件功能之一束建立用于電話通知的TInterest 1104。
圖12示出電話設備1200通過能用于管理電話服務的對象發(fā)送出信息。利用TNotification的三個面向電話的子類從下層的電話硬件向外傳播關于線路狀態(tài),通話,以及特征的信息。TTelephoneStatusNotification在1202處傳送TInterest的三個電話專用子類之一的實例TTelephoneInterest,TTelephoneCallInterest,或TTelephoneFeatureInterest。狀態(tài)更新本身由TToken常數(shù)表示。TTelephoneRingNotification在1204處播送關于進入呼叫的信息。TTelephoneDigitsNotification在1206處允許客戶接收遠程端點生成的DTMF數(shù)字。電話號碼TPhoneNumber,TPhoneEndpoint,以及其它的類可用于表示電話號碼。音頻對象由TTelephoneLineHandle與TTelephonehandset返回的TSpeaker與TMicrophone對象為揚聲器與麥克風類的子類。一個警告數(shù)字電話的數(shù)據格式標準可以因地區(qū)不同而改變。例如,從一條ISDN線路進入的語音數(shù)據可以是對數(shù)壓擴的而不是線性的。并且該語音數(shù)據在8KHz上而不是在22KHz上數(shù)字化。為了指引這種潛在的不兼容性,本發(fā)明設想了格式轉換類。例如,格式轉換類可包括T8KMuLawTo22KConverter,T8KALawTo22KConverter,T22KTo8KMuLawConverter,以及T22KTo8KALawConverter。
圖13提供了用格式轉換對象的實例播放一個聲音文件的例子。例如,為了播放原先直接從一條北美ISDN線路錄制的一個聲音文件,可將文件1300的輸出端口連接在T8KMuLawTo22KConverter 1302的一個實例的輸入端口上。然后將該轉換器的輸出端口連接到TSpeaker 1304的一個實例的輸入端口,并調用文件的播放成員功能。音頻端口利用類型協(xié)商來選擇一種公共數(shù)據格式。
類與成員功能細節(jié)本節(jié)詳細描述以上所述的本發(fā)明的類與成員功能。
如圖14所示,為了利用可以得到的電話資源,在1400處,一個應用例示一個TTelephoneLineHandle,如上所述。然后可以通過調用由1402表示的線路的CreateAndPlaceCall方法或由1404表示的CreateAndAnswerCall方法而建立一個電話連接,兩者都返回一個調用管理。
為了得到正在進行的連接的控制,可利用由1406表示的線路的CreateCallList方法。由這三種方法中任何一種啟動的連接是通過調用通話管理上的由1408表示的HandUp而終止的。TTelephoneLineConfigurationData(電話線路配置數(shù)據)本類表示一條特定電話線的配置。如圖15所示,TTelephoneLineConfigurationData 1500標識與該線路的本地端點(1502)相關聯(lián)的號碼簿號碼并通過類型協(xié)商指定當前在線路(1504)上可得到哪些電話特征。
<pre listing-type="program-listing"><![CDATA[class TTelephoneLineConfigurationDatapublic MCollectible, public MTypeNegotiator//公用構造程序 //用電話號碼集合及特征序列類型,只用電話號碼或用單個電話號碼初始化 TTelephoneLineConfigurationData(const TCollection&amp;localEndpoint, const TSequence&amp;featureTypes); TTelephoneLineConfigurationData(const TCollection&amp;localEndpoint); TTelephoneLineConfigurationData(const TPhoneNumber&amp;); //拷貝構造程序 TTelephoneLineConfigurationData(const TTelephoneLineConfigurationData&amp;); //只用于流送與分配的系統(tǒng)預置構造程序 TTelephoneLineConfigurationData();//解除程序 virtual~TTelephoneLineConfigurationData();//賦值運算符 TTelephoneLineConfigurationData&amp;operator=(constTTelephoneLineConfigurationData&amp;);//訪問功能//返回與線路關聯(lián)的端點(一個或多個電話號碼)void GetLocalEndpoint(TPhoneEndpoint&amp;)const;//MTypeNegotiator替換 //返回有效的特征類型表 virtual void CreatePreferredTypeList(TSequence&amp;)const; //確認由這一配置表示的線路存在一個特定的特征類型 virtual TTypeDescription*ChooesPreferredType(const TSequence&amp;)const;//MCollectible替換MCollectibleDeclarationsMacro(TTelephoneLineConfigurationData); virtual long Hash()const; virtual BooleanIsEqual(const MCollectible*)const; virtual TStream&amp; operator<<=(TStream&amp;fromWhere); virtual TStream&amp; operator>>=(TStream&amp;toWhere)const;TTelephoneLineHandle]]></pre>前面已針對圖7與圖8討論過TTelephoneLineHandle。圖16示出與作為一條電話線的標準代理者的TTelephoneLineHandle相關聯(lián)的功能。它允許通過一個電話線配置數(shù)據對象選擇一條特定的線路(1600)并提供用于啟動電話通話連接的成員功能(1602),從而判定線路的掛鉤狀態(tài)(1604),通過類型協(xié)商匹配電話特征類型(1606),以及為線路建立音頻對象(1608)。它還生成供通知框架采用的用于登記與該線路相關聯(lián)的受關注的電話事件的TInterest子類(1610)。TTelephoneLineHandle是多線索安全的,但并未設計成供跨越組邊界的共享。
<pre listing-type="program-listing"><![CDATA[//公用構造程序 //用配置數(shù)據初始化 TTelephoneLineHandle(const TTelephoneLineConfigurationData&amp;); //拷貝構造程序 TTelephoneLineHandle(const TTelephoneLineHandle&amp;); //只用于流送及分配的系統(tǒng)預置建造器 TTelephoneLineHandle();//公用解除程序 virtual~TTelephoneLineHandle();//賦值運算符 virtual TTelephoneLineHandle&amp;operator=(const TTelephoneLineHandle&amp;);//應用接口 //返回這一線路表示的端點 virtualvoid GetLocalEndpoint(TCollection&amp;)const; //檢驗掛鉤狀態(tài) virtualBoolean IsOnHook()const; //建立一次通話,撥指定的號碼并返回通話 virtual TTelephoneCallHandle*CreateAndPlaceCall(const TPhoneNumber&amp;); //建立一次通話,應答進入的通話并返回通話 virtual TTelephoneCallHandle*CreateAndAnswerCall(); //返回對應于所請求的類型的特征控制對象 virtual TTelephoneLineFeatureControl*CreateFeatureControl(const TTypeDescription&amp;featureType); //返回電話線上當前正在進行的所有連接的TTelephoneCallHandle對象表 virtual void CreateCall List(TCollection&amp;) //送出原始DTMF數(shù)字 virtual void SendDigits(const TPhoneCharacters&amp;);//音頻I/O //建立適當類型的揚聲器與麥克風對象 virtual TSpeaker*CreateSpeaker(); virtual TMicrophone*CreateMicrophone();//通知框架支持 //返回這一線路所關心的掛鉤狀態(tài) virtual TInterest*CreateHookInterest()const; //返回這一線路所關心的振鈴通知virtual TInterest*CreateRingInterest()const; //返回指定的通知管理所關心的一個通話通知 virtual TInterest*CreateCallInterest(constTTelephoneCallHandle&amp;)const; //返回指定的特征控制所關心的一個特征通知 virtual TInterest*CreateFeatureInterest(constTTelephoneLineFeatureControl&amp;)const;低級控制功能將線路摘機 virtual void TakeOffHook();\ //將線路掛機 virtual void PutOnHook();//撥全部指定的電話號碼 virtual void DialNumber(const TPhoneNumber&amp;); //送出原始DTMF數(shù)字 virtual void SendDigits(const TPhoneCharacters&amp;);//MTypeNegotiator替換 //協(xié)商用于特征類型控制的可利用性 virtual void CreatePreferredTypeList(TSequence&amp;)const; virtual TTypeDescription*ChoosePreferredType(constTSequence&amp;)const;//MCollectible替換 MCollectibleDeclarationsMacro(TTelephoneLineHandle); virtual long Hash()const; virtual BooleanIsEqual(const MCollectible*)const; virtual TStream&amp; operator<<=(TStream&amp;fromWhere); virtual TStream&amp; operator>>=(TStream&amp;toWhere)const;TTelephoneCallHandle]]></pre>這是電話連接的輕加權代理者。它允許客戶確定參加連接的遠程號碼及通話的當前狀態(tài)。前面已經相對于圖9與圖10討論過TTelephoneCallHandle。TTelephoneCallHandle是多線索安全的,但并未設計成跨越組邊界共享的。
<pre listing-type="program-listing"><![CDATA[class TTelephoneCallHandlepublic MCollectible//注本類必須通過線路或線路管理建立//解除程序 virtual~TTelephoneCallHandle();//客戶接口 //抽取用于連接的遠程電話號碼 void GetRemoteNumber(TPhoneNumber&amp;theNum)const; //返回當前通話狀態(tài) virtual TToken GetStatus()const; //掛斷通話 virtual void HangUp();//MCollectible替換 MCollectibleDeclarationsMacro(TTelephoneCallHandle); virtual long Hash()const; virtual Boolean IsEqual(const MCollectible*)const;//注客戶不得分配或流送本類TTelephoneLineFeatureControl]]></pre>圖17示出了在1700處響應一個客戶而用TTelephoneLineHandle在1700建立TTelephoneLineFeatureControl。TTelephoneLineHandle可以或不能支持超出執(zhí)行和斷開電話連接的能力的任意組特征。例如,線路管理可能能夠在新的通話到來時采用占線等候的方式暫時中斷當時的通話,轉送一次通話,進行多方交談,或將原有的通話換到另一條線路??蛻敉ㄟ^要求線路管理建立TTelephoneLineFeatureControl的一個子類而使用諸如此類的特征。特征控制子類是用基于所要求的特征的類名的TTypeDescription指定的。TTelephoneLineFeature-Control是多線索安全的,但并未設計成跨越邊界的共享。
<pre listing-type="program-listing"><![CDATA[class TTelephoneLineFeatureControlpublic MCollectible//用于訪問定義的特征類型的靜態(tài)成員定義如下static const void GetHoldFeatureType(TTypeDescription&amp;);static const void GetDropFeatureType(TTypeDescription&amp;);static const void GetTransferFeatureType(TTypeDescription&amp;);static const void GetConferenceFeature Type(TTypeDescription&amp;);static const viod GetForwardFeatureType(TTypeDescription&amp;); //注本類必須通過線路或線路管理建立 //公用解除程序 virtual~TTelephoneFeatureControl(); //客戶接口 //返回特征類型描述 virtual void GetFeatureType(TTypeDescription&amp;)const=0; //返回當前特征狀態(tài)virtual TToken GetStatus()const;//MCollectible替換 MCollectibleDeclarationsMacro(TTelephoneLineFeatureControl); virtual long Hash()const; virtual Boolean IsEqual(const MCollectible*)const;//注客戶不得分配或流送本類]]></pre>標準TTelephoneLineFeatureControl子類提供了五種標準特征控制子類,它們對應于“大四”補充特征并加上通話轉交。1)暫時中斷并占線等候特征控制<pre listing-type="program-listing"><![CDATA[class TTelephoneHoldFeatureControlpublic TTelephoneLineFeatureControl//公用解除程序virtual~TTelephoneHoldFeatureControl();TTelephoneLineFeatureControl替換//返回特征類型描述virtual void GetFeatureType(TTypeDescription&amp;)const;/客戶接口 //暫時中斷并占線等候當前有效的通話 virtual void PutOnHold(); //恢復指定的通話 virtual void Reconnect(const TTelephoneCallHandle&amp;);//MCollectible替換 MCollectibleDeclarationsMacro(TTelephoneHoldFeatureControl); virtual long Hash()const;virtual Boolean IsEqual(const MCollectible*)const;]]></pre>2)放棄特征控制<pre listing-type="program-listing"><![CDATA[class TTelephoneDropFeatureControlpublic TTelephoneLineFeatureControl//公用解除程序virtual~TTelephoneDropFeatureControl();//TTelephoneLineFeatureControl替換 //返回特征類型描述 virtual void GetFeatureType(TTypeDescription&amp;)const;//客戶接口//放棄指定的通話virtual void Drop(const TTelephoneCallHandle&amp;);//MCollectible替換MCollectibleDeclarationsMacro(TTelephoneDropFeatureControl);virtual longHash()const virtual Boolean IsEqual(const MCollectible*)const;]]></pre>3)轉接特征控制<pre listing-type="program-listing"><![CDATA[class TTelephoneTransferFeatureControlpublicTTelephoneLineFeatureControl//公用解除程序virtual~TTelephoneTransferFeatureControl();//TTelephoneLineFeatureControl替換 //返回特征類型描述 virtual void GetFeatureType(TTypeDescription&amp;)const;//客戶接口//起動轉接并將通話放置到指定的號碼virtual TTelephoneCallHandle*CreateCallAndStartTransfer(const TPhoneNumber&amp;newNumber); //結束進行中的轉接操作 virtual void CompleteTransfer(); //中止進行中的轉接操作 virtual void CancelTransfer();//MCollectible替換 MCollectibleDeclarationsMacro(TTelephoneTransferFeatureControl); virtuallong Hash()const; virtualBoolean IsEqual(const MCollectible*)const;]]></pre>4)多方交談特征控制<pre listing-type="program-listing"><![CDATA[class TTelephoneConferenceFeatureControl;public TTelephoneLineFeatureControl//公用解除程序virtual~TTelephoneConferenceFeatureControl();//TTelephoneLineFeatureControl替換 //返回特征類型描述 virtual void GetFeatureType(TTypeDescription&amp;)const;//客戶接口 //起動多方交談操作并將通話放置到指定號碼 virtual TTelephoneCallHandle* CreateCallAndStartAddingToConference(const TPhoneNumber&amp; newNumber); //完成正在進行的多方交談操作 virtual void FinishAddingToConference(); //中止正在進行的多方交談操作virtual void CancelAddingToConference();//MCollectible替換 MCollectibleDeclarationsMacro(TTelephoneConferenceFeatureControl); virtual longHash()const; virtual Boolean IsEqual(const MCollectible*)const;]]></pre>5)轉交特征控制<pre listing-type="program-listing"><![CDATA[class TTelephoneForwardFeatureControlpublic TTelephoneLineFeatureControl//公用解除程序virtual~TTelephoneForwardFeatureControl();//TTelephoneLineFeatureControl替換 //返回特征類型描述 virtual void GetFeatureType(TTypeDescription&amp;)const;//客戶接口 //轉交線路給指定的號碼 virtual void Forward(const TPhoneNumber&amp;phoneNumber); //撤消通話轉交 virtual void CancelForward();//MCollectible替換 MCollectibleDeclarationsMacro(TTelephoneForwardFeatureControl); virtual long Hash()const; virtual Boolean IsEqual(const MCollectible*)const;TTelephoneHandsetConfigurationData(電話手機配置數(shù)據)]]></pre>本類表示一個特定的電話手機的配置。它標識該電話手機可連接的一條或多條電話線路。這已參照圖15討論過。
<pre listing-type="program-listing"><![CDATA[class TTelephoneHandsetConfigurationDatapublic MCollectible//構造程序//用手機能夠連接的電話線的配置初始化TTelephoneHandsetConfigurationData(const TCollection&amp;);TTelephoneHandsetConfigurationData(constTTelephoneLineConfigurationData&amp;);//拷貝構造程序TTelephoneHandsetConfigurationData(constTTelephoneHandsetConfigurationData&amp;);//只用于流送與分配的系統(tǒng)預置構造程序TTelephoneHandsetConfigurationData();//解除程序virtual~TTelephoneHandsetConfigurationData();//賦值運算符TTelephoneHandsetConfiguationData&amp;operator=(constTTellephoneHandsetConfigurationData&amp;);//訪問功能 //為手機能夠連接的所有電話線建立配置數(shù)據對象 virtual void CreateConnectibleLineConfigurations(TCollection&amp;)const;//MCollectible替換MCollectibleDeclarationsMacro(TTelephoneHandsetConfigurationData); virtual long Hash()const; virtual Boolean lsEqual(const MCollectible*)const; virtual TStream&amp; operator<<=(TStream&amp;fromWhere); virtual TStream&amp; operator>>=(TStream&amp;toWhere)const;TTelephoneHandsetHandle]]></pre>圖18提供TTelephoneHandsetHandle的功能表示,它是物理電話終端設備的標準代理者。它提供監(jiān)視掛鉤狀態(tài)的機制(1800)并允許建立對應于手機的內部揚聲器與麥克風的音頻對象(1802,1804)。它還生成供通知框架使用的用于登記與手機相關的受關注的電話事件(1806)。作為一種物理設備,手機通常提供對一條特定的電話線路的手動控制,從而拿起手機就要導致某處的電話線路成為摘機。在用于音頻I/O之前,手機必須從其線路上“斷開”。也有可能將一個手機連接到一組電話線中的一條上。TTelephoneHandsetHandle是多線索安全的,但并未設計成跨越組邊界的共享。
<pre listing-type="program-listing"><![CDATA[class TTelephoneHandsetHandlepublic MCollectible//公用構造程序 //用配置數(shù)據初始化 TTelephoneHandsetHandle(const TTelephoneHandsetConfigurationData&amp;);//拷貝建造器 TTelephoneHandsetHandle(const TTelephoneHandsetHandle&amp;); //只用于流送與分配的系統(tǒng)預置構造程序 TTelephoneHandsetHandle(); //公用解除程序 virtual~TTelephoneHandsetHandle();//賦值運算符virtual TTelephoneHandsetHandle&amp;operator=(constTTelephoneHandsetHandle&amp;);//應用接口 //檢驗掛鉤狀態(tài) virtual Boolean IsOnHook()const; //檢驗連接狀態(tài) virtual Boolean IsConnected()const; //連接到一條特定的電話線 //注手機一次只能連接到一條線路 virtual void ConnectToTelephoneLine(const TTelephoneLineHandle&amp;); //從一條特定的電話線上斷開 virtual void DisconnectFromTelephoneLine(); //為當前連接到該手機的線路建立配置 virtual TTelephoneLineConfigurationData* CreateLineConfigurationData()const; //為可用來連接該手機的所自線路建立配置數(shù)據對象 virtual void CreateConnectibleLineConfigurations(TCollection&amp;)const;//音頻I/O//建立適當類型的揚聲器與麥克風音頻對象 注這些對象表示手機本身而不是它所連接的線路的音頻I/O能力 virtual TSpeaker*CreateSpeaker(); virtual TMicrophone*CreateMicropone();//通知框架支持 //返回這一手機的掛鉤狀態(tài)關心事物 virtual TInterest*CreateHookInterest()const; //返回這一手機的振鈐通知關心事物 virtual TInterest*CreateRingInterest()const;MCollectible替換 MCollectibleDeclarationsMacro(TTelepnoneHandsetHandle); virtual long Hash()const; virtual Boolean IsEqual(const MCollectible*)const; virtual TStream&amp; operator<<=(TStream&amp;fromWhere); virtual TStream&amp; operator>>=(TStream&amp;toWhere)const;TInterest子類]]></pre>圖19示出TInterest子類。本發(fā)明利用三種特定的TInterest子類來通知狀態(tài)更新TTelephoneInterest 1900,TTelephoneCallInterest 1908,以及TTelephoneFeatureInterest1912。TTelephoneInterest 1900允許客戶請求通知影響一條特定電話線或手機的某些電話事件。這些事件包括掛鉤狀態(tài)中的改變1902,來自進入呼叫的振鈴指示1904,及到達的遠程生成的數(shù)字串1906。TTelephoneCallInterest 1908允許客戶請求通知一個特定的電話連接過程中的變化1910。TTelephoneFeatureInterest 1912同樣允許客戶請求通知一種電話特征的特定事例的過程中的變化1914。客戶應該通過調用TTelephoneLineHandle與TTelephoneHandsetHandle所提供的適當成員功能來建立上述類的事例1916。它們都不是多線索安全的。
<pre listing-type="program-listing"><![CDATA[·TTelephoneInterestclass TTelephoneInterestpublic TInterest//公用構造程序TTelephoneInterest(const TTelephoneInterest&amp;);TTelephoneInterest();//公用解除程序virtual~TTelephoneInterest();//賦值運算符virtual TTelephoneInterest&amp;operator=(const TTelephoneInterest&amp;);//MCollectible替換 MCollectibleDeclarationsMacro(TTelephoneInterest); virtual long Hash()const; virtual BooleanIsEqual(const MCollectible*)const; virtual TStream&amp; operator<<=(TStream&amp;fromWhere); virtual TStream&amp; operator>>=(TStream&amp;toWhere)const;·TTelephoneCallInterestclass TTelephoneCallInterestpubllic TInterest//公用構造程序TTelephoneCallInterest(const TTelephoneCallInterest&amp;);TTelephoneCallInterest();//公用解除程序virtual~TTelephoneCallInterest();//賦值運算符virtual TTelephoneCallInterest&amp; operator=(const TTelephoneCallInterest&amp;);//MCollectible替換 MCollectibleDeclarationsMacro(TTelephoneCallInterest); virtual long Hash()const; virtual Boolean IsEqual(constMCollectible*)const; virtual TStream&amp; operator<<=(TStream&amp;fromWhere); virtual TStream&amp; operator>>=(TStream&amp;toWhere)const;·TTelephoneFeatureInterestclass TTelephoneFeatureInterestpublic TInterst//公用構造程序TTelephoneFeatureInterest(const TTelephoneFeatureInterest&amp;);TTelephoneFeatureInterest();//公用解除程序virtual~TTelephoneFeatureInterest();//賦值運算符virtual TTelephoneFeatureInterest&amp;operator=(const TTelephoneFeatureInterest);//MCollectible替換 MColloectibleDeclarationsMacro(TTelephoneFeatureInterest); virtual longHash()const; virtual Boolean IsEqual(const MCollectible*)const;virtual TStream&amp; operator<<=(TStream&amp;fromWhere); virtual TStream&amp; operator>>=(TStream&amp;toWhere)const;]]></pre>關心事物名常量下述公用靜態(tài)常量是為與通知框架一起使用而定義的 ·定義在TTelephoneInterest范圍內的關心事物名<pre listing-type="program-listing"><![CDATA[//掛鉤狀態(tài)更新 stati cconst TToken&amp; kHookStatus; //電話振鈴關心事物名 static const TToken&amp; kRingNotification; //TTelephone數(shù)字關心事物名 static const TToken&amp; kDigitsReceived;]]></pre>·定義在TTelephoneCallInterest范圍內的關心事物名<pre listing-type="program-listing"><![CDATA[//通話狀態(tài) static const TToken&amp; kCallStatus;]]></pre>·定義在TTelephoneFeatureInterest范圍內的關心事物名<pre listing-type="program-listing"><![CDATA[//電話特征狀態(tài)static const TToken&amp; kFeatureStatus]]></pre>
TNotification子類圖20示出從TNotification子類得出的功能關系。有三種TNotification的面向電話的子類。TTelephoneStatusNotification2000輸送一個狀態(tài)更新2002并包含一個TTelephoneInterest,一個TTelephoneCallInterest,或一個TTelephoneFeatureInterest 2004來替代一個簡單的TInterest。取決于與它們相關的操作的進行,可將狀態(tài)更新分配給四種類型之一成功,失敗,進行中,或未知。這允許應用執(zhí)行一個進入通知的初步分類而無須明顯地檢驗其狀態(tài)字段。TTelephoneRingNotification 2006在它已被應答之前輸送一個進入呼叫的電話號碼2008。最后,TTelephoneDigitsNotification 2010輸送來自一個遠程連接的電話鍵盤的原始DTMF數(shù)字2012。客戶通常通過通知框架2016而不是通過建立它們自己的事例來得到這些類的事例2014。這些類不是多線索安全的。
<pre listing-type="program-listing"><![CDATA[·狀態(tài)通知 class TTelephoneStatusNotificationpublic TNotification//公用構造程序TTelephoneStatusNotification(const TTelephoneStatusNotification&amp;);TTelephoneStatusNotification(const TInterest&amp;);//公用解除程序virtual~TTelephoneStatusNotification();//賦值運算符virtual TTelephoneStatusNotification&amp;operator=(const TTelephoneStatusNotification&amp;);//客戶接口//取得/設置狀態(tài)信息 TToken GetStatus()const;//取得通知分類 long GetClassification()const;//MCollectible替換 MCollectibleDeclarationsMacro(TTelephoneStatusNotification); virtual long Hash()const; virtual Boolean IsEqual(const MCollectible*)const; virtual TStream&amp; operator<<=(TStream&amp;fromWhere); virtual TStream&amp; operator>>=(TStream&amp;toWhere)const;·振鈴通知class TTelephoneRingNotificationpublic TNotification//公用構造程序TTelephoneRingNotification(const TPhoneNumber&amp;);TTelephoneRingNotification();TTelephoneRingNotification(const TTelephoneRingNotification&amp;);//公用解除程序virtual~TTelephoneRingNotification();//賦值運算符virtual TTelephoneRingNotification&amp;operator=(const TTelephoneRingNotification&amp;);//客戶接口 //抽取呼叫方電話號碼 void GetIncomingNumber(TPhoneNumber&amp;)const;//Mcollectible替換MCollectibleDeclarationsMacro(TTelephoneRingNotification); virtual long Hash()const; virtual Boolean IsEqual(const MCollectible*)const; virtual TStream&amp; operator<<=(TStream&amp;fromWhere); virtual TStream&amp; operator>>=(TStream&amp;toWhere)const;·進入數(shù)字通知class TTelephoneDigitsNotificationpublic TNotification//公用構造程序 TTelephoneDigitsNotification(const TTelephoneDigitsNotification&amp;); TTelephoneDigitsNotification();//公用解除程序 virtual~TTelephoneDigitsNotification();//賦值運算符virtual TTelephoneDigitsNotification&amp;operator=(const TTelephoneDigitsNotification&amp;);//客戶接口 viod GetDigits(TPhoneCharacters&amp;)const;//MCollectible替換 MCollectibleDeclarationsMacro(TTelephoneDigitsNotification); virtual long Hash()const; virtual BooleanIsEqual(const MCollectible*)const; virtual TStream&amp; operator<<=(TStream&amp;fromWhere); virtual TStream&amp; operator>>=(TStream&amp;toWhere)const;]]></pre>
狀態(tài)常量下述公用靜態(tài)常量TToken標記是為TTelephoneStatusNotification∷的范圍內的電話狀態(tài)更新而定義的·線路狀態(tài)常量KOnHook-線路或手機掛機KOffHook-線路或手機摘機·通話狀態(tài)常量kCallIdle-通話無效。系統(tǒng)預置狀態(tài)。
kIncompleteCallInfo-通話安排正在進行,但需要更多信息。
kCallReorder-通話安排不能前進。號碼中有錯誤。
kCallCannotComplete-通話安排不能完成。
kReadyToDial-存在撥號音。
kFastBusy-撥號音暫停。
kDialingComplete-成功地完成撥號。
kRingbackDetected-收到返回振鈴指示。目的地電話正在振鈴。
kBusyDetected-收到忙音指示。目的地電話號碼正忙。
kNoAnswer-目的地電話號碼無應答。
kCallActive-通話已成功地連接。
kCallOnHold-通話已被暫時中斷處于占線等候狀態(tài)。
kCallTerminationDetected-網絡或連接方已結束通話?!ぬ卣骺刂瞥A縦ActivateInProgress-已確認特征激活請求。
kActivateComplete-特征現(xiàn)被激活。
kCannotActivate-不能激活特征。
kDeactivateInProgress-已確認特征釋放請求。
kDeactivateComplete-特征現(xiàn)被釋放。
kCannotDeactivate-不能釋放特征。
kErrorState-出現(xiàn)一個不明錯誤。ETelephoneStatusClassificationETelephoneStatusClassification是一種在TTelephoneStatusNotification范圍內定義的危害,用以表示一種狀態(tài)通知的通用分類,從而客戶能適當?shù)仨憫鵁o須檢驗狀態(tài)值。定義的值為kSuccess-成功地完成操作kFailure-沒有完成操作kInProgress-正在正常進行操作kUnknown-對于這一狀態(tài)操作的進行不明轉換器類數(shù)據格式轉換是通過諸如T8KMuLawTo22KConverter,T8KALawTo22K-Converter,T22KTo8KMuLawConverter,和T22KTo8KALawConverter等轉換器進行的。這些類繼承MAudio并且不增加它們自己的新的接口協(xié)議。II.電話系統(tǒng)開發(fā)人員的對象除了上面討論的對象以外,電話系統(tǒng)開發(fā)人員在開發(fā)新的電話設備時需要進一步的對象用來工作。例如,諸如AT&amp;T等第三方開發(fā)人員可能希望增加對專有電話設備的支持和/或擴展本發(fā)明來提供高級通訊能力。本發(fā)明將盡可能快與好地滿足第三方開發(fā)人員的這些努力。電話體系結構在使得與標準對象相關的現(xiàn)存代碼的潛在重復使用最大化的同時,還應預見這些擴展的需要。
對象的體系結構概述電話開發(fā)人員須考慮三類種在上面應用部分中未描述的類。抽象的電話線路類定義對電話網絡功能的一個標準接口。它具有與TTelephoneLineHandle面對面的主代理者關系,并包括用于與可能存在多個組中的處理進行通信的內裝式機構。由TTelephoneFeature及其子類提供用于訪問超出簡單的掛/摘機與撥號功能的通用補充特征的接口。希望在專用電話硬件上提供對標準功能的訪問的開發(fā)人員將需要產生線路類的子類及預先定義的特征子類。電話線圖21表示抽象的主類TTelephoneLine,它提供對電話網絡的物理連接的一個軟件模型。每一條電話線路具有相關的(1)一種掛鉤狀態(tài)(掛或摘)2100,(2)包含一組唯一的號碼簿號碼2102的一個TPhoneEndpoint,以及(3)一組本身可用的電話特征2104。此外,一條線路管理向其引導狀態(tài)更新的一張有效的處理表2116。
TTelephoneLine包含純虛擬的成員功能,用于進行摘機,掛機,以及撥出數(shù)字。這些功能中的每一種的實現(xiàn)必須由開發(fā)人員提供。在大多數(shù)情況下,這種實現(xiàn)將需要與專用于給定的硬件/軟件環(huán)境的一個I/O訪問管理程序和/或一個聽音程序任務通信。
例如,如果物理電話接口位于運行一個特定任務A的γ總線卡上,設備驅動器的角色便可出作為TTelephoneLine子類的一個成員字段的示例的一個TaskACard對象來擔任。對該子類的OffHook方法的調用會導致線路向TaskACard發(fā)送一則包含適當?shù)拿钆c數(shù)據的報文。通過一個包含TaskAListener的聽音程序任務向該線路送回應答。然后,線路子類建立適當?shù)腡Notification子類并通過從TTelephoneLine繼承的ReceiveUpdate方法將它們向下傳送到相關的TTelephoneLineHandle。
開發(fā)人員可能感興趣的兩個其它的成員功能為CreateSpeaker與CreateMicrophone。這兩個功能具有簡單地返回一個NIL(零)指針的系統(tǒng)預置實現(xiàn)。然而,建立請求調度程序來平整非零指針供另一方的TTelephoneLineHandle再現(xiàn)。一個最佳實施例包含與實際電話硬件對應的音頻對象以及對聲音服務程序的適當調用來例示這些對象。注意在許多情況中(諸如連接在串行端口上的一個標準的外部調制解調器),不可能在主計算機上傳進或傳出實際的語音數(shù)據而必須保留系統(tǒng)預置實現(xiàn)。
保證按正常序列來生成由線路處理與通話處理類所期望的通知事件是TTelephoneLine子類的責任。電話特征為了提供超出建立與斷開連接所需的高級特征,設想基本TTelephoneLine類支持諸如最普遍使用的五種“暫時中斷并占線等候”,“放棄”,“轉接”,“多方交談”,與“轉交”高級電話特征的請求的調度與處理。在一個給定的電話開關上可以得到的特定特征組既取決于該開關的內在能力,還取決于該開關的客戶所選訂的服務。由于這一點以及由于每年開關制造商推出更新與更精巧的特征,TTelephoneLine工作在一組復雜的特征上,從而多形地激活與釋放它們。
繼續(xù)參見圖21,其中示出了TTelephoneLineFeature的子類。TTelephoneLineFeature為所有特征從其中導出的基本類,它定義激活/釋放協(xié)議。從TTelephoneLineFeature 2104可導出一組標準特征子類TTelephoneHoldFeature 2106,TTelephoneDropFeature 2108,TTelephoneTransferFeature 2110,TTelephoneConferenceFeature2112,以及TTelephoneForwardFeature 2114。其中每一個與保持該特征的控制協(xié)議的任何子類所使用的一種類型描述相關聯(lián)。上列五種特征的標準類型描述是由TTelephoneLineFeatureControl通過靜態(tài)成員功能提供的。
希望提供實現(xiàn)標準特征組的開發(fā)人員必須建立TTelephoneHoldFeature 2106,TTelephoneDropFeature 2108,TTelephoneTransferFeature 2110,TTelephoneConferenceFeature2112,以及TTelephoneForwardFeature 2114的子類,替換繼承的純虛擬功能激活與釋放,以便執(zhí)行有用的工作。
圖22示出在2202處,如果具有著沒有標準TTelephoneLineFeature子類存在的高級特征情況下的過程。在2204處,如果該特征是標準的,便使用它。如果該特征不是標準的,則依賴于開發(fā)人員通過置換純虛擬的成員功能GetTypeDescription在2206提供一個類型描述,并在2208處提供激活與釋放的實現(xiàn)。開發(fā)人員還必須在2210處定義一個特征控制子類以提交給線路處理,并且必須在2212處置換CreateFeatureControl,以使其返回控制的一個實例。電話配置本發(fā)明采用兩種配置信息。例如,從一個可顯示號碼到一個可撥號碼的轉換要求知道本地區(qū)的代碼,以及用于訪問長途服務的前綴。這一類信息可隨地區(qū)變化,但對于裝設在一個給定地點的所在電話線路則是通用的。另一方面,本地電話號碼及與該號碼相關聯(lián)的分機所能利用的特征則是在同一地點內隨不同線路而不同的信息。
在企業(yè)安裝中,可由系統(tǒng)管理人員提供地點專用的配置信息并包含有分配給單個用戶的裝機組件。用戶仍必須指定線路專用的配置。非企業(yè)用戶要負責提供這兩組信息。配置數(shù)據的實際顯示與采集可能需要開發(fā)人員生成一個能夠采集輸入的專用應用程序或一個數(shù)據模型。
配置信息是由TTelephoneLineConfigurationData表示的,它是包含一個由給定的TTelephoneLine所需要的所有地點與線路專用的配置數(shù)據的一個輕加權配置類。一種類似的關系可在TTelephoneHandsetConfigurationData與TTelephoneHandset之間得出。這兩個類已在前一部分中描述過。音頻對象如果開發(fā)人員的TTelephoneLine子類能夠捕捉與再現(xiàn)實際的語音信號,則其依賴于電話開發(fā)人員通過聲音服務程序提供支持這一能力所需的音頻類。例如,對從ISDN卡提供音頻I/O感興趣的開發(fā)人員要編寫MAudio/TAudioProcessor對以表示該硬件的輸入與輸出能力。電話開發(fā)人員的編程接口本節(jié)詳細描述前一節(jié)中所引入的開發(fā)人員工具的類與成員功能。想要實現(xiàn)標準功能和特定電話環(huán)境的特征的開發(fā)人員將對TTelephoneLine以及標準的TTelephoneLineFeature和TTelephoneLineFeatureControl子類再行分類。想要增加新特征與功能的開發(fā)人員將需要TTelephoneLineFeature與TTelephonelineFetureControl的其他子類。必須支持專用的終端設備的開發(fā)人員將編寫TTeleponeHandset與TTelephoneHandsetHandle的子類。TTelephoneLine圖23示出TTelephoneLine 2300的功能動作。這是表示一條電話線路的基本對象。它提供對簡單的電話網絡功能的低級接口。功能包括TakeOffHook 2302,PutOnHook 2304,DialNumber 2306,以及SendDigits 2308。該線路建立TelephoneCallHandle 2310來表示連接,從其TTelephoneLineFeature組中得到TTelephoneFeatureControl2312,并且也能建立麥克風與揚聲器音頻對象2314。一個TTelephoneLine與一個或多個稱作TTelephoneLineHandle的代理對象相關聯(lián)。處理中繼對它們的主線路的請求,后者又依次將電話掛鉤、振鈴、通話、特征與數(shù)字通知分配給線路處理。諸如暫時中斷并占線等候,放棄,轉接,多方交談等高級特征是通過TTelephoneLineFeature的子類支持的。TTelephoneLine已設計成由屬于不同的組的管理安全地共享。
<pre listing-type="program-listing"><![CDATA[class TTelephoneLineprotected MRemoteDispatcher, public MDelegatingNotifier, private MReferenceCounted//公用構造程序virtual~TTelephoneLine();//公用訪問功能//指定該線路的配置//注客戶可能想要改變一條現(xiàn)有線路的配置virtual void SetConfigurationData(const TTelephoneLineConfigurationData&amp;);//建立與返回該線路的配置virtual TTelephoneLineConfigurationData*CreateConfigurationData()const;//受保護的構造程序//指定本地配置信息TTelephoneLine(const TTelephoneLineConfigurationData&amp;);//拷貝構造程序TTelephoneLine(const TTelephoneLine&amp;);//系統(tǒng)預置構造程序,只用于流送TTelephoneLine();//受保護的賦值運算符TTelephoneLine&amp;operator=(const TTelephoneLine&amp;);//子類接口 //在特征表上增加一個新特征對象 //線路子類應在它們的構造程序中建立與采用特征 virtual void AdoptFeature(TTelephoneLineFeature*); //指定該線路實例為之配置的特征類型 //采用特征后必須在構造程序中調用的 //如果要配置的特征不存在便生成異常 virtual void ConfigureFeatures(const TCollection&amp;); //響應外部事件更新線路與傳播通知 virtual void ReceiveUpdate(TNotification&amp;); //掛鉤狀態(tài)設定程序 virtual void SetHookStatus(const TToken&amp;);//來自管理的進程請求,這些成員功能是受保護的//注以下4種純虛擬功能的特定實現(xiàn)必須為使用的實際電話硬件提供 //將線路摘機 virtual void TakeOffHook()=O; //將線路掛機 virtual void PutOnHook()=0; //撥全部指定的電話號碼 virtual void DialNumber(const TPhoneNumber&amp;)=0; //送出原始DTMF數(shù)字 virtual void SendDigits(const TPhoneCharacters&amp;)=0;//其余的受保護的請求管理具有系統(tǒng)預置的實現(xiàn) //作為原子功能放置通話-提供系統(tǒng)預置實現(xiàn) virtual TTelephoneCallHandle*CreateAndPlaceCall(const TPhoneNumber&amp;); //作為原子功能應答通話-提供系統(tǒng)預置實現(xiàn)virtual TTelephoneCallHandle*CreateAndAnswerCall(); //返回該線路上正在進行的所有通話的管理 virtual void CreateCallList(TCollection&amp;)const; //返回當前掛鉤狀態(tài) vi rtual TToken UpdateHookStatus()const //返回指定的通話的當前狀態(tài) virtual TToken UpdateCallStatus(const TTelephoneCallHandle&amp;); ///返回對應于所請求的特征類型的特征控制對象 virtual TTelephoneLineFeatureControl*CreateFeatureControl(const TTypeDescription&amp;)const;//受保護的音頻I/O功能 //建立適當類型的揚聲器與麥克風音頻對象 virtual TSpeaker*CreateSpeaker()=0; virtual TMicrophone*CreateMicrophone()=0;//受保護的通話管理功能 //建立一個新連接 virtual TTelephoneCallHandle*AddCallAndCreateHandle( const TPhoneNumber&amp;); //定位與指定的狀態(tài)匹配的通話管理 virtual TTelephoneCallHandle*FindCallAndCreateHandle(const TToken&amp;callState)const; //消除一個存在的連接 virtual void DeleteCall(const TTelephoneCallHandle&amp;);//受保護的特征管理功能 //定位指定類型的特征 virtual TTelephoneLineFeature*GetFeature( const TTypeDescription&amp;featureType)const;//受保護的生成通知的功能 virtual TNotification*CreateHookNotification(const TToken&amp; HookState,TTelephoneStatusNotification∷ETelephoneStatusClassificationclassification=TTelephoneStatusNotification∷kSuccess)constvirtual TNotification*CreateRingNotification(constTPhoneNumber&amp;)const;vritual TNotification*CreateCallNotification(const TToken&amp;callState, const TTelephoneCallHandle&amp;, TTelephoneStatusNotification∷ETelephoneStatusClassification classification=TTelephoneStatusNotification∷kSuccess)const;virtual TNotification*CreateFeatureNotification(const TToken&amp; featureState,const TTelephoneLineFeature&amp;, TTelephoneStatusNotification∷ETelephoneStatusClassification classification=TTelephoneStatusNotification∷kSuccess)const;virtual TNotificationuCreateDigitsNotification(const TPhoneCharacters&amp;) const;//公用MCollectible替換 VersionDeclarationsMacro(TTelephoneLine); virtual longHash()const; virtual Boolean IsEqual(const MCollectible*)const;//受保護的流送運算符只能由子類調用 virtual TStream&amp;operator<<=(TStream&amp;fromWhere); virtual TStream&amp;operator>>=(TStream&amp;toWhere)const;TTel ephoneHandset]]></pre>圖24示出TTelephoneHandset 2400執(zhí)行的功能流程。這是代表一個物理電話手機的基本對象。它也能建立麥克風與揚聲器音頻對象2402。一個TTelephoneHandset 2400與一個或多個稱作TTelephoneHandsetHandle 2404的代理對象相關聯(lián)。管理中斷對它們的手機的請求2406,后者又依次將狀態(tài)更新2408分配給管理。TTelephoneHandset 2400已設計成由屬于不同組的管理安全地共享。
<pre listing-type="program-listing"><![CDATA[class TTelephoneHandsetprotected MRemoteDispatcher, public MDelegatingNotifier, public MReferenceCounted//公用解除程序virtual~TTelephoneHandset();//公用訪問功能//指定該手機的配置//注客戶可能想要改變一條現(xiàn)有線路的配置virtual void SetConfigurationData(const TTelephoneHandsetConfigurationData&amp;);//建立與返回該手機的配置virtual TTelephoneHandsetConfigurationData*CreateConfigurationData() const;//受保護的構造程序//指定本地配置信息TTelephoneHandset(const TTelephoneHandsetConfigurationData&amp;);//拷貝構造程序TTelephoneHandset(const TTelephoneHandset&amp;);//系統(tǒng)預置構造程序-只用于流送TTelephoneHandset();//賦值運算符TTelephoneHandset&amp;operator=(const TTelephoneHandset&amp;);//子類接口 //響應外部事件更新線路及傳播通知 virtual void ReceiveUpdate(TNotification&amp;); //受保護的掛鉤狀態(tài)設定程序 virtual void SetHookStatus(const TToken&amp;theStatus); //用指定的配置定位可連接的電話線路 //為便于實現(xiàn)“ConnectToTelephoneLine”純虛擬功能而提供本功能 virtual TTelephoneLine*FindLine( const TTelephoneLineConfigurationData&amp;);//來自管理的進程請求-這些成員功能是受保護的//注對于使用的實際電話硬件,必須提供用于以下二種純虛擬功能的特定實現(xiàn) //連接到配置數(shù)據指定的線路 //自動進行可連接性檢驗,連接狀態(tài)維護 virtual void ConnectToTelephoneLine(const TTelephoneLineHandle&amp;)=0; //從當前相關的線路上斷開 //自動維護連接狀態(tài) virtual void DisconnectFromTelephoneLine()=0;//其余的受保護的請求管理具有系統(tǒng)預置的實現(xiàn) //掛鉤狀態(tài)獲取程序 virtual TToken UpdateHookStatus()const; //連接狀態(tài)獲取程序 virtual Boolean UpdateConnectionStatus()const;//獲取當前連接的電話線路的配置數(shù)據 //任何時刻,手機可連接在這些線路中的零或一條上 virtual TTelephoneLineConfigurationData*CreateLineConfigurationData()const; //為手機可以連接的所有電話線路建立配置數(shù)據對象 virtual void CreateConnectibleLineConfigurations(Tcollection&amp;) const;//受保護的音頻I/O功能//建立適當類型的揚聲器與麥克風音頻對象//注這些對象表示手機而不是它所連接的電話線路的本地音頻I/O能力virtual TSpeaker*CreateSpeaker()=0;virtual TMicrophone*CreateMicrophone()=0;//受保護的生成通知功能virtual TNotification*CreateHookNotification(const TToken&amp; hookState, TTelephoneStatusNotification∷ETelephoneStatusClassificationclassificaiton=TTelephoneStatusNotification∷kSuccess)const virtual TNotification*CreateRingNotification(const TPhoneNumber&amp;)const;//公用MCollectible替換 VersionDeclarationsMacro(TTelephoneHandset); virtual longHash()const; virtual Boolean IsEqual(const MCollectible*)const;//受保護的流送運算符只能由子類調用 virtual TStream&amp;operator<<==(TStream&amp;fromWhere); virtual TStream&amp;operator>>==(TStream&amp;toWhere);TTelephoneLineFeature]]></pre>圖25示出TTelephoneLineFeature 2500的功能。TTelephoneLineFeature為定義一組標準的高級電話線路特征的一個基本類。它定義多種形式的激活2502與釋放2504高級電話特征2510的協(xié)議,并提供判定它們的類型2506及查詢它們的狀態(tài)字段2508的方法。TTelephoneLineFeature不是多線索安全的,但是由線路以安全的方式訪問。
<pre listing-type="program-listing"><![CDATA[class TTelephoneLineFeatureprotected MRemoteDispatcher//公用解除程序 virtual~TTelephoneLineFeature();//公用訪問功能//返回特征類型描述-純虛擬功能 virtual voidGetFeatureType(TTypeDescription&amp;)const=0; //返回當前特征狀態(tài) virtual TToken UpdateStatus()const; //建立匹配控制對象 //純虛擬部件功能-必須加以替換 virtual TTelephoneLineFeatureControl*CreateFeatureControl()const=0;//受保護的構造程序 //供子類使用-系統(tǒng)預置成釋放狀態(tài) TTelephoneLineFeature(); //拷貝構造程序 TTelephoneLineFeature(const TTelephoneLineFeature&amp;);//受保護的賦值運算符 TTelephoneLineFeature&amp;operater=(const TTelephoneLineFeature&amp;);//子類接口 //多利形式激活/釋放特征//純虛擬功能-必須加以替換virtualvoid Activate()=0;virtualvoid Deactivate()=0;//公用MCollectible替換VersionDeclarationsMacro(TTelephoneLineFeature);virtual longHash()const;virtual Boolean IsEqual(const MCollectible*)const;//受保護的流送運算符只能由子類調用virtual TStream&amp;operator<<=(TStream&amp;fromWhere);virtual TStream&amp;operator>>=(TStream&amp;toWhere)const;標準TTelephoneLineFeature子類·暫時中斷并占線等候特征class TTelephoneHoldFeaturepublic TTelephoneLineFeature//解除程序 virtual~TTelephoneHoldFeature();//TTelephoneLineFeature替換 //返回標準暫時中斷并占線等候類型描述virtual void GetFeatureType(TTypeDescri ption&amp;)const;//返回標準暫時中斷并占線等候控制對象virtual TTelephoneFeatureControl*CreateFeatureControl()const;//受保護的構造程序TTelephoneHoldFeature();TTelephoneHoldFeature(const TTelephoneHoldFeature&amp;);·放棄特征class TTelephoneDropFeaturepublic TTelephoneLineFeature//公用解除程序 virtual~TTelephoneDropFeature();//TTelephoneLineFeature替換//返回標準放棄類型描述virtual void GetFeatureType(TTypeDescription&amp;)const;//返回標準放棄控制對象virtual TTelephoneFeatureControl*CreateFeatureControl()const;//受保護的構造程序TTelephoneDropFeature()TTelephoneDropFeature(const TTelephoneDropFeature&amp;);·轉接特征class TTelephoneTransferFeaturepublic TTelephoneLineFeature//解除程序 virtual~TTelephoneTransferFeature();// TTelephoneLineFeature替換 //返回標準轉接類型描述 virtual void GetFeatureType(TTypeDescription&amp;)const; //返回標準轉接控制對象 virtual TTelephoneFeatureControl*CreateFeatureControl()const;//受保護的構造程序 TTelephoneTranferFeature(); TTelephoneTransferFeature(const TTelephoneTransferFeature&amp;);·多方交談特征class TTelephoneConferenceFeaturepublic TTelephoneLineFeature//解除程序 virtual~TTelephoneConferenceFeature();//TTelephoneLineFeature替換 //返回標準多方交談類型描述 virtual void GetFeatureType(TTypeDescription&amp;)const; //返回標準多方交談控制對象 virtual TTelephoneFeatureControl*CreateFeatureControl()const;//受保護的構造程序 TTelephoneConferenceFeature(); TTelephoneConferenceFeature(const TTelephoneConferenceFeature&amp;);·轉交特征class TTelephoneForwardFeaturepublic TTelephoneLineFeature//公用解除程序 virtual~TTelephoneForwardFeature();//TTelephoneLineFeature替換 //返回標準轉交類型描述 virtual void GetFeatureType(TTypeDescription&amp;)const; //返回標準轉交控制對象 virtual TTelephoneFeatureControl*CreateFeatureControl()const;//受保護的構造程序TTelephoneForwardFeature();TTelephoneForwardFeature(const TTelephoneForwardFeature&amp;);TTelephoneLineHandle]]></pre>已在應用編寫人員接口部分中描述了本類的構造程序,解除程序,以及一些其它的成員功能。在編寫一個TTelephoneLineFeatureControl子類時,TTelephoneLineHandle所提供的下述低級控制功能可能有用。
<pre listing-type="program-listing"><![CDATA[ //將線路摘機 virtual void TakeOffHook(); //將線路掛機 virtual void PutOnHook(); //撥全部指定的電話號碼 virtual void DialNumber(const TPhoneNumber&amp;); //送出原始DTMF數(shù)字 virtual void SendDigits(const TPhoneCharacters&amp;);TTelephoneFeatureControl]]></pre>以下是用于TTelephoneFeatureControl的功能的類似的表。它們內部地用于實現(xiàn)控制的特征特定的協(xié)議。GetLineHandle返回的指針給出對其關聯(lián)的線路管理的公用成員功能的控制訪問。
<pre listing-type="program-listing"><![CDATA[ //發(fā)送激活/釋放請求到對應的特征對象 virtual void Activate()virtual void Deactivate(); //返回參照給通話的線路管理 TTelephoneLineHandle* GetLineHandle()const]]></pre>音頻考慮與公用電話網絡本身的交互作用通常是間歇的且相當慢,從而施加很少(如果有的話)嚴格的性能限制。反之,音頻數(shù)據的出現(xiàn)帶來實時要求組的標準,這些要求連同模/數(shù)與數(shù)/模轉換硬件一起工作。跟不上這些硬件的要求會引入不良的數(shù)據不連續(xù)性,其結果是不但降低語音數(shù)據的清晰性程度,并且十分難聽(甚至痛苦)。然而,這些實時要求不應損害諸如用戶接口工具等非實時處理的性能。
具體而言,錄制或播放一個聲道的音頻不會在諸如(a)選擇一個菜單項,(b)鍵入一個字符,(c)選擇一個圖形對象,或(d)一個正文范圍等標準用戶操作上提供任何感覺得到的不利影響。在下列各種情況中這應當是可能的1)從電話手機上捕捉并錄制到盤上的8KHz對數(shù)壓擴的取樣2)從電話網絡上捕捉并錄制到盤上的8KHz對數(shù)壓擴的取樣3)從盤上檢索到并播放到手機上的8KHz對數(shù)壓擴的取樣4)從盤上檢索到并播放到網絡上的8KHz對數(shù)壓擴的取樣
5)從盤上檢索到并播放到系統(tǒng)揚聲器上的8KHz對數(shù)壓擴的取樣6)從盤上檢索到并播放到手機上的22KHz線性取樣7)從盤上檢索到并播放到網絡上的228KHz線性取樣情況5至7要求具有同時壓擴到線性或線性到壓擴的轉換的取樣速率轉換。
為了使本發(fā)明與音頻對象一起操作,電話對象支持各式各樣的標準。例如,設想成目標機器支持μ律與A律格式兩者并提供轉換成和來自標準音頻格式的轉換。通過提供與音頻對象交互作用的能力,電話世界和普通聲音世界之間的邊界呈現(xiàn)為平滑與“無縫”的。有可能通過聲音服務程序來示例封裝電話線路和電話手機的音頻輸入或輸出能力的一個標準麥克風或揚聲器對象。
根據一個最佳實施例的實例以上的討論提供了可能用于電話設備接口的某些示范性對象的描述。以下提供使用以上討論的某些對象的實例。放置一次通話<pre listing-type="program-listing"><![CDATA[//建立一個新的TTelephoneHandle.//線路配置是一個TTelephoneHandsetConfigurationData對象TTelephoneLineHandle myLineHandle(lineConfiguration);//建立一個新的通話對象TPhoneNumber myNumber=TPhoneNumber(“974-0001”)TTelephoneCallHandle*myPhoneCall=myLineHandle.CreateAndPlaceCall(myNumber);//OK,離開電話的時間到了myPhoneCall.HangUp();delete myPhoneCall應答一次通話//為了示例,我們說明一個特殊的類來接收振鈴通知class TRingHandler{public TRingHandler(const TTelephoneLineHandle*);virtual ~TRingHandler();virtual void HandleRing(const TTelephoneRingNotification&amp;);privateTTelephoneLineHandle* fLineHandleTTelephoneCallHandle* fCallHandle;TMemberFunctionConnection fConnection;}//TRingHandler的定義如下TRingHandlerTRingHandler(const TTelephoneLineHandle*lineHandle) fLineHandle(lineHandle)fConnection.SetReceiver(this,(NotificationMemberFunction) &amp;TRingHandler∷ReceiveEvent); fConnection.AdoptInterest(fLineHandle->CreateRingInterest()); fConnection.Connect();}TRingHandler∷~TRingHandler(){}TRingHandler∷HandleRing(const TNotification&amp;ringNotification){ //在連接通話前,可以問誰在呼叫 TPhoneNumber callingParty; ((const TTelephoneRingNotification&amp;) theNotification).GetIncomingNumber(callingParty); //繼續(xù)及應答它 fCallHandle=fLineHandle->CreateAndAnswerCall()}暫時中斷通話處于占線等候//建立一個新的TTelephoneHandle如上TTelephoneLineHandle myLineHandle(lineConfiguration);//協(xié)商暫時中斷并占線等候特征//實際上,這將在例示線路以前用代理完成TDeque featureList;TTypeDescription holdFeatureType;TTelephoneLineFeatureControl∷GetHoldFeatureType(holdFeatureType);featureList.AddLast(&amp;holdFeatureType);TTypeDescription*featureType=myLineHandle.ChoosePreferredType(featureList);Boolean canHold=(featureType!=NIL)//建立一個新的通話對象TPhoneNumber myNumber=TPhoneNumber(“974-0001”)TTelephoneCallHandle*myPhoneCall=myLineHandle.CreateAndPlaceCall (myNumber);//OK,通話現(xiàn)在是有效的,因此暫時中斷并處于占線等候if((myPhoneCall->GetStatus()==TTelephoneStatusNotification∷ kCallActive)&amp;&amp;(canHold)){ TTelephoneFeatureControl*holdControl; holdControl=myLineHandle.CreateFeatureControl(holdFeatureType) holdControl->PutOnHold(); //他已等待太久,讓我們再與他連接 holdControl->Reconnect(myPhoneCall);}]]></pre>增加一種新的電話特征<pre listing-type="program-listing"><![CDATA[//--------------------------------------------------//TFancyFeature-說明//--------------------------------------------------class TFancyFeaturepublic TTelephoneLineFeature{public//構造程序 TFancyFeature(); TFancyFeature(const TFancyFeature&amp;);//解除程序 virtual~TFancyFeature();//賦值運算符 TFancyFeature&amp; operator=(const TFancyFeature&amp;);//TTelephoneLineFeature替換//返回新的特征類型描述virtual void GetFeatureType(TTypeDescription&amp;)const;//返回新的特征控制對象virtual TTelephoneFeatureControl*CreateFeatureControl()const;//激活特征virtual void Activate();//釋放特征virtual void Deactivate();//MCollectible替換MCollectibleDeclarationsMacro(TFancyFeature) virtual long Hash()const; virtual Boolean IsEqual(const MCollectible*)const virtual TStream&amp; operator<<=(TStream&amp;fromWhere) virtual TStream&amp; operator>>=(TStream&amp;toWhere)const}//-------------------------------------------------------//MFancyFeature-定義//-------------------------------------------------------//構造程序實現(xiàn) TFancyFeature∷TFancyFeature(){}//解除程序實現(xiàn) TFancyFeature∷~TFancyFeature(){}//返回新的特征類型描述void GetFeatureType(TTypeDescription&amp;featureType)const;{ TFancyFeatureControl∷GetFancyFeatureType(featureType);//建立新的特征控制TTelephoneFeatureControl*TFancyFeature∷CreateFeatureControl()const{ TTelephoneFeatureControl*fancyControl=new TfancyFeatureControl(); return fancyControl;}//激活特征void TFancyFeature∷Activate(){ //Do Actual Work to Activate Feature }//釋放特征void TFancyFeature∷Deactivate(){ //進行實際工作來釋放特征}//MCollectible替換MCollectibleDefinitionsMacro(TFancyFeature,0);//---------------------------------------------------------// MFancyFeatureControl-說明class TFancyFeatureControlpublic TTelephoneFeatureControl{publicstatic const void GetFancyFeatureType(TTypeDescription&amp;);//解除程序 virtual~TFancyFeatureControl();// TTelephoneLineFeatureControl替換 //返回特征類型描述 virtual void GetFeatureType(TTypeDescription&amp;)const;//客戶接口 //訪問該特征-可能需要傳遞線路或通話管理參數(shù) virtual void TurnOnFancyFeature(); viriual void TurnOffFancyFeature(); //Mcollectible替換 MCollectibleDeclarationsMacro(TFancyFeatureControl); virtual Long Hash()const; virtual Boolean IsEqual(const MCollectible*)const;protected virtual TStream&amp; operator<<=(TStream&amp;fromWhere); virtual TStream&amp; operator>>=(TStream&amp;toWhere)const;//構造程序 //被來自指定的特征的值初始化 TFancyFeatureControl(const TFancyFeatureControl&amp;);//拷貝構造程序 TFancyFeatureControl(const TFancyFeatureControl&amp;); // TFancyFeature調用的系統(tǒng)預置構造程序 TFancyFeatureControl(); //賦值運算符 TFancyFeatureControl&amp;operator=(const TFancyFeatureControl&amp;);//只有一個TFancyFeature能構造該類 friend class TFancyFeature;};//----------------------------------------------------------// TFancyFeatureControl-定義//----------------------------------------------------------const void TTelephoneLineFeatureControl∷GetFancyFeatureType (TTypeDescription&amp;featureType){ static const TTypeDescription fancyType(“BrandXFancyFeature”); featureType=fancyType;}//解除程序TFancyFeatureControl∷~TFancyFeatureControl(){}//返回特征類型描述void TFancyFeatureControl∷GetFeatureType(TTypeDescription&amp;featureType) const{ GetFancyFeatureType(featureType);//客戶接口void TFancyFeatureControl∷TurnOnFancyFeature() Activate();}void TFancyFeatureControl∷TurnOffFancyFeature() Deactivate();}//MCollectible替換MCollectibleDefinitionsMacro(TFancyFeatureControl,0);//構造程序//用來自指定特征的值初始化TFancyFeatureControl∷TFancyFeatureControl(const TFancyFeature&amp; theFeature)∷TTelephoneLineFeatureControl(theFeature){}//拷貝構造程序TFancyFeatureControl∷TFancyFeatureControl(const TFancyFeatureControl&amp; source) TTelephoneLineFeatureControl(source){}//只為流送與賦值調用系統(tǒng)預置構造程序TFancyFeatureControl∷TFancyFeatureControl()TTel ephoneLi neFeatureControl(){}//賦值運算符TFancyFeatureControl&amp; TFancyFeatureControl∷operator=( const TFancyFeatureControl&amp;source){ //無自我賦值 if(&amp;source?。絫his){ TTelephoneFeatureControloperator=(source); } return*this;}]]></pre>預定義的電話常數(shù)名稱 意義電話通知所關心的事物名TTelephoneInterest∷kHookStatus 掛鉤狀態(tài)更新TTelephoneCallInterest∷kCallStatus 通話狀態(tài)更新TTelephoneFeatureInterest∷kFeatureStatus 特征狀態(tài)更新TTelephoneInterest∷kRingNotification 進入通話通知TTelephoneInterest∷kDigitsReceived 進入DTMF通知電話線路狀態(tài)TTelephoneStatusNotification∷kOnHook 線路是掛機的TTelephoneStatusNotification∷kOffHook線路是摘機的電話通話狀態(tài)TTelephoneStatusNotification∷kCallIdle 系統(tǒng)預置狀態(tài)TTelephoneStatusNotification∷kIncompleteCallInfo 放置通話需要更多信息TTelephoneStatusNotification∷kCallReorder 通話放置不能進行TTelephoneStatusNotification∷kCallCannotComplete 測到特殊服務信息音調TTelephoneStatusNotification∷kReadyToDial 存在撥號音TTelephoneStatusNotification∷kFastBusy撥號音時間過完TTelephoneStatusNotification∷kDialingComplete 完成撥出TTelephoneStatusNotification∷kRingbackDetected遠程連接正在“振鈴”TTelephoneStatusNotification∷kBusyDetected收到忙音,遠程電話忙TTelephoneStatusNotification∷kNoAnswer遠程電話未應答TTelephoneStatusNotification∷kCallActive 通話已成功連接TTelephoneStatusNotification∷kCallOnHold 通話已被暫時中斷并處于占線等候TTelephoneStatusNotification∷kCallTerminationDetected 另一方已終止電話特征狀態(tài)TTelephoneStatusNotification∷kActivateInProgress 確認特征激活請求TTelephoneStatusNotification∷kActivateComplete現(xiàn)在激活特征TTelephoneStatusNotification∷kCannotActivate 不能激活特征TTelephoneStatusNotification∷kDeactivate 正在進行特征釋放請求確認TTelephoneStatusNotification∷kDeactivateComplete 現(xiàn)在釋放特征TTelephoneStatusNotification∷kCannotDeactivate不能釋放特征通用錯誤狀態(tài)TTelephoneStatusNotification∷kErrorState 不好或未定義的狀態(tài)基本電話通話狀態(tài)機以下提供利用上面討論的某些對象的一種通話狀態(tài)機的實現(xiàn)。起始狀態(tài)kCallIdle[Outbound Call]動作TTelephoneLineHandle∷TakeOffHook結束狀態(tài)kReadyToDial起始狀態(tài)kCallIdle[Incoming Call]動作TTelephoneLineHandle∷TakeOffHook結束狀態(tài)kCallActive起始狀態(tài)kReadyToDial事件kFastBusyDetected 結束狀態(tài)kFastBusyDetected動作TTelephoneLineHandle∷SendDigits結束狀態(tài)kDialingComplete動作TTelephoneLineHandle∷SendDigits結束狀態(tài)kIncompleteCallInfo動作TTelephoneLineHandle∷SendDigits結束狀態(tài)kCallReorder動作TTelephoneCallHandle∷HangUp結束狀態(tài)kCallIdle起始狀態(tài)kFastBusyDetected動作TTelephoneCallHandle∷HangUp結束狀態(tài)kCallIdle起始狀態(tài)kDialingComplete事件kRingbackDetected 結束狀態(tài)kRingbackDetec事件kBusyDetected 結束狀態(tài)kBusyDetected事件kCallCannotComplete 結束狀態(tài)kCallCannotComplete動作TTelephoneCallHandle∷HangUp結束狀態(tài)kCallIdle起始狀態(tài)kIncompleteCallInfo動作TTelephoneCallHandle∷HangUp結束狀態(tài)kCallIdle起始狀態(tài)kCallReorder動作TTelephoneCallHandle∷HangUp結束狀態(tài)kCallIdle起始狀態(tài)kRingbackDectected事件kCallActive 結束狀態(tài)kCalIActive
事件kNoAnswer 結束狀態(tài)kNoAnswer動作TTelephoneCallHandle∷HangUp 結束狀態(tài)kCallIdle起始狀態(tài)kBusyDetected動作TTelephoneCallHandle∷HangUp 結束狀態(tài)kCallIdle起始狀態(tài)kCallCannotComplete動作TTelephoneCallHandle∷HangUp 結束狀態(tài)kCallldle起始狀態(tài)TTelephoneLine∷kCallActive事件kCallIdle結束狀態(tài)kCallIdle動作TTelephoneCallHandle∷HangUp 結束狀態(tài)kCallIdle起始狀態(tài)TTelephoneLine∷kNoAnswer動作TTelephoneCallHandle∷HangUp 結束狀態(tài)kCallIdle雖然已經以特定系統(tǒng)環(huán)境中的最佳實施例描述了本發(fā)明,熟悉本技術的人員應能認識到在所附的權利要求書的精神與范圍內的其它與不同的硬件與軟件環(huán)境中可通過修改上述實施例來實踐本發(fā)明。
權利要求
1.一種電話裝置,包括(a)一個處理器;(b)一個連接在所述處理器上并受其控制的存儲器;(c)一個常駐在所述存儲器中并控制所述處理器的操作的面向對象的操作系統(tǒng);(d)一個與所述面向對象的操作系統(tǒng)控制下的處理器相連的顯示器;(e)一個連接在所述處理器上的電話部件;(f)一個存儲在所述存儲器中并顯示在所述顯示器上的電話對象,所述電話對象表示在所述面向對象的操作系統(tǒng)控制下的電話部件;以及(g)用于由面向對象的操作系統(tǒng)利用所述電話對象控制所述電話部件的裝置。
2.根據權利要求1所述的電話裝置,還包括用于將從所述電話部件接收的信息翻譯成所述面向對象的操作系統(tǒng)能夠利用的信息的裝置。
3.根據權利要求1所述的電話裝置,還包括用于將從所述電話對象接收的信息翻譯成所述電話部件能夠利用的信息的裝置。
4.根據權利要求1所述的電話裝置,其中,所述電話對象包括與電話對象相關聯(lián)的一種方法及數(shù)據。
5.根據權利要求1所述的電話裝置,還包括用于將所述電話部件連接在所述處理器上的裝置。
6.根據權利要求5所述的電話裝置,還包括用于將一條電話線路連接在所述處理器上的裝置。
7.根據權利要求5所述的電話裝置,還包括用于將一個手機連接在所述處理器上的裝置。
8.根據權利要求5所述的電話裝置,還包括用于建立對所述處理器的一次通話的裝置。
9.根據權利要求1所述的電話裝置,還包括通過所述電話對象啟動所述電話部件的特征的裝置。
10.根據權利要求5所述的電話裝置,還包括用于在所述電話部件與所述處理器之間傳遞信息的裝置。
11.根據權利要求10所述的電話裝置,還包括用于在所述電話部件與所述處理器之間交換DTMF音調的裝置。
12.根據權利要求1所述的電話裝置,還包括用于在一個電話部件與所述面向對象的操作系統(tǒng)之間為查詢服務的裝置。
13.根據權利要求1所述的電話裝置,還包括用于在一個電話部件與所述面向對象的操作系統(tǒng)之間交換通知信息的裝置。
14.一種用于在一個計算機系統(tǒng)上啟動電話部件的方法,包括帶有一個連接的存儲器,顯示器,與電話部件的一個處理器,包括(a)用常駐在所述存儲器中的一個面向對象的操作系統(tǒng)控制所述處理器的操作;(b)建立一個存儲在所述存儲器中并顯示在所述顯示器上的電話對象,所述電話對象代表在所述面向對象的操作系統(tǒng)的控制下的電話部件;以及(c)由所述面向對象的操作系統(tǒng)利用所述電話對象控制所述電話部件。
15.根據權利要求14所述的方法,還包括將從電話部件接收的信息翻譯成所述面向對象的操作系統(tǒng)能夠利用的信息的步驟。
16.根據權利要求14所述的方法,還包括將從所述電話對象接收的信息翻譯成所述電話部件能夠利用的信息的步驟。
17.根據權利要求14所述的方法,其中,所述電話對象包括與所述電話對象相關聯(lián)的一種方法與數(shù)據。
18.根據權利要求14所述的方法,還包括將所述電話部件連接在所述處理器上的步驟。
19.根據權利要求18所述的方法,還包括將一條電話線路連接在所述處理器上的步驟。
20.根據權利要求18所述的方法,還包括將一個手機連接在所述處理器上的步驟。
21.根據權利要求18所述的方法,還包括建立一個對所述處理器的通話的步驟。
22.根據權利要求14所述的方法,還包括通過所述電話對象啟動所述電話部件的特征的步驟。
23.根據權利要求18所述的方法,包括在所述電話部件與所述處理器之間傳遞信息的步驟。
24.根據權利要求23所述的方法,包括在所述電話部件與所述處理器之間交換DTMF音調的步驟。
25.根據權利要求14所述的方法,包括在一個電話部件與所述面向對象的操作系統(tǒng)之間交換狀態(tài)信息的步驟。
26.根據權利要求14所述的方法,包括在一個電話部件與所述面向對象的操作系統(tǒng)之間交換通知信息的步驟。
全文摘要
一種用于啟動一組對象接口應用部件和電話系統(tǒng)部件的方法和系統(tǒng)。根據將接口的電話系統(tǒng)的部件,可選擇特定的對象。一個特定的對象可與電話系統(tǒng)的一個或多個部件接口。電話系統(tǒng)的部件可以是該電話系統(tǒng)的任何可標識的方面。例如,對象可表示一個手機或一條線路,也可表示無形的部件,例如,信號或過程,包含通話進行音調,通話建立,通話暫時中斷處于占線等候,多方交談,或其他通話特征。
文檔編號H04M11/00GK1133662SQ94193863
公開日1996年10月16日 申請日期1994年1月6日 優(yōu)先權日1993年10月26日
發(fā)明者邁可爾·羅素·丟辭, 史蒂文·H·米而恩, 大衛(wèi)·B·哥德斯密 申請人:塔里根特公司
網友詢問留言 已有0條留言
  • 還沒有人留言評論。精彩留言會獲得點贊!
1
阿巴嘎旗| 高邮市| 普兰店市| 满城县| 淳化县| 谷城县| 阳江市| 镇平县| 丰原市| 随州市| 西林县| 息烽县| 玛沁县| 攀枝花市| 奈曼旗| 昌江| 泸西县| 商城县| 卢龙县| 镇坪县| 广饶县| 若尔盖县| 阿鲁科尔沁旗| 磴口县| 酒泉市| 绍兴市| 上高县| 桐城市| 东辽县| 新野县| 香格里拉县| 垦利县| 紫云| 富阳市| 隆尧县| 丰县| 翁源县| 长岛县| 贵南县| 江都市| 杂多县|