相對于傳統(tǒng)計算機(jī)程序語言來說,Android開發(fā)學(xué)習(xí)資源上還稍微欠缺一些,對于一些基礎(chǔ)應(yīng)用講解還稍顯匱乏,本篇所講述的Android培訓(xùn)內(nèi)容可以幫助大家更好的理解Android項(xiàng)目快速開發(fā)框架。結(jié)合之前所用的ormlite和hessian,再加上SAE已經(jīng)支持JAVA,把服務(wù)端切換到JAVA,也就有了本文。使用hessian來做數(shù)據(jù)傳輸,ormlite來實(shí)現(xiàn)客戶端與服務(wù)端的數(shù)據(jù)存儲,極大的減少了CRUD工作。本文為探索貼,未正式用于大型項(xiàng)目,歡迎大家討論使用!正文一、簡介1.1 ormliteOrmlite[Object Relational Mapping Lite (ORM Lite)]對象關(guān)系映射精簡版(精簡版的ORM)提供了一些簡單的,輕量級持久化Java對象到SQL數(shù)據(jù)庫,同時也避免了復(fù)雜性和更多的標(biāo)準(zhǔn)的ORM包的開銷的功能。支持?jǐn)?shù)據(jù)庫的jdbc調(diào)用,當(dāng)然,最重要的肯定是它支持android原生的數(shù)據(jù)庫api調(diào)用sqlite?!D(zhuǎn)載自這里。1.2 hessian使用方法參照本博兩篇文章:[hessdroid]Android下使用Hessian與Java服務(wù)端通訊[hessdroid]Android下使用Hessian與Java服務(wù)端通訊的傳值測試1.3 Android快速開發(fā)框架說明考慮如下幾個特點(diǎn):a). 客戶端(Android)和服務(wù)端均使用Java語言b). 客戶端(Android)和服務(wù)端均支持Hessian和ormlite框架c). 完整的支持面向?qū)ο箝_發(fā):存儲和交互傳輸二、準(zhǔn)備2.1 開發(fā)環(huán)境為了便于同時開發(fā)Android和Java Web,這里下載的是Eclipse IDE for Java EE Developers版本,然后安裝最新的ADT插件和TOMCAT插件。2.2 服務(wù)端應(yīng)用服務(wù)器使用Tomcat,采用Java(JSP/Servlet)來實(shí)現(xiàn)服務(wù)端的業(yè)務(wù)邏輯,數(shù)據(jù)庫使用Mysql??焖倏蚣艽罱ㄍ扑]大家使用XAMPP(集成Apache、MySQL、PHP等,支持綠色安裝)。2.3 客戶端普通的Android環(huán)境2.4 通信與存儲說明服務(wù)端與客戶端通過Hessian進(jìn)行數(shù)據(jù)交換,通過Ormlite保存數(shù)據(jù)庫(通過JDBC保存到服務(wù)端的MYSQL數(shù)據(jù)庫,也可以直接保存到客戶端的sqlite數(shù)據(jù)庫);三、代碼3.1 項(xiàng)目工程截圖(服務(wù)端)HOLib共用于客戶端和服務(wù)端,保證接口和數(shù)據(jù)對象一致性。3.2 重點(diǎn)代碼分析3.2.1 服務(wù)端web.xml?xml version="1.0" encoding="ISO-8859-1"?web-app xmlns="" xmlns:xsi="" xsi:schemaLocation=" web-app_2_4.xsd" version="2.4" servlet servlet-nameuser/servlet-name servlet-classcom.nmbb.ho.server.servlet.UserServlet/servlet-class /servlet servlet-mapping servlet-nameuser/servlet-name url-pattern/user.do/url-pattern /servlet-mapping listener listener-classcom.nmbb.ho.server.StartupInit/listener-class /listener/web-appStartupInit.javapublic class StartupInit implements ServletContextListener { @Override public void contextInitialized(ServletContextEvent arg0) { try { TableUtils.dropTable(OrmliteHelper.getConnection(), POUser.class, true); //創(chuàng)建數(shù)據(jù)庫 TableUtils.createTable(OrmliteHelper.getConnection(), POUser.class); } catch (SQLException e) { e.printStackTrace(); } } @Override public void contextDestroyed(ServletContextEvent arg0) { }} 代碼說明:StartupInit可用于創(chuàng)建數(shù)據(jù)庫表結(jié)構(gòu),這里用于測試,真實(shí)環(huán)境注意數(shù)據(jù)丟失問題。POUser.java@DatabaseTable(tableName = "nmbb_users")public class POUser implements Serializable { /** 用戶編號,6位數(shù)字 */ @DatabaseField(generatedId = true) public int suid; /** 用戶名 */ @DatabaseField(width = 30) public String username; /** 密碼 */ @DatabaseField(width = 30) public String password; /** 昵稱 */ @DatabaseField(width = 60) public String nickname; /** 200 正常 201 數(shù)據(jù)校驗(yàn)錯誤 202用戶已經(jīng)存在 */ public int status = 200; /** 用于放錯誤信息 */ public String msg; public POUser() { }} 代碼說明:注意需要一個空的構(gòu)造函數(shù),其他請參考o(jì)rmlite資料。UserServlet.java/*** 用戶Servlet** @author 農(nóng)民伯伯* @see **/public class UserServlet extends HessianServlet implements IUserService { @Override public POUser register(String username, String password) { POUser result = new POUser(); System.out.println("[UserServlet.register]..."); // 檢測數(shù)據(jù)是否合法 if (isEmpty(username) || isEmpty(password)) { result.status = 201; result.msg = "用戶名或密碼不能為空"; } else { // 檢測用戶是否存在 OrmliteHelperPOUser db = new OrmliteHelperPOUser(); if (db.exist(POUser.class, "username", username)) { result.status = 202; result.msg = "用戶名已經(jīng)存在"; } else { result.username = username; result.password = password; db.create(result);// 入庫 result.msg = "注冊成功"; System.out.println("create user suid:" + result.suid); } } return result; } @Override public ListPOUser query(int suid, int startIndex, int pageSize) { return new OrmliteHelperPOUser().query(POUser.class, "suid", suid, startIndex, pageSize) ; } /** * 判斷字符串是否為空 * * @param str * @return */ public static boolean isEmpty(String str) { return str == null || str.length() == 0; }}3.2.2 客戶端(Android) public class UserActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); } public void OnClickRegiger(View view) { new AsyncTaskVoid, Void, POUser() { @Override protected POUser doInBackground(Void... params) { String url = ""; HessianProxyFactory factory = new HessianProxyFactory(); try { factory.setDebug(true); factory.setReadTimeout(5000); //不設(shè)置會報 expected hessian reply at 0x48 factory.setHessian2Reply(false); IUserService basic = (IUserService) factory.create(IUserService.class, url, getClassLoader()); return basic.register("admin", "123456"); } catch (MalformedURLException e) { Log.e("UserActivity", "OnClickRegiger", e); } catch (Exception e) { Log.e("UserActivity", "OnClickRegiger", e); } return null; } @Override protected void onPostExecute(POUser result) { if (result != null) { if (result.status == 200) { //保存入庫 new DbHelperPOUser().create(result); } Toast.makeText(UserActivity.this, "" + result.msg, Toast.LENGTH_LONG).show(); } }; }.execute(); }}代碼說明:1、DbHelper在源碼里給出。2、如果項(xiàng)目無法編譯通過,請注意設(shè)置項(xiàng)目的字符編碼、JDK版本、Android的版本。三、總結(jié)5.1 優(yōu)點(diǎn)a). 完全面向?qū)ο箝_發(fā)b). 降低項(xiàng)目的復(fù)雜度,減少引入其他框架所帶來的復(fù)雜性c). 非常適合一個開發(fā)服務(wù)端和客戶端充分的利用的框架的特點(diǎn),提交開發(fā)效率,適合中小型項(xiàng)目快速開發(fā)。5.2 缺點(diǎn)a). 注意服務(wù)端與客戶端共用id的問題5.3 其他a). ormlite支持標(biāo)準(zhǔn)的JPA助記符,這里。這樣服務(wù)端采用Hibernate應(yīng)該也是可以的,有時間可以做一個整合例子看看。學(xué)習(xí)語言同做事情一樣,想通其中的關(guān)系,就會事半功倍,對語言要深入的理解,
成都創(chuàng)新互聯(lián)公司致力于互聯(lián)網(wǎng)品牌建設(shè)與網(wǎng)絡(luò)營銷,包括成都網(wǎng)站建設(shè)、成都做網(wǎng)站、SEO優(yōu)化、網(wǎng)絡(luò)推廣、整站優(yōu)化營銷策劃推廣、電子商務(wù)、移動互聯(lián)網(wǎng)營銷等。成都創(chuàng)新互聯(lián)公司為不同類型的客戶提供良好的互聯(lián)網(wǎng)應(yīng)用定制及解決方案,成都創(chuàng)新互聯(lián)公司核心團(tuán)隊10年專注互聯(lián)網(wǎng)開發(fā),積累了豐富的網(wǎng)站經(jīng)驗(yàn),為廣大企業(yè)客戶提供一站式企業(yè)網(wǎng)站建設(shè)服務(wù),在網(wǎng)站建設(shè)行業(yè)內(nèi)樹立了良好口碑。
1、Rajawali
介紹:
安卓的OpenGL ES 2.0/3.0 引擎??梢杂糜谥谱髌胀☉?yīng)用或者動態(tài)壁紙,當(dāng)然也可以用于制作游戲。
項(xiàng)目地址:
2、RxAndroid
介紹:
RxAndroid是RxJava的一個針對Android平臺的擴(kuò)展。它包含了一些能夠簡化Android開發(fā)的工具。
項(xiàng)目地址:
3、Paginize
介紹:
Paginize 是一個輕量級的UI框架,使用注解來注入布局和view,除了使用注解之外,該框架還有兩個特色:1.用Page的概念來取代Fragment,2.切換page時自帶ios風(fēng)格的動畫效果。
項(xiàng)目地址:
4、otto
介紹:
Otto 是square公司出的一個事件庫(pub/sub模式),用來簡化應(yīng)用程序組件之間的通訊。 Otto 修改自Google的Guava庫,專門為Android平臺進(jìn)行了優(yōu)化。
項(xiàng)目地址:
5 、rebound
介紹:
rebound是facebook的開源動畫庫??梢哉J(rèn)為這個動畫庫是獨(dú)立于android Framework之外的一種動畫實(shí)現(xiàn)。
項(xiàng)目地址:
6、KJFrameForAndroid
介紹:
KJFrameForAndroid 又叫KJLibrary,是一個幫助快速開發(fā)的框架。使用KJFrameForAndroid,你可以只用一行代碼就完成http請求、網(wǎng)絡(luò)圖片加載、數(shù)據(jù)庫數(shù)據(jù)保存或讀取。
項(xiàng)目地址:
7、xUtils
介紹:
xUtils
包含了很多實(shí)用的android工具。 xUtils
支持大文件上傳,更全面的http請求協(xié)議支持(10種謂詞),擁有更加靈活的ORM,更多的事件注解支持且不受混淆影響... xUitls
最低兼容android 2.2 (api level 8)
項(xiàng)目地址:
目前xUtils主要有四大模塊:
DbUtils模塊:
android中的orm框架,一行代碼就可以進(jìn)行增刪改查;
支持事務(wù),默認(rèn)關(guān)閉;
可通過注解自定義表名,列名,外鍵,唯一性約束,NOT NULL約束,CHECK約束等(需要混淆的時候請注解表名和列名);
支持綁定外鍵,保存實(shí)體時外鍵關(guān)聯(lián)實(shí)體自動保存或更新;
自動加載外鍵關(guān)聯(lián)實(shí)體,支持延時加載;
支持鏈?zhǔn)奖磉_(dá)查詢,更直觀的查詢語義,參考下面的介紹或sample中的例子。
ViewUtils模塊:
android中的ioc框架,完全注解方式就可以進(jìn)行UI,資源和事件綁定;
新的事件綁定方式,使用混淆工具混淆后仍可正常工作;
目前支持常用的20種事件綁定,參見ViewCommonEventListener類和包c(diǎn)om.lidroid.xutils.view.annotation.event。
HttpUtils模塊:
支持同步,異步方式的請求;
支持大文件上傳,上傳大文件不會oom;
支持GET,POST,PUT,MOVE,COPY,DELETE,HEAD,OPTIONS,TRACE,CONNECT請求;
下載支持301/302重定向,支持設(shè)置是否根據(jù)Content-Disposition重命名下載的文件;
返回文本內(nèi)容的請求(默認(rèn)只啟用了GET請求)支持緩存,可設(shè)置默認(rèn)過期時間和針對當(dāng)前請求的過期時間。
BitmapUtils模塊:
加載bitmap的時候無需考慮bitmap加載過程中出現(xiàn)的oom和android容器快速滑動時候出現(xiàn)的圖片錯位等現(xiàn)象;
支持加載網(wǎng)絡(luò)圖片和本地圖片;
內(nèi)存管理使用lru算法,更好的管理bitmap內(nèi)存;
可配置線程加載線程數(shù)量,緩存大小,緩存路徑,加載顯示動畫等...
8、butterknife-view
注入工具
介紹:
為了減少頻繁的調(diào)用findViewById(R.id...),可以采用一些注入框架,可以簡化自己的代碼,讓你更專注于實(shí)際的功能開發(fā),butterknife就是這樣的一個框架,他是jakewharton大神的作品,值得一試。
class ExampleActivity extends Activity {
@InjectView(R.id.title) TextView title;
@InjectView(R.id.subtitle) TextView subtitle;
@InjectView(R.id.footer) TextView footer;
@Override public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.simple_activity);
ButterKnife.inject(this);
// TODO Use "injected" views...
}
}
這是博客地址:
項(xiàng)目地址:
9、cube-sdk
一淘推出的開發(fā)框架
介紹:
cube一個Android開發(fā)包, 可極大提高你的開發(fā)效率。主要提供了圖片加載以及網(wǎng)絡(luò)請求方面的api功能。
項(xiàng)目地址:
他們的網(wǎng)站:
10、ASimpleCache
一個簡單的緩存框架
介紹:
ASimpleCache
是一個為android制定的 輕量級的 開源緩存框架。輕量到只有一個java文件(由十幾個類精簡而來)。
它可以緩存什么東西?普通的字符串、JsonObject、JsonArray、Bitmap、Drawable、序列化的java對象,和
byte數(shù)據(jù)。
項(xiàng)目地址:
11、androidannotations
介紹:
AndroidAnnotations是一個能夠讓你快速進(jìn)行Android開發(fā)的開源框架,它能讓你專注于真正重要的地方。
使代碼更加精簡,使項(xiàng)目更加容易維護(hù),它的目標(biāo)就是“Fast Android Development.Easy maintainance”。
通過一段時間的使用發(fā)現(xiàn),相比原生的Android開發(fā),確實(shí)能夠讓你少些很多代碼
項(xiàng)目地址:
12、Event Bus
解耦android模塊
介紹:
當(dāng)一個Android應(yīng)用功能越來越多的時候,保證應(yīng)用的各個部分之間高效的通信將變得越來越困難。如何優(yōu)雅地解決這個問題?這時候,就需要使用到EventBus。
EventBus是GreenRobot出品的Android系統(tǒng)的一個Event
Bus類庫,使用起來和之前我們所介紹的Square的Otto差不多,都是用來簡化應(yīng)用組件之間的通信。
項(xiàng)目地址:
13、BeeFramework_Android
介紹:
BeeFramework
Android版主要為Android初級開發(fā)人員提供一個基于MVC開發(fā)模式的APP DEMO,并提供一套APP內(nèi)調(diào)試工具,包括
查看網(wǎng)絡(luò)數(shù)據(jù)請求歷史 Crash Log列表 真機(jī)WIFI環(huán)境下模擬2G\3G網(wǎng)絡(luò) 查看APP性能(內(nèi)存占用,CPU占用等)
項(xiàng)目地址:
14、afinal
介紹:
Afinal是一個android的ioc,orm框架,內(nèi)置了四大模塊功能:FinalAcitivity,FinalBitmap,FinalDb,FinalHttp。通過finalActivity,我們可以通過注解的方式進(jìn)行綁定ui和事件。通過finalBitmap,我們可以方便的加載bitmap圖片,而無需考慮oom等問題。通過finalDB模塊,我們一行代碼就可以對android的sqlite數(shù)據(jù)庫進(jìn)行增刪改查。通過FinalHttp模塊,我們可以以ajax形式請求http數(shù)據(jù)。
Afinal里面目前包含了四大組件:
FinalHttp:用于請求http數(shù)據(jù),直接ajax方式請求,文件上傳, 斷點(diǎn)續(xù)傳下載文件等
FinalBitmap:用于顯示bitmap圖片,而無需考慮線程并發(fā)和oom等問題。
FinalActivity:完全可以通過注解方式綁定控件和事件,無需編寫代碼。
FinalDb:android中sqlite的orm框架,一行代碼搞定增刪改查。
Afinal是一個android的ioc,orm框架,內(nèi)置了四大模塊功能:FinalAcitivity,FinalBitmap,FinalDb,FinalHttp。通過finalActivity,我們可以通過注解的方式進(jìn)行綁定ui和事件。通過finalBitmap,我們可以方便的加載bitmap圖片,而無需考慮oom等問題。通過finalDB模塊,我們一行代碼就可以對android的sqlite數(shù)據(jù)庫進(jìn)行增刪改查。通過FinalHttp模塊,我們可以以ajax形式請求http數(shù)據(jù)。詳情請通過以下網(wǎng)址查看。
項(xiàng)目地址:
15、Volley
介紹:
在這之前,我們在程序中需要和網(wǎng)絡(luò)通信的時候,大體使用的東西莫過于AsyncTaskLoader,HttpURLConnection,AsyncTask,HTTPClient(Apache)等,今年的Google
I/O 2013上,Volley發(fā)布了。Volley是Android平臺上的網(wǎng)絡(luò)通信庫,能使網(wǎng)絡(luò)通信更快,更簡單,更健壯。
項(xiàng)目地址:
1.下載:
點(diǎn)擊右邊這個地址 h hub.com/TommyLemon/Android-ZBLibrary
點(diǎn)擊DownloadZip即可。
2.解壓
3.用ADT-Bundle(集成了ADT插件的Eclipse)或 AndroidStudio打開
ADT打開
File Import Android Existing Android Code Into Workspace browse
打開 解壓后的文件目錄(Android-ZBLibrary-master)下的ZBLibrary(ADT)目錄 Finish
AndroidStudio打開
File Open 打開 解壓后的文件目錄(Android-ZBLibrary-master)下的ZBLibrary(AndroidStudio)目錄 OK
4.運(yùn)行
ADT運(yùn)行
右鍵ZBLibrary Demo Run as Android Application
AndroidStudio運(yùn)行
Run Run app
如果不能成功運(yùn)行,點(diǎn)擊以下鏈接查看解決方法
.cnblogs.com/tommylemon/p/5426583.html
5.將自己的項(xiàng)目依賴ZBLibrary
ADT依賴
1)在你的項(xiàng)目的workspace下打開ZBLibrary,方法和第3步一樣
2)右鍵你的項(xiàng)目 Properties Android Library欄目中點(diǎn)擊 add 選擇ZBLibray OK OK
AndroidStudio依賴
1)打開你的項(xiàng)目 然后打開ZBLibrary,方法和第3步一樣
2)右鍵app Open Module Settings Dependencies add(點(diǎn)擊"+") Module Dependency 選擇 ZBLibrary OK OK
3)右鍵app Open Module Settings 選擇app Dependencies 如果有android-support-v4包,選擇并點(diǎn)擊 "-" 移除 OK,沒有就 Cancel
4)右鍵app Open Module Settings 選擇ZBLibrary Dependencies
①如果有android-support-v4包,選擇并點(diǎn)擊 "-" 移除
②點(diǎn)擊"+" File dependency 選擇libs目錄下其中一個 OK
③添加libs下其它jar包依賴,方法和②一樣 OK
6.重復(fù)第4步
7.查看Demo
ADT查看
打開ZBLibraryDemoApp,方法和第3步一樣
AndroidStudio查看 (Android-ZBLibrary-master下的ZBLibrary(AndroidStudio)目錄)
Windows下在資源管理器中查看,Mac下在Finder中查看
主要分為以下幾種:
1、volley
項(xiàng)目地址
(1) JSON,圖像等的異步下載;
(2) 網(wǎng)絡(luò)請求的排序(scheduling)
(3) 網(wǎng)絡(luò)請求的優(yōu)先級處理
(4) 緩存
(5) 多級別取消請求
(6) 和Activity和生命周期的聯(lián)動(Activity結(jié)束時同時取消所有網(wǎng)絡(luò)請求)
2、Android-async-http
項(xiàng)目地址:
文檔介紹:
(1) 在匿名回調(diào)中處理請求結(jié)果
(2) 在UI線程外進(jìn)行http請求
(3) 文件斷點(diǎn)上傳
(4) 智能重試
(5) 默認(rèn)gzip壓縮
(6) 支持解析成Json格式
(7) 可將Cookies持久化到SharedPreferences
3、Afinal框架
項(xiàng)目地址:
主要有四大模塊:
(1) 數(shù)據(jù)庫模塊:android中的orm框架,使用了線程池對sqlite進(jìn)行操作。
(2) 注解模塊:android中的ioc框架,完全注解方式就可以進(jìn)行UI綁定和事件綁定。無需findViewById和setClickListener等。
(3) 網(wǎng)絡(luò)模塊:通過httpclient進(jìn)行封裝http數(shù)據(jù)請求,支持ajax方式加載,支持下載、上傳文件功能。
(4) 圖片緩存模塊:通過FinalBitmap,imageview加載bitmap的時候無需考慮bitmap加載過程中出現(xiàn)的oom和android容器快速滑動時候出現(xiàn)的圖片錯位等現(xiàn)象。
FinalBitmap可以配置線程加載線程數(shù)量,緩存大小,緩存路徑,加載顯示動畫等。FinalBitmap的內(nèi)存管理使用lru算法,
沒有使用弱引用(android2.3以后google已經(jīng)不建議使用弱引用,android2.3后強(qiáng)行回收軟引用和弱引用,詳情查看android官方文檔),
更好的管理bitmap內(nèi)存。FinalBitmap可以自定義下載器,用來擴(kuò)展其他協(xié)議顯示網(wǎng)絡(luò)圖片,比如ftp等。同時可以自定義bitmap顯示器,
在imageview顯示圖片的時候播放動畫等(默認(rèn)是漸變動畫顯示)。
4、xUtils框架
項(xiàng)目地址:
主要有四大模塊:
(1) 數(shù)據(jù)庫模塊:android中的orm框架,一行代碼就可以進(jìn)行增刪改查;
支持事務(wù),默認(rèn)關(guān)閉;
可通過注解自定義表名,列名,外鍵,唯一性約束,NOT NULL約束,CHECK約束等(需要混淆的時候請注解表名和列名);
支持綁定外鍵,保存實(shí)體時外鍵關(guān)聯(lián)實(shí)體自動保存或更新;
自動加載外鍵關(guān)聯(lián)實(shí)體,支持延時加載;
支持鏈?zhǔn)奖磉_(dá)查詢,更直觀的查詢語義,參考下面的介紹或sample中的例子。
(2) 注解模塊:android中的ioc框架,完全注解方式就可以進(jìn)行UI,資源和事件綁定;
新的事件綁定方式,使用混淆工具混淆后仍可正常工作;
目前支持常用的20種事件綁定,參見ViewCommonEventListener類和包c(diǎn)om.lidroid.xutils.view.annotation.event。
(3) 網(wǎng)絡(luò)模塊:支持同步,異步方式的請求;
支持大文件上傳,上傳大文件不會oom;
支持GET,POST,PUT,MOVE,COPY,DELETE,HEAD,OPTIONS,TRACE,CONNECT請求;
下載支持301/302重定向,支持設(shè)置是否根據(jù)Content-Disposition重命名下載的文件;
返回文本內(nèi)容的請求(默認(rèn)只啟用了GET請求)支持緩存,可設(shè)置默認(rèn)過期時間和針對當(dāng)前請求的過期時間。
(4) 圖片緩存模塊:加載bitmap的時候無需考慮bitmap加載過程中出現(xiàn)的oom和android容器快速滑動時候出現(xiàn)的圖片錯位等現(xiàn)象;
支持加載網(wǎng)絡(luò)圖片和本地圖片;
內(nèi)存管理使用lru算法,更好的管理bitmap內(nèi)存;
可配置線程加載線程數(shù)量,緩存大小,緩存路徑,加載顯示動畫等...
5、ThinkAndroid
項(xiàng)目地址:
主要有以下模塊:
(1) MVC模塊:實(shí)現(xiàn)視圖與模型的分離。
(2) ioc模塊:android中的ioc模塊,完全注解方式就可以進(jìn)行UI綁定、res中的資源的讀取、以及對象的初始化。
(3) 數(shù)據(jù)庫模塊:android中的orm框架,使用了線程池對sqlite進(jìn)行操作。
(4) http模塊:通過httpclient進(jìn)行封裝http數(shù)據(jù)請求,支持異步及同步方式加載。
(5) 緩存模塊:通過簡單的配置及設(shè)計可以很好的實(shí)現(xiàn)緩存,對緩存可以隨意的配置
(6) 圖片緩存模塊:imageview加載圖片的時候無需考慮圖片加載過程中出現(xiàn)的oom和android容器快速滑動時候出現(xiàn)的圖片錯位等現(xiàn)象。
(7) 配置器模塊:可以對簡易的實(shí)現(xiàn)配對配置的操作,目前配置文件可以支持Preference、Properties對配置進(jìn)行存取。
(8) 日志打印模塊:可以較快的輕易的是實(shí)現(xiàn)日志打印,支持日志打印的擴(kuò)展,目前支持對sdcard寫入本地打印、以及控制臺打印
(9) 下載器模塊:可以簡單的實(shí)現(xiàn)多線程下載、后臺下載、斷點(diǎn)續(xù)傳、對下載進(jìn)行控制、如開始、暫停、刪除等等。
(10) 網(wǎng)絡(luò)狀態(tài)檢測模塊:當(dāng)網(wǎng)絡(luò)狀態(tài)改變時,對其進(jìn)行檢
6、LoonAndroid
項(xiàng)目地址:
主要有以下模塊:
(1) 自動注入框架(只需要繼承框架內(nèi)的application既可)
(2) 圖片加載框架(多重緩存,自動回收,最大限度保證內(nèi)存的安全性)
(3) 網(wǎng)絡(luò)請求模塊(繼承了基本上現(xiàn)在所有的http請求)
(4) eventbus(集成一個開源的框架)
(5) 驗(yàn)證框架(集成開源框架)
(6) json解析(支持解析成集合或者對象)
(7) 數(shù)據(jù)庫(不知道是哪位寫的 忘記了)
(8) 多線程斷點(diǎn)下載(自動判斷是否支持多線程,判斷是否是重定向)
(9) 自動更新模塊
(10) 一系列工具類
7、KJFrameForAndroid
項(xiàng)目地址:
github項(xiàng)目地址:
備用項(xiàng)目地址:
KJFrameForAndroid 又叫KJLibrary,是一個android的orm 和 ioc 框架。同時封裝了android中的Bitmap與Http操作的框架,使其更加簡單易用;
KJFrameForAndroid的設(shè)計思想是通過封裝Android原生SDK中復(fù)雜的復(fù)雜操作而達(dá)到簡化Android應(yīng)用級開發(fā),最終實(shí)現(xiàn)快速而又安全的開發(fā)APP。我們提倡用最少的代碼,完成最多的操作,用最高的效率,完成最復(fù)雜的功能。
同時,KJFrameForAndroid是免費(fèi)的、開源的、簡易的、遵循Apache Licence 2.0開源協(xié)議發(fā)布的android應(yīng)用開發(fā)框架,總共分為五大模 塊:UILibrary,UtilsLibrary,HttpLibrary,BitmapLibrary,DBLibrary。
8、AndroidAnnotations
xUtils是國內(nèi)比較火的快速開發(fā)框架,但是它的注解機(jī)制不是太穩(wěn)定而且注解可選也比較少,國外的一個框架主要專注于注解的開發(fā),簡化Android代碼編寫,它除了有依賴注入的特性以外,還集成了Ormlite,Spring-android中的REST模板。使用起來非常方便,大大提高了開發(fā)效率。
1.下載AndroidAnnotations:
git官網(wǎng):
項(xiàng)目中重要的兩個jar包分別是:androidannotations-api-3.0.1.jar和androidannotations-3.0.1.jar
2.新建一個android項(xiàng)目,然后將androidannotations-api-3.0.1.jar復(fù)制到libs目錄下,在項(xiàng)目的根目錄新建一個文件夾,命名為compile-libs,然后將androidannotations-3.0.1.jar復(fù)制到該目錄下
3.在你的工程上右鍵單擊,在彈出的菜單中選擇"Properties",找到Java Compiler,確保Compiler compliance level設(shè)置為1.6,否則的話處理器將不起作用
4.然后設(shè)置項(xiàng)目屬性:右鍵-Properties-Java Compiler-Annotation Processing 在該頁面選中Enable project specific settings。
5.轉(zhuǎn)到Java Compiler 中的 Annotation Processing 下邊的 Factory Path,在此將androidannotations-3.0.1.jar添加到其中。
注解1:@ViewById 與findViewById功能相似,如果ViewById后沒有設(shè)置資源ID的話,就是自動查找與變量名稱相同的id資源。
注解2:@Click 點(diǎn)擊事件處理的注解。
注解3:@UiThread 后臺Ui線程的注解,省去了Handler等等。
注解4:@EActivity 提示Activity的注解,注意,該注解將Activity編譯成Activity_,注意,多一個下劃線“_”,因此在AndroidManifest.xml文件中需要將其添加下滑線
注解5:@AfterViews 是指View類注入完畢之后執(zhí)行的代碼。
搭建Android開發(fā)環(huán)境
準(zhǔn)備工作:下載Eclipse、JDK、Android SDK、ADT插件
下載地址:Eclipse:
JDK:
Android SDK:
ADT:
1、安裝和配置JAVA開發(fā)環(huán)境:
①把準(zhǔn)備好的Eclipse和JDK安裝到本機(jī)上(最好安裝在全英文路徑下),并給JDK配置環(huán)境變量,其中JDK的變量值為JDK安裝路徑的根目錄,如我的為:D:\Program Files\Java\jdk1.7.0_02;
②打開命令提示符(cmd),輸入java -version命令,顯示如下圖則說明JAVA環(huán)境變量已經(jīng)配置好了。
2、安裝ADT插件:
①打開已安裝好的Eclipse,選擇菜單欄上的“Help”-在彈出的下拉框中單擊選擇“Install new software...”;
②在新打開的對話框中我們完全可以直接在"Work with"中輸入:在線安裝ADT插件,但由于Google的服務(wù)器搭建在國外,所以通過這種方式安裝起來會比較慢,而且可能會出現(xiàn)人品差死活裝不上的情況,所以不推薦在線安裝。
③我推薦直接通過下載好的ADT插件壓縮包進(jìn)行安裝(此種方式可以在離線環(huán)境下進(jìn)行)。具體步驟是:在新打開的對話框中點(diǎn)擊“Add”按鈕-在打開的對話框中點(diǎn)擊“Archive”按鈕選擇之前已經(jīng)下載好保存在本地硬盤的ADT插件壓縮包,至于上面的“Name”可以隨便取,這只是一個代號而已,沒什么實(shí)際作用。
④在上一步中點(diǎn)擊“Ok”按鈕后我們會發(fā)現(xiàn)中間的空白處出現(xiàn)了兩行復(fù)選框,單擊"Select All"按鈕選中所有的復(fù)選框,這步過后一路“Next”,需要“Accept”的就選中“Accept”,直到點(diǎn)擊“Finish”結(jié)束,這樣ADT插件就安裝好了。整個過程需要的時間視機(jī)器性能而定。安裝好ADT插件后,Eclipse的工具欄會出現(xiàn)一排Android的圖標(biāo),如下圖:
3、安裝SDK:
①把下載好的Android SDK安裝到本機(jī)上(最好安裝在全英文路徑下),并為Android SDK配置環(huán)境變量。Android SDK的環(huán)境變量值為SDK安裝目錄下的platform-tools文件夾和tools文件夾子目錄路徑,如我的分別為:E:\My Studying\Android\android-sdk\platform-tools、E:\My Studying\Android\android-sdk\tools,在變量值中,兩個路徑用逗號隔開。
②打開命令提示符(cmd),分別輸入android -h和adb命令,顯示如下圖則說明Android SDK環(huán)境變量已經(jīng)配置好了。
③打開Android SDK的安裝目錄,雙擊 "SDK Manager"-在打開的窗口中先選擇你需要安裝的SDK版本,其中“Status”表示該SDK包是否安裝,如我選的是“Android2.2(API 8)”(我的之前已經(jīng)安裝過了,所以“Status”為“Installed”)-再點(diǎn)擊“Install packages...”按鈕,在彈出來的窗口中最好選“Accept All”這樣才能安裝你剛才選的所有的包-最后點(diǎn)“Install”按鈕就開始安裝了,整個過程會很慢,這需要你的耐心。
另外我們還可以通過在Eclipse上的工具欄中點(diǎn)擊下圖指示的圖標(biāo)打開“SDK Manager”然后進(jìn)行安裝,這樣和上面的SDK安裝方式一樣,就不累述了。
④最后再選擇Eclipes主菜單上的"Windows"-選擇"preferrnces";
⑤在彈出來的對話框中選中左邊欄的“Android”-通過右側(cè)的“Browse...”按鈕選擇SDK的安裝路徑根目錄-點(diǎn)擊最下方的“Ok”按鈕,這樣SDK就在Eclipse上加載成功了。
4、創(chuàng)建Android模擬器(AVD):
①打開Eclipse-在Eclipse的工具欄上單擊下圖指示的圖標(biāo)打開“Android Virsual Device Manager”窗口;
②在“Android Virsual Device Manager”窗口單擊“New”按鈕-在彈出來的窗口中"Name"可以隨便??;“Target”指模擬器的系統(tǒng)版本;“SD Card”的"size"是指手機(jī)存儲卡的大小,只要你不在模擬器上裝太多的應(yīng)用,一般給個二三十MB就夠了;“Skin”是指屏幕的分辨率大小,其中“Built in”是一般手機(jī)常用標(biāo)準(zhǔn)屏幕分辨率大小,而“Resolution”是自定義屏幕分辨率大小,具體做法,可以根據(jù)自身情況選擇。-一切設(shè)置好后點(diǎn)擊“Create AVD”,這時一個模擬器就創(chuàng)建好了。如果有必要,我們可以創(chuàng)建多個模擬器用于測試時使用。
附:Android模擬器型號以及其對應(yīng)的分辨率大?。?/p>
Standard Width Height DAR Pixeis
HVGA 480 * 320 3:2 153,600
QVGA 320 * 240 4:3 76,800
WQVGA400 400 * 240 5:3 96,000
WQVGA432 432 * 240 9:5 103,680
WVGA800 800 * 480 5:3 384,000
WVGA852 854 * 480 409,920
至此為止,在Eclipse上就已經(jīng)成功搭建Android開發(fā)環(huán)境了。
在前面的課程中,隨著對Android體系的了解,已經(jīng)可以進(jìn)行正常的Android應(yīng)用開發(fā)了。在Android開發(fā)中,同其他工程開發(fā)一樣,也經(jīng)常使用一些提高效率的框架,本文我們做一個對比。這些框架,既包括:網(wǎng)絡(luò)請求框架、也包括圖片加載庫框架、還包括數(shù)據(jù)庫操作等一些框架,總之,了解和熟悉這些框架,會對自己的開發(fā)效率有很大的提升和幫助。
網(wǎng)絡(luò)請求框架
1、okHttp
在前文的學(xué)習(xí)中,我們已經(jīng)了解過okHttp,是一個常用的網(wǎng)絡(luò)加載庫。
2、Retrofit
介紹
Retrofit是一個很不錯的網(wǎng)絡(luò)請求庫,該庫是square開源的另外一個庫,之前的okhttp也是該公司開源的。
Retrofit是基于OkHttp封裝的RESTful網(wǎng)絡(luò)請求框架,使用注解的方式配置請求。優(yōu)點(diǎn)是速度快,使用注解,callback函數(shù)返回結(jié)果自動包裝成Java對象。官方自己的介紹說:
A type-safe REST client for Android and Java
該網(wǎng)絡(luò)框架在github上的地址如下:
要求
Retrofit支持的http方式方式包括 GET/POST/PUT/DELETE/HEAD/PATCH,Retrofit要求Java的版本是1.8+,Android應(yīng)用的API版本應(yīng)該在21+。
依賴
使用Retrofit庫,和其他庫一樣,首先需要設(shè)置依賴,依然是在build.gradle文件中設(shè)置依賴:
//添加retrofit庫依賴
implementation ‘com.squareup.retrofit2:retrofit:2.1.0’
//添加gson轉(zhuǎn)換器
implementation ‘com.squareup.retrofit2:converter-gson:2.1.0’
使用
通過一個例子,我們可以來演示該框架的使用步驟:
1、定義請求接口,即程序中都需要什么請求操作
public interface HttpServices {
/**
獲取頭條新聞
@param type 新聞類型
@param key apiKey
@return
*/
@GET(“toutiao/index”)
Call getNewsList(@Query(“type”) String type, @Query(“key”) String key);
}
2、實(shí)例化Retrofit對象,使用的Builder的模式創(chuàng)建,如下代碼所示:
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(Constants.BASE_API)
.addConverterFactory(GsonConverterFactory.create())
.build();
注意,這里設(shè)置結(jié)構(gòu)體轉(zhuǎn)換器,是可以直接把網(wǎng)絡(luò)請求回來的數(shù)據(jù)轉(zhuǎn)換為Java結(jié)構(gòu)體,這里設(shè)置的Gson解析器,因此要引入相應(yīng)的轉(zhuǎn)換器支持庫。
3、得到接口對象,自己創(chuàng)建的全局的接口對象,并調(diào)用相應(yīng)的接口,得到一個類似于請求Call對象。如下所示:
HttpServices httpServices = retrofit.create(HttpServices.class);
Call newsListCall = httpServices.getNewsList(“top”, Constants.API_KEY);
4、加入到請求隊列中,并設(shè)置回調(diào)方法:
newsListCall.enqueue(new Callback() {
@Override
public void onResponse(Call call, Response response) {
//網(wǎng)絡(luò)請求成功的回調(diào)方法
List list = Arrays.asList(response.body().result.data);
Log.i(“TAG”, “請求成功:” + String.valueOf(list.size()));
NewListAdapter adapter = new NewListAdapter(RetrofitActivity.this);
adapter.setmData(list);
mRecyclerView.setAdapter(adapter);
}
@Override
public void onFailure(Call call, Throwable throwable) {
//網(wǎng)絡(luò)請求失敗的回調(diào)方法
Log.i(“TAG”, “請求失敗:” + throwable.getMessage());
}
});
其他界面操作和之前的Android中的內(nèi)容一致。
3、RxJava
簡單來說,用來處理事件和異步任務(wù),在很多語言上都有實(shí)現(xiàn),RxJava是Rx在Java上的實(shí)現(xiàn)。
原理
RxJava最基本的原理是基于觀察者模式來實(shí)現(xiàn)的。通過Obserable和Observer的機(jī)制,實(shí)現(xiàn)所謂響應(yīng)式的編程體驗(yàn)。
特點(diǎn)
RxJava在編程中的實(shí)現(xiàn)就是一種鏈?zhǔn)秸{(diào)用,做了哪些操作,誰在前誰在后非常直觀,邏輯清晰,代碼維護(hù)起來非常輕松。
RxJava也是一個在github上的庫,github地址如下:
基于此,還有一個RxAndroid,github地址如下:
RxJava和RxAndroid的關(guān)系
RxAndroid是RxJava的一個針對Android平臺的擴(kuò)展,主要用于 Android 開發(fā)。
基本概念
RxJava 有四個基本概念:
Observable:可觀察者,即被觀察者Observer:觀察者subscribe:訂閱事件
這四個概念之間的邏輯關(guān)系是:Observable和Observer通過subscribe方法實(shí)現(xiàn)訂閱關(guān)系,從而Observable可以在需要的時候發(fā)出事件來通知Observer。
事件
RxJava 的事件回調(diào)方法主要包含以下幾個:
onNext:普通的事件onCompleted:事件隊列完結(jié)。RxJava 不僅把每個事件單獨(dú)處理,還會把它們看做一個隊列。RxJava 規(guī)定,當(dāng)不會再有新的 onNext 發(fā)出時,需要觸發(fā) onCompleted 方法作為標(biāo)志。:事件隊列異常。在事件處理過程中出異常時, 會被觸發(fā),同時隊列自動終止,不再允許再有事件發(fā)出。在一個正確運(yùn)行的事件序列中, onCompleted和 有且只有一個,并且是事件序列中的最后一個。需要注意的是,onCompleted() 和 () 二者也是互斥的,即在隊列中調(diào)用了其中一個,就不應(yīng)該再調(diào)用另一個。
數(shù)據(jù)庫操作框架
在開發(fā)時,本地數(shù)據(jù)庫可以起到緩存數(shù)據(jù)和存儲業(yè)務(wù)數(shù)據(jù)的作用,隨著技術(shù)的成熟,不斷推出了有很多關(guān)于數(shù)據(jù)庫的操作框架。比較常見的數(shù)據(jù)庫操作框架有諸如:GreenDao,OrmLite 和 ActiveAndroid,DBFlow等。
GreenDAO
GreenDAO是一個開源的 Android ORM(“對象/關(guān)系映射”),通過 ORM(稱為“對象/關(guān)系映射”),在我們數(shù)據(jù)庫開發(fā)過程中節(jié)省了開發(fā)時間!
GreenDao的官方文檔地址如下:
GreenDao的作用
通過 GreenDao,我們可以更快速的操作數(shù)據(jù)庫,我們可以使用簡單的面相對象的API來存儲,更新,刪除和查詢 Java 對象。這款數(shù)據(jù)庫操作框架的特點(diǎn)是:
高性能,在官方的統(tǒng)計數(shù)據(jù)中,GreenDao在GreenDao,OrmLite 和 ActiveAndroid三個框架中,讀、寫、更新操作效率均表現(xiàn)第一。易于使用的強(qiáng)大 API,涵蓋關(guān)系和連接。內(nèi)存消耗較小。安全:greenDAO 支持 SQLCipher,以確保用戶的數(shù)據(jù)安全;
核心概念
GreenDao 的核心類有三個:分別是:
DaoMaster:保存數(shù)據(jù)庫對象(SQLiteDatabase)并管理特定模式的 DAO 類(而不是對象)。它有靜態(tài)方法來創(chuàng)建表或刪除它們。它的內(nèi)部類 OpenHelper 和DevOpenHelper 是 SQLiteOpenHelper 實(shí)現(xiàn),它們在 SQLite 數(shù)據(jù)庫中創(chuàng)建模式。DaoSession:管理特定模式的所有可用 DAO 對象,您可以使用其中一個getter方法獲取該對象。DaoSession 還提供了一些通用的持久性方法,如實(shí)體的插入,加載,更新,刷新和刪除。XXXDao:數(shù)據(jù)訪問對象(DAO)持久存在并查詢實(shí)體。對于每個實(shí)體,greenDAO 生成DAO。它具有比 DaoSession 更多的持久性方法。Entities:可持久化對象。通常, 實(shí)體對象代表一個數(shù)據(jù)庫行使用標(biāo)準(zhǔn) Java 屬性(如一個POJO 或 JavaBean )。
使用
按照官方的文檔和github上的說明可以實(shí)現(xiàn)greendao的使用。
首先進(jìn)行的是依賴,對于greenDao,有兩個地方需要設(shè)置,分別是項(xiàng)目根目錄中的 build.gradle,還有module中的build.gradle。
classpath ‘org.greenrobot:greendao-gradle-plugin:3.3.0’ // add plugin
在項(xiàng)目根目錄中的build.gradle目錄中寫這句話的意思是添加greenDao的插件。
在項(xiàng)目module中的build.gradle中也需要進(jìn)行配置,有兩個地方需要設(shè)置,如下圖所示:
apply plugin: ‘org.greenrobot.greendao’ //開頭加入該代碼
dependences{
implementation ‘org.greenrobot:greendao:3.2.0’
}
然后就可以使用了。
bean實(shí)體
可以在項(xiàng)目中創(chuàng)建自己業(yè)務(wù)需要的實(shí)體類,并通過注解來設(shè)置是實(shí)體類,字段約束等內(nèi)容。然后點(diǎn)擊Android Studio中的Make module,即可自動生成XXXDao代碼,以此來方便開發(fā)者的操作。生成的XXXDao類,不可修改和編輯,是自動生成的。
ORMLite
ORMLite框架是另外一款A(yù)ndroid開發(fā)中可以使用的數(shù)據(jù)庫操作框架。該框架的文檔地址如下:
該框架的文檔準(zhǔn)備的不是特別友好,此處不再贅述。
總結(jié),所有的框架原理幾乎都相差不大,只是操作有所差異。
視圖注入框架
在Android項(xiàng)目開發(fā)過程中,有太多的頁面需要布局完成,同時在代碼中需要些大量的findviewbyid的操作,來實(shí)現(xiàn)控件的解析。于是就有人想能否輕松一些,解放雙手節(jié)省時間,干一些其他有意義的事情,于是ButterKnife就來了。
ButterKnife是一個專注于Android系統(tǒng)的View注入框架,可以減少大量的findViewById以及setOnClickListener代碼,可視化一鍵生成。
該項(xiàng)目在github上的地址如下:
這個框架的優(yōu)勢也非常明顯:
強(qiáng)大的View綁定和Click事件處理功能,簡化代碼,提升開發(fā)效率方便的處理Adapter里的ViewHolder綁定問題運(yùn)行時不會影響APP效率,使用配置方便代碼清晰,可讀性強(qiáng)
使用
首先是設(shè)置依賴,在build.gradle中進(jìn)行依賴設(shè)置:
implementation ‘com.jakewharton:butterknife:10.2.1’
annotationProcessor ‘com.jakewharton:butterknife-compiler:10.2.1’
需要注意,該框架要求Java環(huán)境1.8版本以上,SDK版本在26以上,因此在使用到的module中的build.graldle文件中,還必須添加如下代碼配置:
apply plugin: ‘com.jakewharton.butterknife’
android{
//…
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
//…
}
另外,還必須在項(xiàng)目根目錄中的build.gradle文件中,添加該框架的插件,如下圖所示:
dependences{
classpath ‘com.jakewharton:butterknife-gradle-plugin:10.2.1’
}
然后即可在代碼中進(jìn)行使用了。
在使用該框架的頁面進(jìn)行綁定諸如,如下所示代碼:
ButterKnife.bind( this) ;
主要的功能
@BindView():控件id 注解,解放雙手,不用再每個控件都寫一遍findviewById@BindViews():多個控件id 的注解,括號內(nèi)使用花括號包括多個id即可,中間用,分割開在Fragment中使用,綁定Fragment。@BindString():綁定字符串@BindArray:綁定數(shù)組@BindBitmap:綁定bitmap資源@OnClick、@OnLongClick:綁定點(diǎn)擊事件和長按事件…還有很多
插件安裝
如果是頁面很復(fù)雜,一個一個寫B(tài)indView也很費(fèi)勁,在Android Studio中,可以安裝一個ButterKnife的插件,安裝該插件后,可以在Studio中直接將對應(yīng)的布局中的所有控件均給自動生成。
注意,在進(jìn)行自動生成時,鼠標(biāo)要放在布局文件上。
注意事項(xiàng)
ButterKnife框架在使用時,要求的版本比較高,包括Java的版本也有限制。因此,如果計劃在項(xiàng)目中使用,要提前做好預(yù)備工作,以防止對已有項(xiàng)目和業(yè)務(wù)帶來不必要的麻煩,反而影響工作進(jìn)度。