前言:写此文章的目的是为了梳理并加强自己对于导入第三方lib包细节知识的记忆。
我们平时在开发的过程中,都会遇到要实现某一个特效或者具体的功能,如android仿iOS滚轮效果,如实现分享等第三方平台功能,而这些我们如果全部都自己来Coding的话,估计费老鼻子劲了,所以都会从网上找一些开源的、好用的、成熟的主要是省事的第三方lib包导入系统,再次就梳理一下在导包的过程中可能遇到的问题。
项目引入第三方代码有几种方式,分别是开源的、直接集成好的jar包,原则上如果有源代码,就导入源代码,这样也方便个性化定制以及去除无用的代码。导入的形式又份本地的和网络的。下面就分别来说说各自的方式。
1、集成好的jar包
1.1 本地的jar包
一般情况我们都放到主工程下面的libs文件夹下,然后通过gradle编译
上图中,libs中除了文件夹类型后面再议外,看到很多*.jar文件,其中前面带箭头的代表已经通过编译了,不带箭头的,代表还没有编译过(没有编译过是不能引用其中的类)。下面我们来对其进行编译。
找到对应的build.gradle文件,看到其中有这么一段话
dependencies {
compile fileTree(include: ['*.jar'],dir:'libs')
compile project(':library')
compile files('libs/open_sdk_r5509_lite.jar')
compile files('libs/jcc-bate-0.7.3.jar')
}
这里重点说一下,其实有最上面的
compile fileTree(include: ['*.jar'],dir:'libs')
已经代表每一次gradle都会对libs文件夹下的jar文件进行编译,通俗点就是,导入一个jar包后,再点击一下
就妥妥的了。
就是说,上面的gradle文件可以改成
dependencies {
compile fileTree(include: ['*.jar'],dir:'libs')
compile project(':library')(这个是这个项目要导入的其他lib)
}
ps:在导入第三方jar包的时候,一定要注意其对应的是否有对应的so库,以及so库支持的CPU类型。有的时候第三方提供的so库对应的cpu类型不全,其中的坑谁用谁知道,放一个链接,不懂的童鞋可以看看:
http://blog.csdn.net/u013278099/article/details/50414438
http://blog.csdn.net/ouyang_peng/article/details/51168072
ps:上面链接我随手搜到的,如果有更好的到时候再更新。(估计也就是说说,别当真)
1.2 网络lib包
原谅我这无知的人对于网络上的仓库什么Maven Central什么JCenter之类的一知半解,为了不出洋相就不多阐述,但是还是很厚道的放一个链接:
http://blog.csdn.net/lu_xin_/article/details/51134849
我们通常使用的都是JCenter(如果遇到需要通过meven的人家的网站上都会详细说明一步一步怎么做,照做就好),贴出项目的build.gradle中的配置,就妥妥的使用了jcenter了:
allprojects{
repositories {
jcenter()
}
}
然后在application中的build.gradle中加上如下内容
然后再次gradle一下,就又不出意外的妥妥导入进去了
2、导入源代码
2.1 直接将源文件添加进项目代码中
这种方式很粗暴的说,比如直接把人家的类作为自己的写的类来使用,适用于特殊场景的,比如自定义图片、自定义简单的view,这种一般就是一个文件搞定,不是一个项目的方式导入进去。
2.2 将源代码整个项目作为lib库导入
这个就是项目源代码作为lib导入,首先需要声明其是一个lib而不是一个application,在其对应的build.gradle文件中最开头加上一句:
apply plugin:'com.android.library'
然后在整个项目的setting.gradle中include进去
include':wheel'
再次要注意的是,上面的写法代表这个项目是和我们的application是在同一个文件夹下的,如果这个项目(指的是wheel)作为一个公共的(多个项目都使用到的)lib被用到,每一个项目中都添加一遍也不利于变动修改,所以可以在项目的setting.gradle指定具体路径的项目作为lib:
include':wheel'
project(':wheel').projectDir = file("../android-tools/trunk/wheel")
上面..代表上级路径哈!
这也声明了是lib也include了进去,下一步就该使用了,在application中(或者在使用的项目lib中)的build.gradle文件下
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
compile project(':wheel')
}
这样就成了。
最后说一句大家都知道的东西,就是lib可以相互继承,把A、B项目作为lib后,如果B中的build.gradle添加了compile A项目,再在C项目中compile B,C项目也可以使用A项目的代码。