1.需求
無論是在.net還是java平臺,合理的分層架構是最普遍的模塊化思路之一。
dll,jar文件無不風靡盛行,無處不在。
一天,tx團隊和我說,我們現在要做android上做三個論壇的客戶端,一個是新聞論壇,一個是文學論壇,一個是音樂論壇。除了數據,界面和很少的模塊不一樣,其他的都一摸一樣。
jar是我第一刻就想到的東西,但是共用的jar文件無法方便的共享資源或者覆蓋資源。
而我們也不會傻傻的單獨做三個客戶端的吧,也不會傻傻的做3個客戶端再傻傻的copy3份,依次修改吧。
2.問題
在android工程中如何開發一個共用framework,能共用資源,代碼,但是也能擴展?
3.使用硬編碼判斷
有人提出了一種方案, 在代碼里面判斷:
if(新聞論壇) {
//加載新聞論壇的資源
//執行新聞論壇的代碼
//顯示新聞論壇的效果
}else if(文學論壇) {
//加載文學論壇的資源
//執行文學論壇的代碼
//顯示文學論壇的效果
}else if(音樂論壇) {
//加載音樂論壇的資源
//執行音樂論壇的代碼
//顯示音樂論壇的效果
}
ps:這是一種很無奈的辦法,代碼丑陋,擴展性差,有沒有更好的辦法呢?
4.使用android library分離工程
android library提供了一個類似于其他平臺的庫的概念,這個庫不僅能公用代碼,還能共用資源,還能覆寫資源。
android library是以工程的顆粒來復用,引用它的工程,其實就是引用它的代碼,然后生成r.java和主工程需要的資源,而剔除library中被覆蓋的資源。其中library中的androidmanifest.xml不能復用,也就是說主工程必須重新定義androidmanifest.xml,這個也很容易理解,androidmanifest.xml本來就是工程的一個配置文件,一般來說不具備共用的庫的通用性。
步驟如下:
第一步:新建android工程common。
第二步:右鍵common,選擇properties,在android標簽頁,選中"is library" ,如下圖。

第三步: 新建主工程新聞論壇tianxianews。
第四步: 右鍵tianxianews,選擇properties,在android標簽頁,點擊add,選中common。如下圖。

查看最后的工程結構:

此時此刻,common工程天衣無縫成了tianxianews工程的一部分。
我們展開tianxianews工程的gen目錄:

eclipse為了生成了兩個r.java,一個是common工程的,一個tianxianews工程的,但是內容是一摸一樣的,這樣做的好處是:r.java里面的內容包括兩個工程資源,第一,tianxianews工程通過r.java能調用到common工程的資源;第二,如果有覆寫的資源,生成apk的時候,tianxianews工程覆蓋common工程的資源,因為兩個r.java內容一樣,common代碼調用的r.java中的資源,實際上調用的是tianxianews資源,這個特性類似如面向對象的繼承的概念。
我們還可以另外新建tianxiamusic,tianxialiterature工程,都引用common,這樣我們三個工程就能共用common,這樣我們就可以只在common一個工程中開發了。
在這里,具體的使用步驟我沒有截圖出來,主要是沒什么技術,也沒什么好說的,就是兩個字:覆蓋。
5.小結
android library為android模塊化和工程擴展提供了一個很好的工具或者方式。隨著項目的增大,資源的共享,模塊化和擴展的這種需求更是日益凸顯,它不僅去掉了代碼的丑陋,而且減少了開發量,帶來的益處不少。同時由此我們也可以看出來android的不成熟,他們為我們大型工程提供的方案還是太少,這可能也有源自手機平臺本身的局限性吧,我們期待android市場走向更強大,技術走向更強悍。