Android Studio如何打jar包和使用
- 生成jar包方式
- module方式生成jar方式
- 第一类修改主app的方式
- 第二类:通过新建module方式生成jar包
- 如何使用jar包
- aar生成并使用
- aar生成
- aar使用
之前有篇文章介绍了so库的生成和使用,看这里,但是,如果我们想把我们写的so库,通过java接口的方式提供出去,一般我们是打成jar包或者aar的形式提供,这篇文章介绍下如何打成jar包的,我们提供给使用方的是jar包和so库;
生成jar包方式
总的来说,AS打包生成jar包可以分成两类:
第一类是将应用模块application转换成库模块library后生成jar包
第二类是通过新建module库模块的方式生成jar包
module方式生成jar方式
今天我们主要讲解第二种方式;
第一类修改主app的方式
简单写下将应用模块application转换成库模块library后生成jar包步骤:
- build.gradle 将com.android.application改成com.android.library
- 注释掉applicationId
- AndroidManifest.xml中application配置的属性去掉
- 去掉Activity入口
后边的步骤和自建个module基本一致;
第二类:通过新建module方式生成jar包
新建module,File->New->New Module…
选择Android Library,
修改名称等配置,finish;
这个时候就可以在module中写代码了;
- 编写build文件
如图所示,我们暴露了一个getStrFromNative()的测试方法,这个方法是从so中获取了一个字符串,方法名和包名一定要跟so生成的时候一致;这样调用方调用native方法的时候才不会报错;
真正生成jar包的方法在build.gradle文件下修改;
task makeJar(type: Copy) {
//删除存在的
delete 'build/libs/jarsdk.jar'
//设置拷贝的文件
// from('build/intermediates/bundles/release/')
from('build/intermediates/aar_main_jar/release/')
//打进jar包后的文件目录
into('build/libs/')
//将classes.jar放入build/libs/目录下
//include ,exclude参数来设置过滤
//(我们只关心classes.jar这个文件)
include('classes.jar')
//重命名
rename ('classes.jar', 'jarsdk.jar')
}
makeJar.dependsOn(build)
将如上代码写到module模块下的build.gradle文件下的android闭包内;
2. 生成jar
添加完后就可以生成啦,这里也有两种方式:
(1)通过cmd命令行方式
在AndroidStudio->Terminal中输入命令:
gradlew makeJar
(2)
通过Android Studio右边的Gradle的makeJar task;
在module下的other目录里寻找到makejar,双击执行;
如图所示就是成功了;
如上图所示,在build->libs目录下,jarsdk就是生成的jar包;
如何使用jar包
将jar包拷贝到要使用的工程中,app->libs目录下;
在app->src->main目录下新建jniLibs,将so库拷贝过来,如图:
如果生成so库请参见这篇:Android JNI编程并生成so库
build.gradle中,android闭包下添加
sourceSets {
main {
jniLibs.srcDirs = ['src/main/jniLibs', 'libs']
}
}
dependencies闭包下添加
implementation files('libs/jarsdk.jar')
或者
implementation fileTree(dir: 'libs', include: ['*.jar'])
然后代码里就可以使用我们暴露的getStrFromNative()方法了;
case R.id.btn_test:
Toast.makeText(getApplicationContext(), NdkTools.getStrFromNative(), Toast.LENGTH_LONG).show();
break;
说明成功了;
aar生成并使用
aar生成
aar的生成比较简单,参考第二步创建的module,新创建一个module,然后编写自己需要的代码;
还是编写暴露的代码,如第二步中的getStrFromNative()方法;
引入需要的so库,新建jniLibs文件夹,把so库拷贝进来
然后就可以makeproject
然后就在build-outputs-aar文件下就可以看到生成的aar文件;
aar使用
在使用的工程中,把aar拷贝到libs目录下:
并且在build.gradle文件中引入
implementation files('libs/tts-debug.aar')
同步一下,就可以使用了getStrFromNative()方法了;
总结一下:
aar的生成和使用比较简单,也是google为了方便大家并推荐的方式;而且aar里面可以包含资源和so;
jar包的方式稍微麻烦一点,并且如果是提供sdk的话还得提供两部分代码,一个jar包和一个so库;