android開源界面
1. 32個實用酷炫的Android開源UI框架
1.Side-Menu.Android
分類側滑菜單 , Yalantis 出品。
項目地址: https://github.com/Yalantis/Side-Menu.Android
2.Context-Menu.Android
可以方便快速集成漂亮帶有動畫效果的上下文菜單, Yalantis 出品。
項目地址: https://github.com/Yalantis/Context-Menu.Android
3.Pull-to-Refresh.Rentals-Android
提供一個簡單可以自定義的 下拉刷新 實現,Yalantis 出品。
項目地址: https://github.com/Yalantis/Pull-to-Refresh.Rentals-Android
4.Titanic
可以顯示水位上升下降的TextView
項目地址: https://github.com/RomainPiel/Titanic
5.AndroidSwipeLayout
滑動Layout ,支持單個View,ListView,GridView
項目地址: https://github.com/daimajia/AndroidSwipeLayout
Demo地址: Download Demo
6.Android Typeface Helper
可以幫你輕松實現自定義字體的庫
項目地址: https://github.com/norbsoft/android-typeface-helper
7.android-lockpattern
Android的圖案密碼解鎖
項目地址: https://code.google.com/p/android-lockpattern/
Demo地址: https://play.google.com/store/apps/details?id=group.pals.android.lib.ui.lockpattern.demo
文檔介紹: https://code.google.com/p/android-lockpattern/wiki/QuickUse
APP示例:Android開機的圖案密碼解鎖,支付寶的密碼解鎖
8.ToggleButton
狀態切換的 Button,類似 iOS,用 View 實現
項目地址: https://github.com/zcweng/ToggleButton
9.WilliamChart
繪制圖表的庫,支持LineChartView、BarChartView和StackBarChartView三中圖表類型,並且支持 Android 2.2及以上的系統。
項目地址: https://github.com/diogobernardino/WilliamChart
Demo地址: https://play.google.com/store/apps/details?id=com.db.williamchartdemo
Demo項目: https://github.com/diogobernardino/WilliamChart/tree/master/sample
10.實現滑動ViewPager漸變背景色
項目地址: https://github.com/TaurusXi/GuideBackgroundColorAnimation
11.Euclid
用戶簡歷界面, Yalantis 出品。
項目地址: https://github.com/Yalantis/Euclid
12. InstaMaterial
Instagram的一組Material 風格的概念設計
項目地址: https://github.com/frogermcs/InstaMaterial
13. SpringIndicator
使用bezier實現粘連效果的頁面指示
項目地址: https://github.com/chenupt/SpringIndicator
14. BezierDemo
仿qq消息氣泡拖拽 消失的效果。
項目地址: https://github.com/chenupt/BezierDemo
15. FoldableLayout
折疊的信紙被打開一樣的動畫效果
項目地址: https://github.com/alexvasilkov/FoldableLayout
16.Taurus
下拉刷新,Yalantis 出品。(是不是有點似曾相識呢?)
項目地址: https://github.com/Yalantis/Taurus
17. PersistentSearch
在點擊搜索的時候控制項在原有位置顯示輸入框。
項目地址: https://github.com/Quinny898/PersistentSearch
18. circular-progress-button
帶進度顯示的Button
項目地址: https://github.com/dmytrodanylyk/circular-progress-button
19. discrollview
當上下滾動的時候子元素會呈現不同動畫效果的scrollView,網頁上稱之為:視差滾動
項目地址: https://github.com/flavienlaurent/discrollview
20. sweet-alert-dialog
一個帶動畫效果的 自定義對話框樣式
項目地址: https://github.com/pedant/sweet-alert-dialog
21. android-floating-action-button
Material Desig風格的 浮動操作按鈕
項目地址: https://github.com/futuresimple/android-floating-action-button
22. android-collapse-calendar-view
可以在月視圖與周視圖之間切換的calendar控制項
項目地址: https://github.com/blazsolar/android-collapse-calendar-view
22. android-collapse-calendar-view
可以在月視圖與周視圖之間切換的calendar控制項
項目地址: https://github.com/blazsolar/android-collapse-calendar-view
23. NumberProgressBar
個簡約性感的數字進度條
項目地址: https://github.com/daimajia/NumberProgressBar
24. CircularProgressView
CircularProgressView 是通過自定義view的方式實現的Material風格的載入提示控制項,兼容任何版本。
項目地址: https://github.com/rahatarmanahmed/CircularProgressView
25. OriSim3D-Android
opengl 實現了各種折紙效果,模擬了從一張紙折疊成一條船的整個過程
項目地址: https://github.com/RemiKoutcherawy/OriSim3D-Android
26、萬能日歷控制項:CalendarView
GitHub: https://github.com/huanghaibin-dev/CalendarView
中文使用文檔: https://github.com/huanghaibin-dev/CalendarView/blob/master/QUESTION_ZH.md
27、大圖查看器: BigImage ImageView ViewPager
Github: https://github.com/SherlockGougou/BigImageViewPager
地址: https://www.jianshu.com/p/b15e65791c3f
支持超長圖、超大圖的圖片瀏覽器,優化內存,支持手勢放大、下拉關閉、查看原圖、載入百分比、保存圖片等功能。現已支持androidx。
28、安卓工具包androidUntilCode(安卓必備)
Github: https://github.com/Blankj/AndroidUtilCode/blob/master/lib/utilcode/README-CN.md
29、萬能適配器-BRAVH
官網: http://www.recyclerview.org
GitHub: https://github.com/CymChad/BaseRecyclerViewAdapterHelper
RecyclerView
作為Android最常用的控制項之一,是否常常為「她」操碎了心
BRVAH受益群體是所有Android開發者,希望更多開發者能夠一起來把這個項目做得更好幫助更多人
30、智能刷新控制項--SmartRefreshLayout
GitHub: https://github.com/scwang90/SmartRefreshLayout
中文: https://gitee.com/scwang90/SmartRefreshLayout
SmartRefreshLayout以打造一個強大,穩定,成熟的下拉刷新框架為目標,並集成各種的炫酷、多樣、實用、美觀的Header和Footer。 正如名字所說,SmartRefreshLayout是一個「聰明」或者「智能」的下拉刷新布局,由於它的「智能」,它不只是支持所有的View,還支持多層嵌套的視圖結構。 它繼承自ViewGroup 而不是FrameLayout或LinearLayout,提高了性能。 也吸取了現在流行的各種刷新布局的優點,包括谷歌官方的 SwipeRefreshLayout , 其他第三方的 Ultra-Pull-To-Refresh 、 TwinklingRefreshLayout 。 還集成了各種炫酷的 Header 和 Footer。
31、內存泄漏檢測工具--leakcanary
使用方式: https://www.jianshu.com/p/b83ddffcb3b5
LeakCanary是Square公司基於MAT開源的一個工具,用來檢測Android App中的內存泄露問題。官方地址: https://github.com/square/leakcanary
32、 1218683832 / AndroidSlidingUpPanel
SlidingUpPanelLayout:可以上下滑動的菜單布
https://github.com/1218683832/AndroidSlidingUpPanel
2. 機友分享 | 導入機智雲Android開源項目的正確姿勢
以下文章來源於小雨編程 ,作者小雨tt
「使用機智雲AIoT平台支持項目自生成APP源碼,即可輕松解決Android開源項目啦,」開發者下載源碼後,只需要優化UI和設計設備控制界面控制邏輯,源碼的控制頁面編寫了機智雲SDK控制設備的標准流程,APP源碼二次開發過程中只需按照該流程進行相關代碼的優化即可快速完成針對自身產品的智能控制APP。
因此只要我們將源碼工程文件成功導入Android Studio,那麼我們便可以自由定製我們的應用程序,那麼如何正確導入到Android Studio中,編譯成功並在真機上運行呢?
01下載項目
在機智雲官網,我們定義好數據點後,在服務->應用開發子菜單中,下載工程文件。
機智雲APP代碼自動生成服務介紹:http://docs.gizwits.com/zh-cn/UserManual/devApp.html
02方法
由於本地環境與開源工程文件中不同,理論上我們把開源工程文件中的環境修改成和我們本地相同的就可以順利導入了。
為了正確修改開源工程配置文件,我們可以新建一個本地工程文件夾,對照參考。
第一步
修改根目錄下的build.gradle文件
將開源工程項目中的build.gradle與本地工程保持一致。
第二步
修改gradle/wrapper文件夾里gradle-wrapper.properties配置文件
將distributionUrl中的gradle版本保持與本地項目一致;
第三步
我們再修改app目錄下的build.gradle文件
這時候開源項目與我們的本地項目區別就有點大了,我們只需擇其重點進行修改
將機智雲版 本的 compileSdkVersion , buildToolsVersion , minSdkVersion , targetSdkVersion 與本地保持一致;這里由於自2018年底開始Android已經拋棄了 compile ,所以這里我們需要將 compile 換成 implementation ,同時將 com.android.support:design , com.android.support:appcompat 換成與本地版本相一致的28.0.0版本
下面是修改之後的版本:
第四步
導入項目再配置
打開AndroidStudio修改 基本的配置參數已經修改的差不多了,這時我們導入項目試一試,打開Android Studio歡迎界面,點擊Open an existing Android Studio project;
在工程界面工具欄,點擊編譯按鈕,這時候可能還會 報 一些小錯誤,比如:
它表示最小開發版本不需要在清單文件中解釋,我們只需點擊藍色下劃線,跳轉到如下界面。
點擊方框內容,打開清單文件
刪除改行,再Try Again重新同步一下gradle工程。
第五步
修改部分過時的函數
點擊小錘子重新編譯一下工程,此時仍會報如下錯誤:
這里報錯(找不到符號變數 MAXRIX_SAVE_FLAG ) 這是因為我們的sdk版本較高,新的sdk已經對之前老版本里的方法進行了修改,調用 canvas.save(Canvas.CLIP_SAVE_FLAG) ;方法編譯器報錯,我們只需要 save() 方法里的參數刪除即可,直接調用 canvas.save() 方法就編譯通過了。
此時,我們的APP已經可以運行啦!
end..
這篇教程是以使用機智雲AIoT平台的源碼為例,如何正確的編譯項目。其實對於大多數網上的Android開源項目都可以用這種方法來導入。
錯過了#秋天的第一杯奶茶,那我們一起來敲代碼吧
今日份推薦,安排加購鴨..
中移Cat.1 4G DTU模組ML302-GC211支持OTA免開發快速接入機智雲
3. Android的手機系統是開源的,開源到底是什麼意思
開源,全稱為開放源代碼。市場上開源軟體層出不窮,很多人可能認為開源軟體最明顯的特點是免費,但實際上並不是這樣的,開源軟體最大的特點應該是開放,也就是任何人都可以得到軟體的源代碼,加以修改學習,甚至重新發放,當然是在版許可權制范圍之內。
開源主要的目的就是允許任何一個人來修改和完善它,使用開源的軟體都不需要繳納費用,不想windows操作系統那樣一套要兩千塊。
(3)android開源界面擴展閱讀
開源主要表現為管理成本、設計程序議題以及組織可信賴性等。首先就管理成本而言,主要是因為一旦計劃發展到一定程度,其創新、修正的質量必然變大,參與人數眾多,當然也會造成一定的管理成本,另外,整合、決策架構都會增高管理的成本。
其次就設計程序議題來看,其不斷釋出新版本,將造成消費者需要不斷重新安裝的困擾,並且由於其設計上通常較不關心友善的界面,會增加使用者的接近使用的難度。
4. 鴻蒙確實用了安卓開源項目代碼,但安卓套殼論卻是一戳即破的謊言
現在華為鴻蒙系統(Harmony OS)已經到了大規模推廣、搭載前的最後公測階段,已經有很多人升級到了鴻蒙,事實就擺在面前了,所以現在關於鴻蒙系統是PPT的說法,差不多都該很快消失了。
目前對鴻蒙系統的質疑聲音,又集中到了「安卓套殼」這個老話題上來,畢竟鴻蒙系統確實是全面兼容安卓APP,而且在日常界面上也和安卓系統很類似。很多所謂程序員就根據鴻蒙系統中確實有很多AOSP(安卓開源項目)的開源代碼來認定,鴻蒙系統就是安卓套個殼而已。
一、這樣的觀點,實際上從稍有知識產權、法律常識的角度看,根本就是不可能成立的。
難道一個強悍的谷歌公司,就沒有幾個律師(法務)懂這事?你以為谷歌強制要求的 安卓手機開機界面「Powered by android」 只是個擺設,或是個花架子沒用的?如果說誰家手機系統底層是安卓,卻不遵從這個規則,怕是早就被谷歌告進了法院。谷歌有多麼狠沒人不知道吧?要知道谷歌自家私有的GMS(谷歌移動服務),早就禁止華為手機安裝了。當時谷歌那可是步步緊逼,堅決把禁止華為使用GMS進行到底的力度。
放心吧,谷歌沒這么傻,華為更沒這么傻。如果鴻蒙系統不是完全自己開發的,華為有必要多此一舉? 華為現在的 「安卓+EMUI+HMS(華為移動服務)」模式 ,不也是用得好好的嗎? 而且,「安卓+EMUI+HMS」這個模式,只要華為想用安卓開源系統,還可以一直用下去,完全符合開源項目規則。
其實這也是目前小米、OPPO、vivo、三星等所有安卓系手機廠家都在做的,比如小米的安卓+MIUI等。況且,華為的EMUI也很強大,完全不比任何別家UI系統差。
二、即便是從軟體技術、軟體開源社區及開源軟體規則這些常識看,鴻蒙系統使用AOSP(安卓開源項目)的開源代碼不但合規,還是合情、合理的。
下面咱們來看看2021年1月下旬,華為消費者業務軟體部總裁、鴻蒙操作系統負責人王成錄接受采訪時,對鴻蒙系統全面、深入的介紹。王成錄這位資深「程序員」,應該是最有資格介紹鴻蒙系統的了。
這里王成錄還是把對鴻蒙系統的質疑歸結於理解不一致的問題。他說並不是所有安卓代碼都是谷歌開發的,安卓系統的絕大部分代碼來自開源社區。
鴻蒙也會吸收社區的優秀技術和代碼,用了AOSP(Android 開源項目)的開源代碼,就認定鴻蒙是安卓換了皮,說明這類吐槽者沒有太准確理解什麼是開源。開源系統的最大意義就在於大家都來貢獻代碼,大家都可以免費使用。而華為本身就是安卓開源系統最大的貢獻者之一。
王成錄說到 今年10月,鴻蒙第三階段的開源代碼會上線,來自AOSP社區的、由谷歌貢獻的代碼就幾乎沒有了 。相信華為的這個時間表,那些吐槽的所謂「程序員」應該可以理解了。
由此可見, 鴻蒙系統是龐大的,特別是前期吸收開源社區的技術、代碼,都可以顯著提高系統開發的進程,華為何樂而不為呢?這個槽點,該破了。
類似的,鴻蒙系統對於安卓APP的兼容,也是這個連續性的道理。王成錄明確提到,現在鴻蒙生態的應用量(APP及開發者)還不夠多。他說谷歌安卓系統有約2000萬開發者,蘋果iOS有2400萬開發者,鴻蒙生態的開發者數量還差很多。所以, 在鴻蒙生態起步的初級階段,兼容安卓不但不該被吐槽,反而應該是一個妙招 。
當然華為也沒有忽視自有生態建設。華為選擇了中國應用市場(APP)下載量排名前200的廠家,一個個去溝通,已確定做方案的達到70%。鴻蒙生態建設非一日之功,早在緊張進行中。
這些吐槽的所謂程序員,要麼就是揣著明白裝糊塗,為了吐槽鴻蒙而裝糊塗;要麼根本就不是程序員,打著程序員的幌子,純粹就是為了吐槽鴻蒙而已。
三、最後做個善意提醒,現在用著安卓系統的手機廠家,也不要高興太早,或是暗自慶幸自己運氣好,沒有被谷歌打壓。
谷歌可是在一步步收緊對安卓系統的控制,說不定啥時候讓你交點兒使用費,怕是躲不開的。而且交點兒使用費,怕這還是好的。 要是哪天你也想真心實意做點兒技術活,也搞點兒高新 科技 ,難免要被美國盯上,難道就不怕和華為一樣也被禁掉GMS?多做點兒准備,不是壞事。
並且鴻蒙系統的微內核、軟匯流排、分布式架構的先進性,是安卓系統不可匹敵的。隨著鴻蒙系統生態進一步完善,加上華為鴻蒙系統的開放政策,相信用上更先進的系統,對任何廠商都有吸引力。用上中國自己的操作系統,何樂而不為?連谷歌都在開發安卓的替代系統Fuchsia了,難道還有人懷疑安卓必將被淘汰的結果嗎?
鴻蒙系統確實是個新事物,很多人對其缺乏認識是可以理解的。我們中國之前確實也沒有拿出一個成功的操作系統,鴻蒙系統突圍而出的難度的確很大,有些人缺乏信心也有可能。 但是現在華為有實力、有機會,鴻蒙成功就在眼前,我們還腿軟,就不該了。
5. android app開發中常用到哪些開源框架
在前面的課程中,隨著對Android體系的了解,已經可以進行正常的Android應用開發了。在Android開發中,同其他工程開發一樣,也經常使用一些提高效率的框架,本文我們做一個對比。這些框架,既包括:網路請求框架、也包括圖片載入庫框架、還包括資料庫操作等一些框架,總之,了解和熟悉這些框架,會對自己的開發效率有很大的提升和幫助。
網路請求框架
1、okHttp
在前文的學習中,我們已經了解過okHttp,是一個常用的網路載入庫。
2、Retrofit
介紹
Retrofit是一個很不錯的網路請求庫,該庫是square開源的另外一個庫,之前的okhttp也是該公司開源的。
Retrofit是基於OkHttp封裝的RESTful網路請求框架,使用註解的方式配置請求。優點是速度快,使用註解,callback函數返回結果自動包裝成java對象。官方自己的介紹說:
A type-safe REST client for Android and Java
該網路框架在github上的地址如下:https://square.github.io/retrofit/
要求
Retrofit支持的http方式方式包括 GET/POST/PUT/DELETE/HEAD/PATCH,Retrofit要求Java的版本是1.8+,Android應用的API版本應該在21+。
依賴
使用Retrofit庫,和其他庫一樣,首先需要設置依賴,依然是在build.gradle文件中設置依賴:
//添加retrofit庫依賴
implementation 『com.squareup.retrofit2:retrofit:2.1.0』
//添加gson轉換器
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、實例化Retrofit對象,使用的Builder的模式創建,如下代碼所示:
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(Constants.BASE_API)
.addConverterFactory(GsonConverterFactory.create())
.build();
注意,這里設置結構體轉換器,是可以直接把網路請求回來的數據轉換為Java結構體,這里設置的Gson解析器,因此要引入相應的轉換器支持庫。
3、得到介面對象,自己創建的全局的介面對象,並調用相應的介面,得到一個類似於請求Call對象。如下所示:
HttpServices httpServices = retrofit.create(HttpServices.class);
Call newsListCall = httpServices.getNewsList(「top」, Constants.API_KEY);
4、加入到請求隊列中,並設置回調方法:
newsListCall.enqueue(new Callback() {
@Override
public void onResponse(Call call, Response response) {
//網路請求成功的回調方法
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) {
//網路請求失敗的回調方法
Log.i(「TAG」, 「請求失敗:」 + throwable.getMessage());
}
});
其他界面操作和之前的Android中的內容一致。
3、RxJava
簡單來說,用來處理事件和非同步任務,在很多語言上都有實現,RxJava是Rx在Java上的實現。
原理
RxJava最基本的原理是基於觀察者模式來實現的。通過Obserable和Observer的機制,實現所謂響應式的編程體驗。
特點
RxJava在編程中的實現就是一種鏈式調用,做了哪些操作,誰在前誰在後非常直觀,邏輯清晰,代碼維護起來非常輕松。
RxJava也是一個在github上的庫,githubhttp://www.xingkongmj.com/news/id/62.html地址如下:https://github.com/ReactiveX/RxJava
基於此,還有一個RxAndroid,github地址如下:https://github.com/ReactiveX/RxAndroid
RxJava和RxAndroid的關系
RxAndroid是RxJava的一個針對Android平台的擴展,主要用於 Android 開發。
基本概念
RxJava 有四個基本概念:
Observable:可觀察者,即被觀察者Observer:觀察者subscribe:訂閱事件
這四個概念之間的邏輯關系是:Observable和Observer通過subscribe方法實現訂閱關系,從而Observable可以在需要的時候發出事件來通知Observer。
事件
RxJava 的事件回調方法主要包含以下幾個:
onNext:普通的事件onCompletedhttp://dachang.net/432717.html:事件隊列完結。RxJava 不僅把每個事件單獨處理,還會把它們看做一個隊列。RxJava 規定,當不會再有新的 onNext 發出時,需要觸發 onCompleted 方法作為標志。:事件隊列異常。在事件處理過程中出異常時, 會被觸發,同時隊列自動終止,不再允許再有事件發出。在一個正確運行的事件序列中, onCompleted和 有且只有一個,並且是事件序列中的最後一個。需要注意的是,onCompleted() 和 () 二者也是互斥的,即在隊列中調用了其中一個,就不應該再調用另一個。
資料庫操作框架
在開發時,本地資料庫可以起到緩存數據和存儲業務數據的作用,隨著技術的成熟,不斷推出了有很多關於資料庫的操作框架。比較常見的資料庫操作框架有諸如:GreenDao,OrmLite 和 ActiveAndroid,DBFlow等。
GreenDAO
GreenDAO是一個開源的 Android ORM(「對象/關系映射」),通過 ORM(稱為「對象/關系映射」),在我們資料庫開發過程中節省了開發時間!
GreenDao的官方文檔地址如下:http://www.xingkongmj.com/news/id/63.html
GreenDao的作用
通過 GreenDao,我們可以更快速的操作資料庫,我們可以使用簡單的面相對象的API來存儲,更新,刪除和查詢 Java 對象。這款資料庫操作框架的特點是:
高性能,在官方的統計數據中,GreenDao在GreenDao,OrmLite 和 ActiveAndroid三個框架中,讀、寫、更新操作效率均表現第一。易於使用的強大 API,涵蓋關系和連接。內存消耗較小。安全:greenDAO 支持 sqlCipherhttp://www.xingkongmj.com/news/id/64.html,以確保用戶的數據安全;
核心概念
GreenDao 的核心類有三個:分別是:
DaoMaster:保存資料庫對象(SQLiteDatabase)並管理特定模式的 DAO 類(而不是對象)。它有靜態方法來創建表或刪除它們。它的內部類 OpenHelper 和DevOpenHelper 是 SQLiteOpenHelper 實現,它們在 SQLite 資料庫中創建模式。DaoSession:管理特定模式的所有可用 DAO 對象,您可以使用其中一個getter方法獲取該對象。DaoSession 還提供了一些通用的持久性方法,如實體的插入,載入,更新,刷新和刪除。XXXDao:數據訪問對象(DAO)持久存在並查詢實體。對於每個實體,greenDAO 生成DAO。它具有比 DaoSession 更多的持久性方法。Entities:可持久化對象。通常, 實體對象代表一個資料庫行使用標准 Java 屬性(如一個POJO 或 JavaBean )。
使用
按照官方的文檔和github上的說明可以實現green的使用。
首先進行的是依賴,對於greenDao,有兩個地方需要設置,分別是項目根目錄中的 build.gradle,還有mole中的build.gradle。
classpath 『org.greenrobot:green-gradle-plugin:3.3.0』 // add plugin
在項目根目錄中的build.gradle目錄中寫這句話的意思是添加greenDao的插件。
在項目mole中的build.gradle中也需要進行配置,有兩個地方需要設置,如下圖所示:
apply plugin: 『org.greenrobot.greenhttp://www.xingkongmj.com/news/id/66.html』 //開頭加入該代碼
dependences{
implementation 『org.greenrobot:green:3.2.0』
}
然後就可以使用了。
bean實體
可以在項目中創建自己業務需要的實體類,並通過註解來設置是實體類,欄位約束等內容。然後點擊Android Studio中的Make mole,即可自動生成XXXDao代碼,以此來方便開發者的操作。生成的XXXDao類,不可修改和編輯,是自動生成的。
ORMLite
ORMLite框架是另外一款Android開發中可以使用的資料庫操作框架。該框架的文檔地址如下:https://ormlite.com/sqlite_java_android_orm.shtml
該框架的文檔准備的不是特別友好,此處不再贅述。
總結,所有的框架原理幾乎都相差不大,只是操作有所差異。
視圖注入框架
在Android項目開發過程中,有太多的頁面需要布局完成,同時在代碼中需要些大量的findviewbyid的操作,來實現控制項的解析。於是就有人想能否輕松一些,解放雙手節省時間,干一些其他有意義的事情,於是ButterKnife就來了。
ButterKnife是一個專注於Android系統的View注入框架,可以減少大量的findViewById以及setOnClickListener代碼,可視化一鍵生成。
該項目在github上的地址如下:http://www.xingkongmj.com/news/id/65.html
這個框架的優勢也非常明顯:
強大的View綁定和Click事件處理功能,簡化代碼,提升開發效率方便的處理Adapter里的ViewHolder綁定問題運行時不會影響APP效率,使用配置方便代碼清晰,可讀性強
使用
首先是設置依賴,在build.gradlehttp://dachang.net/432714.html中進行依賴設置:
implementation 『com.jakewharton:butterknife:10.2.1』
annotationProcessor 『com.jakewharton:butterknife-compiler:10.2.1』
需要注意,該框架要求Java環境1.8版本以上,SDK版本在26以上,因此在使用到的mole中的build.graldle文件中,還必須添加如下代碼配置:
apply plugin: 『com.jakewharton.butterknife』
android{
//…
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
//…
}
另外,還必須在項目根目錄中的build.gradle文件中,添加該框架的插件,如下圖所示:
dependences{
classpath 『com.jakewharton:butterknife-gradle-plugin:10.2.1』
}
然後即可在代碼中進行使用了。
在使用該框架的頁面進行綁定諸如,如下所示代碼:
ButterKnife.bind( this) ;
主要的功能
@BindView():控制項id 註解,解放雙手,不用再每個控制項都寫一遍findviewById@BindViews():多個控制項id 的註解,括弧內使用花括弧包括多個id即可,中間用,分割開在Fragment中使用,綁定Fragment。@BindString():綁定字元串@BindArray:綁定數組@BindBitmap:綁定bitmap資源@OnClick、@OnLongClick:綁定點擊事件和長按事件…還有很多
插件安裝
如果是頁面很復雜,一個一個寫BindView也很費勁,在Android Studio中,可以安裝一個ButterKnife的插件,安裝該插件後,可以在Studio中直接將對應的布局中的所有控制項均給自動生成。
注意,在進行自動生成時,滑鼠要放在布局文件上。
注意事項
ButterKnife框架在使用時,要求的版本比較高,包括Java的版本也有限制。因此,如果計劃在項目中使用,要提前做好預備工作,以防止對已有項目和業務帶來不必要的麻煩,反而影響工作進度。