深入探討WPF UI自動化模型
我們在這里將會為初學WPF的朋友帶來有關WPF UI自動化模型的一些概念介紹。希望大家可以通過本文介紹的基礎知識,充分掌握這一技術。#t#
現(xiàn)有技術下實現(xiàn)UI自動化測試系統(tǒng)開發(fā)需要通過不同方法獲得和展現(xiàn)UI元素信息,開發(fā)人員需要花費大量的時間和精力去搜集這些必需的UI元素信息,而不能集中精力于系統(tǒng)特征和功能的實現(xiàn)上。
借助于WPF UI自動化模型所提供的統(tǒng)一的控制模式,通過其等價的名字屬性 (NameProperty) 就可以輕松實現(xiàn)對不同UI元素的統(tǒng)一控制。UI自動化技術減少了此類應用系統(tǒng)的開發(fā)成本,將成為下一代輔助訪問技術產品和自動化測試系統(tǒng)主要的界面信息資源提供者。
UI自動化包括兩部分。UI自動化服務提供者 (UI Automation Providers) 和UI自動化客戶程序 (UI Automation Clients) 。UI自動化服務提供者是提供UI自動化服務的應用程序,比如Word, Excel及其它基于Windows的應用程序 等,為用戶通過輔助程序技術對其訪問提供支持。UI自動化客戶端程序是實現(xiàn)用戶界面自動化訪問的輔助技術程序,比如Word和Excel中供應用程序訪問的對象模型及其宏腳本等。
相應的,對開發(fā)人員來說,可以通過調用UI自動化提供者應用程序接口(UI Automation Providers API)創(chuàng)建用戶界面控制元素,也可以通過調用UI自動化客戶端應用程序接口(UI Automation Clients API)創(chuàng)建應用程序,通過UI自動化核心層與UI自動化界面控制元素進行通訊。
WPF UI自動化模型通過把界面上一個個的UI元素作為自動化元素 (AutomationElement)暴露給客戶端應用程序供其調用。所有UI自動化元素組成以桌面(Desktop)為根節(jié)點的樹型層次結構,樹狀結構包含所有正在運行的應用程序,每一個正在運行的應用程序都是這個根的子節(jié)點,其每一個可能與用戶進行互動的界面元素都是一系列層次化的自動化元素(AutomationElement)。
樹型層次結構通過原始視圖(Raw View) 的形式展現(xiàn)給客戶端,客戶端可以通過過濾自動化元素樹的原始視圖 (Raw View) ,得到控制項視圖 (Control View) 和內容項視圖 (Content View) 。 NET3.0提供UI 探測程序UISpy.exe供開發(fā)人員調用以察看UI自動化元素視圖。
自動化元素 ( AutomationElement)對象包括UI元素在界面上所呈現(xiàn)的兩類共有屬性。一個是控制類型屬性(Control Type),控制類型屬性定義界面元素的基本表現(xiàn)形式和功能,并以此作為單一的識別實體。
比如,按鈕Button類型或者多選框Check Box類型。一個是控制模式(Control Patterns),控制模式提供一個統(tǒng)一的方法來構建和表達控制類型所擁有的功能。比如,可以對擁有被調用功能的控制類型比如按鈕Button類型使用調用模式,對編輯類控制類型使用文本模式等。
控制模式通過公開方法調用使客戶端得到界面元素進一步的詳細信息并提供輸入。微軟鑒別出18種控制模式,通過這18種控制模式可以展現(xiàn)出任何類UI元素及其任意組合所能實現(xiàn)的所有事情。
注意,WPF UI自動化模型中的控制類型和控制模式之間并不是一一對應的關系。一個控制模式可以被多種控制類型支持,一個控制類型也可以支持多種控制模式,每一個組合都展現(xiàn)其不同的行為樣式。
比如,一個下拉框類型(Combo Box)具有至少兩種控制模式:一個是呈現(xiàn)其折疊和展開能力的模式(ExpandCollapsePattern),另一個是呈現(xiàn)其選擇項的可選擇模式(SelectionItemPattern)。