Android?Studio打包?aar實現(xiàn)步驟示例詳解
引言
演示Demo中創(chuàng)建了兩個 Library Module,其中A不包含第三方依賴庫,B包含;筆者將在下面介紹兩種類型的打包,并在app module中引用
項目目錄
一、不包含第三方依賴的打包
如果需要打包的module中沒有引入任何的第三方依賴庫,或者打包出來的aar在其他項目中并不需要用到依賴的三方庫,可以使用該方式打包;否則請看下面 包含第三方依賴的打包
1. Android Studio 打開右側(cè)的 Gradle 面板,選擇需要打包的module —> Tasks —> build, 雙擊 assemble
assemble 打包 aar
2. Build Successed 之后,將會在module的build/outputs/aar目錄下生成 debug 和 release 兩個版本的 aar包
3. 在 app module 中引用 libraryA,先將剛才生成的aar拷貝到 app module 的 libs目錄下
4. 在打開app module 的 build.gradle, 添加如下紅色框中內(nèi)容
添加 aar 依賴
repositories { flatDir{ dirs 'libs' } } compile(name: 'librarya-debug', ext: 'aar')
二、包含第三方依賴的打包
如果library中引用了第三方的依賴包,再采用上面的方式,編譯時將會提示說一些第三方的類文件找不到了。所以此時需要將library打成本地或遠程的aar倉庫,然后在項目中引用;
1. 打開 library 的 build.gradle 文件,在最外層加入如下內(nèi)容
apply plugin: 'maven' // 省略其他配置 uploadArchives{ repositories.mavenDeployer{ // Ubuntu本地倉庫路徑, Windows 為(url:"file://D://***/***/***/") repository(url:"file:/home/jinyx/develop/other/") // 唯一標識 pom.groupId = "com.jinyx" // 項目名稱 pom.artifactId = "libraryB" // 版本號 pom.version = "1.0" } }
2. 同樣的,打開Android Studio右側(cè)的Gradle面板,雙擊 module下面的 Tasks/upload/uploadArchives
上傳倉庫
3. BUILD SUCCESSFUL之后,本地剛才配置的倉庫路徑中將會生成aar相關(guān)的文件
生成本地aar倉庫
4. 在app module中引用aar,首先在根目錄的 build.gradle 的倉庫配置中加入本地倉庫地址,然后在app module 的bulid.gradle 中添加 項目依賴
// 添加到 root 的 build.gradle maven{ url 'file:/home/jinyx/develop/other/' } // 添加到 app 的 build.gradle,注意名字規(guī)則和上面配置本地倉庫之間的關(guān)聯(lián) implementation 'com.jinyx:libraryB:1.0'
遠程倉庫的就不說了,只是將上面配置的倉庫地址 換成線上的
三、補充說明
- 打包的module需要是 library,如果是 application的module,需要將 build 配置中的 apply plugin: 'com.android.application' 替換成 apply plugin: 'com.android.library',并且去掉applicationId
- 打包的module下的清單文件,application標簽下的android:name、android:roundIcon、android:icon三個屬性需要移除,避免和引用的項目中的清單文件產(chǎn)生沖突。同樣的,由于aar將資源文件也打包在里面,所以需要避免和引用的項目重名,造成資源沖突
- 如果是打包的app模塊,一般會有自定義的Application,用于一些SDK的初始化等操作,但是上面說到android:name屬性需要移除,所以引用aar的項目的application,需要繼承aar中原先的application,或者是實現(xiàn)里面的初始化等內(nèi)容
- 上面提到,application模塊打包成aar時,需要移除applicationId,所以問題來了;Android7.0對文件訪問的限制,需要添加 File Provider,其中使用差值表達式引用了applicationId
<provider android:name="android.support.v4.content.FileProvider" android:authorities="${applicationId}.file.provider" android:grantUriPermissions="true"> <meta-data android:name="android.support.FILE_PROVIDER_PATHS" android:resource="@xml/boxing_file_provider" /> </provider>
如果 build.gradle 中沒有定義 applicationId,那么編譯時會把 AndroidManfest 中的packageName 作為 applicationId
以上就是Android Studio 打包 aar的詳細內(nèi)容,更多關(guān)于Android Studio 打包 aar的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解關(guān)于Android Studio中安裝和gradle的一些坑
本篇文章主要介紹了關(guān)于Android Studio中安裝和gradle的一些坑,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10Android?14新功能HighLights快速實現(xiàn)文本高亮
這篇文章主要為大家介紹了Android?14新功能HighLights快速實現(xiàn)文本高亮示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03Android調(diào)用系統(tǒng)自帶的分享功能實例代碼
本篇文章主要介紹了Android調(diào)用系統(tǒng)自帶的分享功能實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-04-04Input系統(tǒng)按鍵事件的分發(fā)處理示例詳解
這篇文章主要為大家介紹了Input系統(tǒng)按鍵事件的分發(fā)處理示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01