Android開發(fā)之項目模塊化實踐教程
前言
大家應(yīng)該都知道,項目模塊化是一個大命題,相信各團隊都有其合理方案。本文不求涵蓋各方面,僅從項目協(xié)同、開發(fā)調(diào)試、業(yè)務(wù)模塊服務(wù)調(diào)用與通知三個方面簡述一個可行方案。下面話不多說了,來一起看看詳細的介紹吧。
項目協(xié)同
項目協(xié)同,也叫多項目協(xié)同,是對多個相關(guān)且有并行情況項目的管理模式,它是幫助實現(xiàn)項目與企業(yè)戰(zhàn)略相結(jié)合的有效理論和工具[1]。本文的項目協(xié)同為Android主APP與其他業(yè)務(wù)模塊的協(xié)同。
假設(shè)我們的APP目錄如下,一個主app,多個modules。并假設(shè)我們的主app與各modules為多git repository。一個大APP多git repository管理是合理的。本文使用git repo[2]管理項目(可能有團隊使用git submodule[3],在此不推薦,其坑會很多)。
MApp --獨立git rep app modules module1 --獨立git rep module2 --獨立git rep module3 --獨立git rep ...
使用git repo,團隊早期可以不用玩一整套(git repo+gerrit),可以考慮只用repo去管理項目目錄,成員提交代碼還是繼續(xù)走git提交。
項目開發(fā)與調(diào)試
Android模塊化的主要目的是業(yè)務(wù)并行開發(fā),減少編譯時間,但又方便業(yè)務(wù)模塊與主App的調(diào)試。本文介紹如下方案。
MApp app --application modules module1 demo --application lib --library settings.gradle settings.gradle settings_debug.gradle local.properties
MApp的settings.gradle文件:
boolean moduleDebug() { boolean ret = false try { Properties properties = new Properties() File file = file('local.properties') if (!file.exists()) { return false } properties.load(file.newDataInputStream()) String debugStr = properties.getProperty("debug") if (debugStr != null && debugStr.length() > 0) { ret = debugStr.toBoolean() } } catch (Throwable throwable) { throwable.printStackTrace() ret = false } return ret } include ':app' if (moduleDebug()) { apply from: 'settings_debug.gradle' }
settings_debug.gradle文件:
//include 'module1' //project(':module1').projectDir = new File('modules/module1/lib') ...其他業(yè)務(wù)模塊
當(dāng)module1在需求開發(fā)階段,完全不用考慮主APP,可以在Android Studio中以項目的方式打開。當(dāng)module1需要和主APP跑流程時,我們只需要把MApp的local.properties的debug屬性改為true,并在settings_debug.gradle中打開module1即可。
業(yè)務(wù)模塊服務(wù)調(diào)用與通知
當(dāng)APP模塊化后,通過Intent(Context packageContext, Class<?> cls)
方式去啟動其他模塊的Activity就不太合理了。模塊化后,模塊里的Activity或其他組件對其他業(yè)務(wù)模塊最好透明。喚起Activity可以通過App Links[4]的方式,也就是我們常說的url router方式。App Links還可以玩deep link。Github上現(xiàn)在開源項目比如ARouter[5]就是App Link的應(yīng)用。
當(dāng)然,模塊之間的通信,不局限于啟動四大組件,還有服務(wù)調(diào)用與通知。這的服務(wù)不是Android系統(tǒng)的Service。舉個服務(wù)通知的例子,在電商APP中,店鋪詳情頁點收藏按鈕,可能要通知其他模塊,變更UI或數(shù)據(jù)。服務(wù)調(diào)用的例子,比如模塊喚起登陸注冊,登陸或注冊成功后,做相應(yīng)業(yè)務(wù)處理。
服務(wù)調(diào)用,大部分團隊可能沒涉及到。服務(wù)調(diào)用可以用IOC,反射等注冊到服務(wù)注冊中心。本文選一個取巧的方案。利用Applicatin.getSystemService方法,讓Application作為ZoomKeep一樣成為服務(wù)注冊中心。只要各Serivce繼承同一個Interface,相應(yīng)模塊間服務(wù)調(diào)用就不難了。
public class MApp extends Application { @Override public Object getSystemService(String name) { return super.getSystemService(name); } }
服務(wù)通知,稍簡單,用廣播,EventBus[6]或其他方式都可。本文推薦EventBus,但其有缺點,如Event多起來后,很難找全觀察者和通知者之間的關(guān)系;一些簡單Event對象無法復(fù)用,所以最好二次開發(fā)。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
參考
[1] 項目協(xié)同: http://www.baike.com/wiki/%E...
[2] git repo:https://gerrit.googlesource.com/git-repo/
[3] git submodule: https://git-scm.com/book/zh/v1/Git...
[4] App Links:https://developer.android.com/training/app-links/deep-linking.html
[5] ARouter:https://github.com/alibaba/ARouter
[6] EventBus:https://github.com/greenrobot/EventBus
相關(guān)文章
Android自定義View Material Design理念詳解
這篇文章主要為大家介紹了Android自定義View Material Design理念詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02Android開發(fā)中如何解決Fragment +Viewpager滑動頁面重復(fù)加載的問題
這篇文章主要介紹了Android開發(fā)中如何解決Fragment +Viewpager滑動頁面重復(fù)加載的問題 ,需要的朋友可以參考下2017-07-07基于Android studio3.6的JNI教程之ncnn人臉檢測mtcnn功能
這篇文章主要介紹了基于Android studio3.6的JNI教程之ncnn之人臉檢測mtcnn功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03Android實現(xiàn)在TextView文字過長時省略部分或滾動顯示的方法
這篇文章主要介紹了Android實現(xiàn)在TextView文字過長時省略部分或滾動顯示的方法,結(jié)合實例形式分析了Android中TextView控件文字顯示及滾動效果相關(guān)操作技巧,需要的朋友可以參考下2016-10-10Android應(yīng)用UI開發(fā)中Fragment的常見用法小結(jié)
這篇文章主要介紹了Android應(yīng)用UI開發(fā)中Fragment的常見用法小結(jié),Fragment的存在是為了解決不同屏幕分辯率的動態(tài)和靈活UI設(shè)計,需要的朋友可以參考下2016-02-02Android中使用SharedPreferences完成記住賬號密碼的功能
這篇文章主要介紹了Android中使用SharedPreferences完成記住賬號密碼的功能,需要的朋友可以參考下2017-08-08