專利名稱:用于動態(tài)生成用戶界面的方法和系統(tǒng)的制作方法
技術(shù)領(lǐng)域:
本發(fā)明涉及一種用于為應(yīng)用程序生成用戶界面的方法和系統(tǒng),其中該用戶界面在至少一個(gè)目標(biāo)系統(tǒng)上運(yùn)行,并且可以包括多個(gè)顯示器。
背景技術(shù):
在現(xiàn)有技術(shù)的早期系統(tǒng)中,用戶界面的實(shí)現(xiàn)是作為各應(yīng)用程序代碼的組成部分。但是這導(dǎo)致在更改或更新代碼時(shí)還必須一起更改用戶界面。這增加了編程和維護(hù)的開銷。
為避免該缺陷,目前主要采用網(wǎng)頁瀏覽器和標(biāo)記語言即超文本標(biāo)記語言(HTML),從而能生成至少最大限度獨(dú)立于目標(biāo)系統(tǒng)參數(shù)的用戶界面,該目標(biāo)系統(tǒng)的參數(shù)例如是分辨率或所采用的平臺。作為HTML基礎(chǔ)的機(jī)制是通過所謂的標(biāo)簽預(yù)先給定應(yīng)當(dāng)如何表示一個(gè)應(yīng)用程序(例如WWW瀏覽器)的文檔的特定部分。但是根據(jù)現(xiàn)有技術(shù)的基于HTML的方法需要較高的編程代價(jià),因?yàn)閺亩喾矫鎭碚fHTML是有限的。
因此,必須由瀏覽器來解釋基于HTML的應(yīng)用,而瀏覽器一般不是用于實(shí)施應(yīng)用的。這導(dǎo)致處理時(shí)間很長。此外,基于HTML來生成用戶界面要求,必須應(yīng)新用戶的變化的需要而利用界面的其它參數(shù),如另一種分辨率來為該新用戶改寫同一應(yīng)用程序。
而且?guī)缀醪豢赡苌煽稍趹?yīng)用程序運(yùn)行時(shí)動態(tài)更改的用戶界面,或者只能在極高的代價(jià)和錯(cuò)誤率下生成這種用戶界面。
因此目前的方法存在一些缺陷。
發(fā)明內(nèi)容
因此本發(fā)明要解決的技術(shù)問題在于,提供一種方法,可以用來不依賴分辨率和平臺地生成用戶界面,同時(shí)還可以動態(tài)更改和遠(yuǎn)程配置用戶界面。
特別的,該技術(shù)問題是通過一種用于在至少一個(gè)目標(biāo)系統(tǒng)上為一應(yīng)用程序生成多顯示器用戶界面的方法來解決的,該方法訪問配置文件,其中該配置文件至少描述了待生成用戶界面的布局的組件,尤其是可視化組件,并且通過讀入和/或解釋該配置文件來生成所述用戶界面,其中用戶界面的生成在數(shù)據(jù)技術(shù)上是與目標(biāo)系統(tǒng)和/或所述應(yīng)用無關(guān)的,并且還可以在所述應(yīng)用的運(yùn)行時(shí)配置所生成的用戶界面。
此外,該技術(shù)問題還通過一種開始所述類型的系統(tǒng)解決的,尤其是通過一種用于在至少一個(gè)目標(biāo)系統(tǒng)上為一應(yīng)用生成多顯示器用戶界面的系統(tǒng),該系統(tǒng)具有 -至少一個(gè)配置文件,該配置文件至少描述了待生成用戶界面的布局的組件,尤其是可視化組件, -至少一個(gè)具有多顯示器功能的布局引擎,該引擎讀入、解釋該配置文件和/或生成所述用戶界面,其中所述布局引擎在數(shù)據(jù)技術(shù)上是與目標(biāo)系統(tǒng)和/或所述應(yīng)用沒有聯(lián)系的。
本發(fā)明的一個(gè)重要概念建立在這樣的基礎(chǔ)上,即中央機(jī)制,也就是所謂的布局引擎,是基于對可視化組件和涉及事件的組件的分配。換句話說就是在下列任務(wù)之間進(jìn)行區(qū)分 要求定義應(yīng)當(dāng)如何顯示一個(gè)對象的任務(wù),和 要求定義一個(gè)對象應(yīng)當(dāng)具有哪些意義或哪些內(nèi)容的任務(wù)。
根據(jù)本發(fā)明,一般地提供了用于確定用戶界面的基本機(jī)制,并且該基本機(jī)制可以用于任何應(yīng)用,因?yàn)檫@些基本機(jī)制作為模塊化的組成部分是與各特定應(yīng)用沒有聯(lián)系的。
在優(yōu)選基于XML的配置文件的基礎(chǔ)上,布局引擎自動或至少半自動地、借助附加輸入和/或用戶命令為各應(yīng)用生成界面。
這優(yōu)選響應(yīng)該應(yīng)用的詢問來進(jìn)行,也就是說用戶界面的生成是在用戶觸發(fā)下進(jìn)行的。
在本發(fā)明的優(yōu)選擴(kuò)展中,所述配制文件是由本發(fā)明系統(tǒng)或方法的組件在內(nèi)部生成的,而在該優(yōu)選的實(shí)施方式中只對外部生成的配置文件進(jìn)行訪問,并提供合適的界面。
布局引擎沒有定義和包含應(yīng)用語義或?qū)嵤┠P?。因此根?jù)本發(fā)明,封裝了用于生成用戶界面的邏輯,并且總的來說可以不依賴各應(yīng)用情況地采用該邏輯。
通過本發(fā)明解決方案的模塊化體系結(jié)構(gòu),配置文件、布局引擎和/或應(yīng)用邏輯可以駐留在基于服務(wù)器的資源上。
此外,在其上生成或運(yùn)行用戶界面的目標(biāo)系統(tǒng)可以設(shè)置在不同于所述應(yīng)用自身的另一位置。
在本發(fā)明的優(yōu)選擴(kuò)展中,通過SOAP協(xié)議向網(wǎng)頁服務(wù)傳遞由布局引擎生成的用戶界面控制。SOAP協(xié)議(簡單對象存取協(xié)議)是一種用于在分散的分布式環(huán)境中交換信息的協(xié)議,并且該協(xié)議因此適合于在本發(fā)明的模塊之間交換信息。
布局引擎優(yōu)選通過HTTP協(xié)議加載XML文件。但在這兩種情況下都可以采用特殊定義的協(xié)議。
優(yōu)選的,根據(jù)本發(fā)明生成的用戶界面是不依賴于目標(biāo)系統(tǒng)的分辨率和/或平臺而生成的,和/或配置文件是不依賴于用戶界面的程序庫而生成的。
在本發(fā)明的另一種優(yōu)選結(jié)構(gòu)中,自動生成配置文件和/或用戶界面。
此外優(yōu)選的是,還可以遠(yuǎn)程配置用戶界面,這提高了系統(tǒng)的靈活度。
在本發(fā)明的另一優(yōu)選擴(kuò)展中,配置文件包括映射規(guī)則,這些規(guī)則將一個(gè)控制事件分別對應(yīng)一個(gè)同樣可配置的事件處理程序,其中該映射只是一般性的,并且不依賴于所述應(yīng)用和/或目標(biāo)系統(tǒng)。
在此,事件處理程序一方面可以在客戶機(jī)上本地執(zhí)行,另一方面可以在服務(wù)器上遠(yuǎn)程執(zhí)行。
本發(fā)明的優(yōu)選實(shí)施方式建立在這樣的基礎(chǔ)上,即通過多個(gè)控制字段、尤其是控制(Control)來定義用戶界面,其中本方法分為下列步驟 -創(chuàng)建控制字段, -定位該控制字段,和 -向可配置的控制處理程序傳遞該控制字段。
本發(fā)明方法的上述實(shí)施方式還可以構(gòu)成計(jì)算機(jī)程序產(chǎn)品,具有計(jì)算機(jī)可讀介質(zhì)和計(jì)算機(jī)程序代碼裝置,并且在該計(jì)算機(jī)程序產(chǎn)品中,在加載了計(jì)算機(jī)程序之后促使計(jì)算機(jī)執(zhí)行本發(fā)明的上述方法。
另一可選解決技術(shù)問題的方案是一種存儲介質(zhì),該介質(zhì)用于存儲上述可用計(jì)算機(jī)實(shí)施的方法,并且可由計(jì)算機(jī)讀出。
在下面對附圖的詳細(xì)描述中,利用實(shí)施例的特征和其它優(yōu)點(diǎn)說明了非受限理解的實(shí)施例,該附圖描述應(yīng)當(dāng)與附圖聯(lián)系起來閱讀。在圖中示出了 圖1示出了根據(jù)本發(fā)明的體系結(jié)構(gòu)的示意性圖, 圖2示出了本發(fā)明優(yōu)選實(shí)施例的流程圖。
具體實(shí)施例方式 對于應(yīng)用程序A應(yīng)當(dāng)生成用戶界面UI。該用戶界面UI應(yīng)當(dāng)在目標(biāo)系統(tǒng)Z上運(yùn)行,該目標(biāo)系統(tǒng)Z不需要與運(yùn)行應(yīng)用程序A的系統(tǒng)一致。根據(jù)本發(fā)明,這在訪問布局引擎LE的條件下進(jìn)行,該布局引擎LE是模塊化構(gòu)建的,并且其功能在應(yīng)用程序A與目標(biāo)系統(tǒng)Z上生成的用戶界面UI之間。
如圖1所示,根據(jù)本發(fā)明,從應(yīng)用程序A出發(fā)生成XML配置文件10。配置文件10不依賴于UI庫地描述待生成的界面UI的布局。由此,根據(jù)本發(fā)明獲得了在目前現(xiàn)有技術(shù)的方法中不可能達(dá)到的自由度。這意味著,根據(jù)本發(fā)明生成的用戶界面UI提供了例如不同于1280×1024分辨率的1024×786屏幕分辨率的布局。還可以引入變量,例如2個(gè)或更多新按鈕控制12。如果存在多個(gè)布局區(qū)域(Layout Area),則可以在配置文件中定義多個(gè)布局說明。因此,多個(gè)布局說明允許布局引擎LE既不依賴分辨率又能實(shí)現(xiàn)動態(tài)改變布局。
下面結(jié)合圖2說明本發(fā)明優(yōu)選實(shí)施方式的運(yùn)行 在此,布局引擎LE應(yīng)要求讀入XML配置文件10??蛇x的,還可以按照可預(yù)先確定的時(shí)間間隔來檢查配置文件10的當(dāng)前性,并自動將該配置文件10傳遞到布局引擎LE。
在讀入配置文件10之后,由布局引擎了LE來解釋該配置文件10。在此,布局引擎LE訪問同樣存放在配置文件10中的映射。
由此,布局引擎LE可以動態(tài)地生成一個(gè)布局,并對該映射進(jìn)行訪問,或進(jìn)行事件連接。
所述映射包括一系列規(guī)則,根據(jù)這些規(guī)則將控制事件對應(yīng)于事件處理程序14??梢詫⒖刂?2定義為用于生成用戶界面UI的控制字段。本發(fā)明的一個(gè)特別的優(yōu)點(diǎn)在于,即使在應(yīng)用程序A運(yùn)行時(shí)也可以向已存在的控制添加新的控制12。由此,可以動態(tài)更改和/或配置根據(jù)本發(fā)明生成的界面UI。
根據(jù)本發(fā)明的方法,可以處理任意類型的控制12,而在根據(jù)現(xiàn)有技術(shù)的基于HTML的方法中,只能有限地使用控制Control(或者包括有限的功能,或者必須以相對高的代價(jià)復(fù)制該控制Control,例如樹視圖控制TreeViewControl)。
XML配置文件可以放在萬維網(wǎng)服務(wù)器上。由此可有利地極大簡化界面UI的安裝。甚至還可以完全配置事件處理程序14,因此事件處理程序14由可執(zhí)行或可加載的代碼組成。然后,根據(jù)本發(fā)明不必在客戶機(jī)或目標(biāo)系統(tǒng)Z上實(shí)施安裝過程。這顯著提高了系統(tǒng)的可操作性。
XML配置文件10除了特定于應(yīng)用程序的數(shù)據(jù)之外還包括涉及界面的控制事件至腳本事件處理程序14(這些腳本事件處理程序可以例如用Javascript或Perl編寫)的映射(或連接),或例如直接至網(wǎng)頁服務(wù)的映射(連接)。由此根據(jù)本發(fā)明,用戶界面UI的邏輯完全包含在XML配置文件10中,而迄今為止一般是必須對該邏輯編程的(在訪問UI庫的條件下或在網(wǎng)頁應(yīng)用服務(wù)器中通過ASP.NET/或JSP)。
待編程的事件處理程序14用作封裝的模塊,并且完全與用戶界面UI的布局分離。此外,還可以不依賴于平臺地實(shí)現(xiàn)事件處理程序14,因?yàn)檫@些事件處理程序優(yōu)選只與布局引擎LE的模塊通信。如果UI事件直接連接到一個(gè)或多個(gè)網(wǎng)頁服務(wù)(或者其他服務(wù)),則根據(jù)本發(fā)明不必再編程。
下面舉出XML配置文件10的例子 <UI><Layouts><Layout name=“1024×786”default=“”><Areas><!--Man kann verschiedene Areas definieren in denen die Controls plaziertwarden--><Area name=“area1“x=“0”y=“0”w=“100”h=“100”/><Area name=“area1“x=“101”y=“0”w=“100”h=“400”/></Areas><Controls><!--controls referenzieren eine Area die Koordinaten der Controls sindrelativ zurArea--><Control area=“area1”name=“Button1”type=“Button”x=“10”y=“10”<!-- SIPO <DP n="5"> --><dp n="d5"/>w=“40”h=“20”><!--beliebige Properties des Controls knnen definiert werden--><Property name=“color”value=“red”/></Control><Control area=“area2”name=“Button2”type=“Button”x=“40”y=“10”w=“40”h=“20”/></Controls></Layout><!--ein altematives 2.Layout--><Layout name=“800×600”><Areas><Area name=“area1”x=“0”y=“0”w=“100”h=“100”/></Areas><Controls><Control area=“area1”name=“Button1”type=“Button”x=“10”</Controls></Layout><EventHandlers><!--Ein Event Handler.der an einen WebService verdrahtet ist--><Handler name=“Handler1”type=“WebService”><!--$1 ist ein Platzhalter,der dem ersten Parameter in der<map>definition entspricht--><connectionuri=“https//www.myserve r.corn/services/buttonclick.aspx?click=$1”/></Handler><!--Ein Event Handler,der inline Skript code enthlt--><Handler name=“Handler2”type=“Script”><script type=“inline”><!-- SIPO <DP n="6"> --><dp n="d6"/><!--die bergabeparameter der Handler entsprechen den Parametern in der<map>definition--><code>function foo(id){alert(“you clicked me!”+id);}</code></script></Handler></EventHandlers><EventMapping><!--Verdrahtet das Button1“Click”Event mit Handler1 und bergibtdiesem Handler als Parameter die Property id des controls--><map name=“EventMap1”control=“Button1”event=“Click”han-dler=“Handler1”entry=“”><param value=“control.id”/></map><!--Verdrahtet das Button2“Click”Event mit Handler2 ruft dessenFunktion foo auf und bergibt den Parameter--><map name=“EventMap2”control=“Button2”event=“Click”handler=“Handler2”entry=“foo”><param value=“control.id”/></map></EventMapping></UI> 下面示例性給出根據(jù)本發(fā)明的“.Net Windows Forms”(縮寫為WinForms)的步驟 //省略XML語法分析//為XML配置中定義的、WinForm形式的區(qū)域和控制產(chǎn)生Control,//并將Form(myForm)添加到主程序Main中Areas[]theAreas=getAreas(xmlData);foreach(Area area in theAreas){<!-- SIPO <DP n="7"> --><dp n="d7"/>Panel aPanel=new Panel();setPanelProperties(aPanel,area);//設(shè)置面板坐標(biāo)和其它定義區(qū)域的特性myForm.Controls.Add(aPanel);//將面板添加到Form中XMLConfigControl[]theControls=getConttolsForArea(area);foreach(XMLConfigControl control in theControls){Control aControl=ControlFactory.createControl(control);//產(chǎn)生正確的//Control類型setControlProperties(aControl,control);//設(shè)置坐標(biāo)和必要時(shí)定義的//Control的特性apanel.Controls.Add(aControl);}...//產(chǎn)生事件處理程序...//為腳本事件處理程序的每個(gè)函數(shù)返回一個(gè)單獨(dú)的EventHandlerEventHandler[]theEventHandlers=getEventHandler(xmlData);foreach(EventHandler evtHandler in theEventHandlers){Delegate aDelegate=null;if(evtHandler.type==EyentHandlerTypes.WEBSERVICE){aDelegate=createWebserviceDelegate(evtHandler,evtHandler.params);}else if(evtHandler.type==EventHandlerTypes.SCRIPT){aDelegate=createScriptDelegate(evtHandler,evtHandler.params);}addToEventHandlerCollection(aDelegate,evtHandler.name);}...//將控制事件和事件處理程序連接...EventMapping[]theEventMappings=getEventMappings(xmlData);foreach(EventMapping evtMap in theEventMappings){<!-- SIPO <DP n="8"> --><dp n="d8"/>Control aControl=findControl(evtMap.control);EventInfo theEvent=getEvent(aControl,evtMap.event);Delegate aDelegate=findEventDelegate(evtMap.handler,evtMap.entry);//Control事件的參數(shù)不必與配置的事件處理程序的參數(shù)一致,因此事//件參數(shù)必須轉(zhuǎn)換為處理程序Delegate期望的參數(shù)Delegate aEvtDelegate=createTransformnEvtDelegate(aDelegate,evtMap.params,theEvent);theEvent.AddEventHandler(aControl,aEvtDelegate);}...
權(quán)利要求
1.一種用于在至少一個(gè)目標(biāo)系統(tǒng)上為一應(yīng)用程序(A)生成多顯示器用戶界面(UI)的方法,其中,該方法通過讀入和/或解釋一配置文件(10)來訪問該配置文件(10),所述配置文件(10)至少描述待生成用戶界面的布局的組件,尤其是可視化組件,其中所述用戶界面(UI)的生成在數(shù)據(jù)技術(shù)上是與目標(biāo)系統(tǒng)(Z)和/或所述應(yīng)用程序(A)無關(guān)的。
2.根據(jù)權(quán)利要求1所述的方法,其特征在于,所生成的用戶界面(UI)在所述應(yīng)用程序(A)的運(yùn)行時(shí)也可以被動態(tài)配置。
3.根據(jù)權(quán)利要求1或2所述的方法,其特征在于,所述用戶界面(UI)不依賴于目標(biāo)系統(tǒng)(Z)的分辨率和/或平臺而生成。
4.根據(jù)上述權(quán)利要求之一所述的方法,其特征在于,所述配置文件(10)不依賴于用戶界面的程序庫而生成。
5.根據(jù)上述權(quán)利要求之一所述的方法,其特征在于,所述配置文件(10)是基于XML協(xié)議的。
6.根據(jù)上述權(quán)利要求之一所述的方法,其特征在于,所述配置文件(10)和/或所述用戶界面(UI)是自動生成的。
7.根據(jù)上述權(quán)利要求之一所述的方法,其特征在于,所述配置文件(10)不是放置在所述目標(biāo)系統(tǒng)(Z)中,而是特別放置在萬維網(wǎng)服務(wù)器中。
8.根據(jù)上述權(quán)利要求之一所述的方法,其特征在于,所述用戶界面(UI)還可以被遠(yuǎn)程配置。
9.根據(jù)上述權(quán)利要求之一所述的方法,其特征在于,所述配置文件(10)包括將控制事件與同樣可配置的事件處理程序(14)相對應(yīng)的映射,其中,所述映射只是一般性的,并且不依賴于所述應(yīng)用程序(A)和/或目標(biāo)系統(tǒng)(Z)。
10.根據(jù)權(quán)利要求9所述的方法,其特征在于,所述事件處理程序(14)可以在客戶機(jī)上本地執(zhí)行,也可以在服務(wù)器上遠(yuǎn)程執(zhí)行。
11.根據(jù)上述權(quán)利要求之一所述的方法,其特征在于,所述用戶界面(UI)通過多個(gè)控制字段,尤其是控制(12)來定義,其中所述方法分為下列步驟
-創(chuàng)建所述控制字段,
-定位該控制字段,和
-向可配置的控制處理程序(14)傳遞該控制字段。
12.一種用于在至少一個(gè)目標(biāo)系統(tǒng)(Z)上為應(yīng)用程序(A)生成多顯示器用戶界面(UI)的系統(tǒng),該系統(tǒng)具有
-至少一個(gè)配置文件(10),該配置文件至少描述待生成用戶界面(UI)的布局的組件,尤其是可視化組件,
-至少一個(gè)具有多顯示器功能的布局引擎(LE),該引擎讀入、解釋該配置文件(10)和/或生成所述用戶界面(UI),其中所述布局引擎(LE)在數(shù)據(jù)技術(shù)上是與所述應(yīng)用(A)和/或目標(biāo)系統(tǒng)(Z)無關(guān)的。
13.根據(jù)權(quán)利要求12所述的系統(tǒng),其特征在于,所述用戶界面(UI)不依賴于目標(biāo)系統(tǒng)(Z)的分辨率和/或平臺而生成。
14.根據(jù)權(quán)利要求12或13所述的系統(tǒng),其特征在于,所述配置文件(10)不依賴于用戶界面的程序庫而生成。
15.根據(jù)權(quán)利要求12至14中任一項(xiàng)所述的系統(tǒng),其特征在于,所述配置文件(10)是基于XML協(xié)議的。
16.根據(jù)權(quán)利要求12至15中任一項(xiàng)所述的系統(tǒng),其特征在于,所述配置文件(10)和/或所述用戶界面(UI)是自動生成的。
17.根據(jù)權(quán)利要求12至16中任一項(xiàng)所述的系統(tǒng),其特征在于,所述配置文件(10)不是放置在所述目標(biāo)系統(tǒng)(Z)中,而是特別放置在萬維網(wǎng)服務(wù)器中。
18.根據(jù)權(quán)利要求12至17中任一項(xiàng)所述的系統(tǒng),其特征在于,所述用戶界面(UI)還可以被遠(yuǎn)程配置。
19.根據(jù)權(quán)利要求12至18中任一項(xiàng)所述的方法,其特征在于,所述配置文件(10)包括將控制事件與同樣可配置的事件處理程序(14)相對應(yīng)的映射,其中所述映射只是一般性的,并且不依賴于所述應(yīng)用程序(A)和/或目標(biāo)系統(tǒng)(Z)。
20.根據(jù)權(quán)利要求19所述的系統(tǒng),其特征在于,所述事件處理程序(14)可以在客戶機(jī)上本地執(zhí)行,也可以在服務(wù)器上遠(yuǎn)程執(zhí)行。
21.根據(jù)權(quán)利要求12至20中任一項(xiàng)所述的系統(tǒng),其特征在于,定義多個(gè)控制字段,尤其是控制(12),其中該方法分為下列步驟
-創(chuàng)建所述控制字段,
-定位該控制字段,和
-向可配置的控制處理程序(14)傳遞該控制字段。
全文摘要
本發(fā)明涉及一種用于為用戶(A)動態(tài)地、不依賴于分辨率和平臺地生成用戶界面(UI)的方法和系統(tǒng)。其中讀入和解釋配置文件(10)。在訪問分別將一個(gè)控制事件與一個(gè)事件處理程序(14)對應(yīng)的映射的條件下,布局引擎(LE)生成用戶界面(UI)。
文檔編號G06F9/44GK1614557SQ200410089780
公開日2005年5月11日 申請日期2004年11月4日 優(yōu)先權(quán)日2003年11月4日
發(fā)明者卡爾海因茨·多恩, 克里斯琴·沙夫, 邁克爾·施尼茨克, 漢斯-馬丁·馮斯托克豪森 申請人:西門子公司