如何重構PhoneGap架構和代碼,支持軟硬整合開發

034349424.png034429923.png

ee                                                                        ee
html

歡迎訪問 ==>高老師的博客網頁架構

高煥堂:MISOO(大數據.大思考)聯盟.臺北中心和東京(日本)分社.總教練框架


EE                                                                        EEide

何重構PhoneGap架構和代碼,支持軟硬整合開發


1.  案例說明大數據

1.1  目標

這是支持智能家庭的<軟硬整合開發、硬硬結合銷售>商業模式的應用軟件平臺架構設計。在此商業模式裏,TV/STB是扮演主角(主硬件角色),因此這個開源(Open Source)的軟件平臺會執行於TV/STB裏。咱們稱此平臺爲:<軟硬整合平臺>。當用戶將小配件鏈接到TV/STB時,此平臺就會啓動相對映的(軟件)插件(Plug-in)來掌控大、小硬件的通訊;並且銜接到上層的應用軟件(App)。隨着小配件的創新和數量增多,插件也會更新、數量也會增多。因而,此<軟硬整合平臺>裏,須要開發一個軟件模塊來管理上述的衆多插件。這個軟件模塊,通稱爲:<插件管理模塊>(Plug-in Manager)。它負責管理衆多的插件,這插件就是EIT造形裏的<T>。如圖-1裏的Tc和Tn。spa

01221723-dd5123c5b8c247e89a1f8c5ff6a0276
圖-1. 插件與小硬件是對映的插件

其中,Tc對映到Router而鏈接到Contec雲平臺;而tn則對映到Router而鏈接到Neat雲平臺。因爲這是一個支持<硬硬結合銷售>的軟件平臺;其架構設計必須考慮其跨(別人的)平臺的能力,以便擺脫被外來(軟、硬件)模塊的束縛。並進而化被動爲主動,隨時能順暢地抽換外來模塊,確保軟件平臺的新陳代謝,是軟件平臺持續成長的基礎。而其中的EIT造形就擔任這項任務。例如,圖-2裏的透過<Tp>插件來整合外掛的信息推送系統,讓<軟硬整合平臺>可以不受信息推送系統的束縛。架構設計

01221744-5fae05e8fc3a4054afb71de42b69da3
圖-2.  架構設計必須考慮其跨(別人的)平臺設計

1.2   作法

在PhoneGap框架裏有個<插件管理(Plug-in Manager)>模塊,因爲PhoneGap是一個開源軟件,能夠對它加以重構而移植過來,作爲咱們開源開放的<軟硬整合平臺>裏的<插件管理模塊>。原來的PhoneGap框架,其信息流向是承接來自WebView的事件。也就是它原來搭配的是HTML5-based的Web App;如圖-3所示。orm

01221813-d62a01ac24ba4355b3785f7595b6d42
圖-3.  原來PhoneGap框架的信息流向

因爲咱們的<軟硬整合平臺>上的應用軟件,其形式包含傳統的Android App形式,以及HTML5-based的Web App形式。因此咱們必須重構PhoneGap框架,讓信息流向也能承接來自傳統(通常)Android App裏的View事件;如圖-4所示。

01221837-f6d910c1dc00403eae9bfa79b45aaa6
圖-4. 重構後,PhoneGap框架所添加的信息流向

因而,咱們的<軟硬整合平臺>就能管理上述兩種Android App所須要的插件了;透過這些插件來將上層的App與底層硬件驅動(Driver)銜接,來控制外加的小配件;而實踐了<軟硬整合開發、硬硬結合銷售>的商業目標。[歡迎光臨 高煥堂 網頁:  http://www.cnblogs.com/myEIT/ ]  


2.  重構設計的經驗分享與討論

2.1    從<重構設計>到<重構代碼>的過程

◆  議題:PhoneGap目前只搭配HTML5的Web App
★ 如何重構PhoneGap的架構和代碼
★ 讓PhoneGap也能搭配通常的Native App

◆  現況:目前PhoneGap的架構設計
★ HTML5 & PhoneGap可讓UI更容易跨平臺
★ 其依賴Browser和PhoneGap的插件<T>來吸取平臺的差化
★ 若是插件不少時,PhoneGap裏的PluginManager負責管理之
★ UI事件是從WebView傳送到PhoneGap的插件<T>

◆  目標:
★ 即便不採用HTML5,也能使用PhoneGap來管裏插件
★ 一旦不使用HTML5,PhoneGap就再也不搭配WebView
★ 因而,PhoneGap轉而搭配通常的View,如Button等
★ UI事件(Event)改從通常的傳送到PhoneGap的插件<T>

◆  收穫:
★ 如何攔截App的啓動事件(onCreate事件)和UI事件
★ 以EIT造形加快理解PhoneGap框架的結構
★ 深入領悟<I>的設計要領:如IPlugin接口設計
★ 熟悉從<重構設計>到<重構代碼>的過程

2.2   重構的設計思考

     ◆  重構範圍內共有3個EIT造形的美妙組合
★ 第1個造形:{ Activity-DroidGap }
★ 第2個造形:{ WebView-CodavaWebView }
★ 第3個造形:{ PluginManager-Plugin-<T>}
★ 熟悉從<重構設計>到<重構代碼>的過程
     ◆  由於再也不搭配WebView,因此前兩個EIT造形都必須重構
     ◆  第3個造形最複雜
     ◆  上上策是:不重構第3個造形,其內涵和接口代碼都保持不變
     ◆  成功地讓第3個造形跨到重構的新平臺(即前兩個造形)

2.3   案例的成功關鍵和啓示

     ◆  關鍵:在於上述的設計思考
     ◆  洞悉:心懷EIT造形去觀察架構
     ◆  技巧:從<I>觀察重構的變更震幅,找出上上之策
     ◆  啓示:優越架構,帶來易於重構的機會,創造了系統將來性

=========================================================

相關文章:<Android與iOS/WP8跨平臺整合設計與開發 專欄>

~ End~

**                                                                     **

162709484.png

相關文章
相關標籤/搜索