android第三方库格式,【原创】Android 引用第三方库文件大全

【原创】Android 引用第三方库文件大全

【原创】Android 引用第三方库文件大全

不知不觉,使用Android Studio开发App已有一段时间了,接触到了各式各样的第三方库文件的引入,也是时候总结一波了。

使用android Studio开发Android应用时,避免不了需要借助Gradle引入各式各样的第三方库文件,帮助我们更好的开发App,常见的引入方式有:Jar文件,so文件,Library库文件,aar文件,远程jcenter、maven仓库文件。这几种引入方式各有利弊,对应的gradle配置也有所不同,本文根据平时的使用经验,做一个简单的总结,帮助大家更好的利用Gradle引入第三方库文件。

jar文件

将jar文件复制至app module目录下的libs文件夹下,然后打开app module目录下的build.gradle配置文件,在dependencies项中添加配置命令,这里有两种配置方式可供选择:

一次性引入libs目录下所有jar文件compile fileTree(include: ['*.jar'], dir: 'libs')11单个逐一引入jar文件compile files('libs/universal-image-loader-1.8.6-with-sources.jar')11

so文件

Gradle 旧版本

将so文件(包含arm64等文件夹)复制app module下面的libs文件夹中,和jar文件类似,然后在build.gradle的android栏目下添加一个task:指定so文件的目录,并将其转化为Jar文件。命令如下:

task nativeLibsToJar(type: Zip, description: "create a jar archive of the native libs") {

destinationDir file("$projectDir/libs")

baseName "Native_Libs2"

extension "jar"

from fileTree(dir: "libs", include: "**/*.so")

into "lib"

}

tasks.withType(JavaCompile) {

compileTask -> compileTask.dependsOn(nativeLibsToJar)

}1

2

3

4

5

6

7

8

9

10

111

2

3

4

5

6

7

8

9

10

11Gradle 新版本

新版Gradle实现了自动打包编译so文件的功能,并且为so文件指定了默认的目录app/src/main/jniLibs,当然默认是没有这个文件夹的,我们只需要新建一个jniLibs文件夹,并将so文件复制到该文件夹下,编译运行即可。

通常,为了更好地管理第三方库文件,或者更简单地将Eclipse项目转化为Android Studio项目,建议将jar文件和so文件放在一起,统一搁置在app/libs目录下,此时,我们只需要在build.gradle的android一栏中添加如命令,指定so文件的目录即可:

sourceSets {

main {

jniLibs.srcDirs = ['libs']

}

}1

2

3

4

51

2

3

4

5

通过这种方式,编译过后,将项目目录切换至Android试图,可以看到,app目录下多了一个jniLibs文件夹,里面包含了引入的so文件和jar包,如下图所示,表示集成成功。

174c3f13a581f201eab597431e555b7a.png

Library库文件

将第三方Library库文件复制到项目根目录下,打开项目根目录下的settings.gradle文件,添加配置命令,如:

include ':app', ':PullToRefresh'11

然后打开app module目录下的build.gradle,添加配置命令,如:

compile project(':PullToRefresh')11

小技巧:推荐在项目根目录下新建一个文件夹,如extras文件夹,将所有Library库文件都复制到该文件下,方便统一浏览管理,这样上面两步对应的配置命令将变成:

include ':app', ':extras:PullToRefresh'11

compile project(':extras:PullToRefresh')11

aar文件

aar其实也是一个压缩文件,相比jar文件,它能够含带res资源文件等,aar文件的引入方式有两种:

Module形式引入

选择File菜单,或者打开Project Structure界面,添加新的Module(New Module…),选择Import

.JAR/.AAR Package,选择目标aar文件导入。导入之后,在项目根目录下会自动生成一个新的文件夹放置aar文件及其配置文件,如:

c7f15878cc60138acf9264b453ce7036.png

然后打开app module目录下的build.gradle配置文件,在dependencies依赖项中添加配置即可:

compile project(':qiniu-android-sdk-7.2.0')11

注意:这种引入方式无法查看aar文件中的代码和资源等文件。

libs目录中引入

将aar文件复制到app module目录下的libs文件夹中,然后打开app module目录下的build.gradle配置文件,在android一栏中添加依赖:

repositories {

flatDir {

dirs 'libs'

}

}1

2

3

4

51

2

3

4

5

然后再在dependencies一栏中添加:

compile(name:'qiniu-android-sdk-7.2.0', ext:'aar')11

对应完整的app module目录下的build.gradle配置文件如:

apply plugin: 'com.android.application'

android {

compileSdkVersion 23

buildToolsVersion "23.0.2"

defaultConfig {

applicationId "com.feng.demo"

minSdkVersion 11

targetSdkVersion 23

versionCode 1

versionName "1.0.0"

}

buildTypes {

release {

minifyEnabled false

proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'

}

}

repositories {

flatDir {

dirs 'libs'

}

}

}

dependencies {

compile fileTree(include: ['*.jar'], dir: 'libs')

testCompile 'junit:junit:4.12'

compile 'com.android.support:appcompat-v7:23.3.0'

compile project(':extras:PullToRefresh')

compile 'com.squareup.okhttp3:okhttp:3.2.0'

compile(name:'qiniu-android-sdk-7.2.0', ext:'aar')

}1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

381

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

重新同步,编译工程,然后可以在app的build目录下生成对应aar的临时文件,可以看到aar文件中的jar文件、资源文件等,看上去更像是一个解压缩文件夹:

aa953039aef38179e62c91d7735d3495.png

jcenter、maven仓库文件

在项目根目录的build.gradle文件中添加仓库,如:

buildscript {

repositories {

jcenter()

}

dependencies {

classpath 'com.android.tools.build:gradle:2.1.0'

}

}

allprojects {

repositories {

jcenter()

}

}

task clean(type: Delete) {

delete rootProject.buildDir

}1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

181

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

然后再各个Module的build.gradle配置文件的dependencies项中添加依赖,格式为`compile

‘name:version’`,如:

compile 'com.squareup.okhttp3:okhttp:3.2.0'

因为AndroidStuduio加入对Library Module的安全管理机制,所以不能直接右键项目找到Delete(Delete菜单压根找不到)进行删除。

解决办法:在项目列表直接右键你要删除的Library Module(其他类型Module也可以这样操作),找到菜单Open Module Settings,在弹出的Project Structure窗口中找到要删除的Library Module,点击左上角的 - 号图标,移除后点击OK,这时Library Module 失去依赖,最后右键项目中的Library Module 这时可以看到Delete菜单了,点击进行最后一步的删除,搞定!

11

因为AndroidStuduio加入对Library Module的安全管理机制,所以不能直接右键项目找到Delete(Delete菜单压根找不到)进行删除。

解决办法:在项目列表直接右键你要删除的Library Module(其他类型Module也可以这样操作),找到菜单Open Module Settings,在弹出的Project Structure窗口中找到要删除的Library Module,点击左上角的 - 号图标,移除后点击OK,这时Library

Module 失去依赖,最后右键项目中的Library Module 这时可以看到Delete菜单了,点击进行最后一步的删除,搞定!

因为AndroidStuduio加入对Library Module的安全管理机制,所以不能直接右键项目找到Delete(Delete菜单压根找不到)进行删除。

【原创】Android 引用第三方库文件大全相关教程

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值