前言:我们在使用AndroidStudio的时候,会经常用到第三方的代码库。引入第三方库的方式无非就是引入本地库和在线库两种(其实在线库也是先下载到本地再引用的)。在引用在线库的时候,只需在AS的app级的gradle里面添加一句话,例如:
compile 'com.android.support:appcompat-v7:26+'
就可以直接引用了。是不是也想以这种方式,将自己的库分享给别人引用呢,这篇博客教你。
通过翻看网上的大量资料,发现集成方式有两种:
(1)使用gradle-bintray-plugin
(2)使用bintray-release
二者的区别简介度娘一大把,我就不过多赘述了。我就简单说说最大区别,就是前者集成配置多且麻烦,后者配置简单易用。所以我就以后者的方式教大家如何集成。如果你在集成前就看到我这篇博客,恭喜你,弯路基本可以完全不用走了。如果你是根据网上一些文章尝试过集成,但是无奈中路的n多坑让你下不去手,此时如果你看到这篇博客,应该能给你很大帮助。
这里再说点题外话(不感兴趣的可以直接跳到下个知识点),就是这个账号的头像设置问题。(有坑指数A)
账号建立成功后,选择EditProfile:
你会发现头像这栏是无法直接通过上传图片来更改的。默认图片太丑,怎么办呢?
看到后面的change没有,点它,会外链到一个第三方的头像管理网站Gravatars
这个网站的作用就是你可以上传一些头像图片绑定到你指定的邮箱上面。然后Bintray那边就通过这种方式来显示头像。所以呢,你如果想自己的账号美美哒,还要注册一个该网站的账号。然后就点击sign in吧。结果呢发现该网站又是外链到一个叫WordPress.com账号来绑定账号的。是不是觉得又是一个坑。好吧,如果你觉得麻烦可以放弃了。如果还能坚持,那我们就继续。注册没有太大坑,关键是支持中文:
除了麻烦,其实注册还算比较轻松的:
那个Add Email Address可以添加自己的邮箱地址,Add a new Image可以上传自己喜欢的图片。上传的时候会提示你选择该图片的分级(是不是限制级),国外的分级制度还是比完善的。
这样的话,头像就算解决了。
至此,恭喜你,童鞋,万里长征可以开始了。
这个库,就是以后你上传你的安卓代码的地方,然后别人就在这里面引用你的库。
登录进你的bintray。
右上角头像那边有个下拉框,点击选择view profile
该页面的左边,选择Add New Repository
我们从上往下看:
(1)Chang Avatar是用来设置这个库的图标的。这里和设置账户头像不同,支持直接上传图片,注意不要太大,不然会解析不出来。
(2)接下来有两个选项,由于我们的是免费账号,只能选择Public,意思就是你上传的代码都是开源的。
(3)Name框这栏要注意了,这里是一个
。首先这个值就是你的库名字,这点好理解。然后,这个值还对应了你使用
bintray-release插件配置的一个参数repo name的值(在gradle-bintray-plugin中对应repo属性)。我为什么要说这是个坑。因为你看网上很多介绍的文章,都没有说过这个东西。而且在配置的时候也没提过那个属性。他们只是告诉你在Name这栏填maven,这就给很多小白造成一个错误的印象,就认为这里只能死填一个值,其实不然。填maven,是因为bintray-release插件配置的repo name默认属性就是maven(这点可以查阅一下官方的介绍文档),而那些文章又都没介绍过要设置这个属性,所以就完全“巧合”地建成功了。
(4)Type一项选择Maven吧,因为我们要上传的就maven库。
后面两个是可选的。根据你的需求就是选择填写。
上面的信息在后面都是可以重复修改的。
最后点击Create就创建好一个maven库了。
前面我们创建好了Maven的代码仓库,现在我们就往仓库里面添加东西了。
进到你的maven库,点击Add New Package:
填空里面带*好的都是必填的
Package avatar 设置这个库的图标;
Name 这个库的名字,跟后面配置的artifactId属性一致;
Description 库的描述,干什么用的;
Licenses 开源声明,根据需求自行选择;
Tags 这个的库的类别属性,别人可以通过搜索这些标签来找到你的库。输入完后按回车,可以设置多个标签;
Maturity 字面翻译,成熟度。就是你这个库当前开发到什么地步了,有稳定版,实验版等选项。我这里是例子,就选实验版,你们根据自己需求进行选择;
Website 该库的相信信息的网站链接,一般链接到该项目的github网站上,你们根据自己需求进行填写;
Issues tracker 该库的发布里程追踪。一般链接到一个网址上。这里我选择不填。
Version control 当前库的发行版本号,初始的一般填1.0.0
注意,这两步操作的时候有暗坑:
注意,我这里新建的app主module和bintrayuploadlib库module的package name是完全一样的。这个是不行的。为什么不行,后面会讲到,我这里是为了重现那个错误,你们在创建的时候不要一样。
buildscript {
repositories {
google()
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:3.0.1'
classpath 'com.novoda:bintray-release:0.8.0'//添加依赖插件
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
} }
接着在你的库的gradle文件里面:
顶部
apply plugin: 'com.novoda.bintray-release'//应用bintray插件
底部最外层
publish {
repoName='Android_Library'//此处是坑,这个是你建立BintaryRespository的库名,如果你没有设置这个值,默认就是maven,具体看前面的介绍
userOrg = 'XXX'//你登录bintray的用户名
groupId = 'XXX'//jcenter上的路径
artifactId = 'BintrayUpload'//项目名称,和之前建package的Name属性一致
publishVersion = '1.0.0'//版本号
desc = 'A convenient tool to help building a float button.Support full screen mode and Samsung S-series mobile phones change visiblity of bottom navigation bar dynamic.'//描述
website = 'https://github.com/ChenJunsen'//库的链接网站
}
请注意groupid这个属性有点点暗坑。这个值可以自己随意定义,而且晚上很多文章都是以com.xx.xx的样式设置的,但是,你如果为了美观,这个属性值最好不要以com开头。为啥?这个属性就是你在jcenter上面审核成功后,能够直接外网访问的路径。
举个栗子:
groupId = 'cjs.android.widgets'//jcenter上的路径
artifactId = 'Android-FloatButtonLayout'//项目名称
这个是我的一个项目设置,然后jcenter那边审核成功后,我用浏览器能访问到:
看到没,如果你以com开头,你的访问路径就是https://bintray.com/com。看着是不是超级别扭,作为有强迫症的程序猿,你能容忍?
首先上传的控制台代码是:
gradlew clean build bintrayUpload -PbintrayUser=XXXX -PbintrayKey=XXXXXXXXX -PdryRun=false
这里需要填两个参数:
现在我们在Android Studio的terminal里面运行那个指令,指令运行期间请保持联网状态,会下载一些组件,时间视你的网速而定,然后不出意外,你可能会遇到一个坑(这个跟你的电脑配置有关,我的电脑是win10 16G内存,所以AS自动分配内存比较大,如果你的内存本来就小,可能不会遇到这个错):
Starting a Gradle Daemon, 2 incompatible Daemons could not be reused, use --status for details
FAILURE: Build failed with an exception.
* What went wrong:
Unable to start the daemon process.
This problem might be caused by incorrect configuration of the daemon.
For example, an unrecognized jvm option is used.
Please refer to the user guide chapter on the daemon at https://docs.gradle.org/4.1/userguide/gradle_daemon.html
Please read the following process output to find out more:
-----------------------
Error occurred during initialization of VM
Could not reserve enough space for 1572864KB object heap
* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.
* Get more help at https://help.gradle.org
居然说heap太大了。然后查了资料,我们先打开gradle.properties这个文件:
这里的jvmargs参数恰好与报错的数值一致。我们改小点,改成-Xmx512m。(这点很讽刺,因为后面gradle编译的时候又会提示说1536m是最好的)
To run dex in process, the Gradle daemon needs a larger heap.
It currently has 512 MB.
For faster builds, increase the maximum heap size for the Gradle daemon to at least 1536 MB.
To do this set org.gradle.jvmargs=-Xmx1536M in the project gradle.properties.
For more information see https://docs.gradle.org/current/userguide/build_environment.html
然后我们再来试试。
> Task :app:transformDexArchiveWithDexMergerForDebug
Dex: Error converting bytecode to dex:
Cause: com.android.dex.DexException: Multiple dex files define Lcom/cjs/widget/demo/bintrayupload/BuildConfig;
UNEXPECTED TOP-LEVEL EXCEPTION:
com.android.dex.DexException: Multiple dex files define Lcom/cjs/widget/demo/bintrayupload/BuildConfig;
com.android.dex.DexException: Multiple dex files define Lcom/cjs/widget/demo/bintrayupload/BuildConfig;
at com.android.dx.merge.DexMerger.readSortableTypes(DexMerger.java:661)
at com.android.dx.merge.DexMerger.getSortedTypes(DexMerger.java:616)
at com.android.dx.merge.DexMerger.mergeClassDefs(DexMerger.java:598)
at com.android.dx.merge.DexMerger.mergeDexes(DexMerger.java:171)
at com.android.dx.merge.DexMerger.merge(DexMerger.java:198)
at com.android.builder.dexing.DexArchiveMergerCallable.call(DexArchiveMergerCallable.java:61)
at com.android.builder.dexing.DexArchiveMergerCallable.call(DexArchiveMergerCallable.java:36)
at java.util.concurrent.ForkJoinTask$AdaptedCallable.exec(ForkJoinTask.java:1424)
at java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:289)
at java.util.concurrent.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1056)
at java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1692)
at java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:157)
FAILURE: Build failed with an exception.
* What went wrong:
Execution failed for task ':app:transformDexArchiveWithDexMergerForDebug'.
> com.android.build.api.transform.TransformException: com.android.dex.DexException: Multiple dex files define Lcom/cjs/widget/demo/bintrayupload/BuildConfig;
如果你的app主module和库module的package name是一致的,恭喜你,中奖了,就报了这个错。所以在创建工程的时候我才说两者的名字不要一样。然后我们将二者改成不一样的,再来试试。
> Task :app:lint
Ran lint on variant release: 8 issues found
Ran lint on variant debug: 8 issues found
Wrote HTML report to file:///D:/WorkSpace/AndroidStudio2/BintrayUpload/app/build/reports/lint-results.html
Wrote XML report to file:///D:/WorkSpace/AndroidStudio2/BintrayUpload/app/build/reports/lint-results.xml
> Task :bintrayuploadlib:lint
Ran lint on variant release: 4 issues found
Ran lint on variant debug: 4 issues found
Wrote HTML report to file:///D:/WorkSpace/AndroidStudio2/BintrayUpload/bintrayuploadlib/build/reports/lint-results.html
Wrote XML report to file:///D:/WorkSpace/AndroidStudio2/BintrayUpload/bintrayuploadlib/build/reports/lint-results.xml
> Task :bintrayuploadlib:releaseAndroidJavadocs
D:\WorkSpace\AndroidStudio2\BintrayUpload\bintrayuploadlib\src\main\java\com\cjs\widget\demo\bintrayuploadlib\Constant.java:6: 错误: 编码GBK的不可映射字符
* 浣滆??:闄堜繆妫?
^
D:\WorkSpace\AndroidStudio2\BintrayUpload\bintrayuploadlib\src\main\java\com\cjs\widget\demo\bintrayuploadlib\Constant.java:6: 错误: 编码GBK的不可映射字符
* 浣滆??:闄堜繆妫?
^
D:\WorkSpace\AndroidStudio2\BintrayUpload\bintrayuploadlib\src\main\java\com\cjs\widget\demo\bintrayuploadlib\Constant.java:6: 错误: 编码GBK的不可映射字符
* 浣滆??:闄堜繆妫?
^
D:\WorkSpace\AndroidStudio2\BintrayUpload\bintrayuploadlib\src\main\java\com\cjs\widget\demo\bintrayuploadlib\Constant.java:7: 错误: 编码GBK的不可映射字符
* 鍒涘缓鏃堕棿:2018骞?04鏈?29鏃? 14:43
^
D:\WorkSpace\AndroidStudio2\BintrayUpload\bintrayuploadlib\src\main\java\com\cjs\widget\demo\bintrayuploadlib\Constant.java:7: 错误: 编码GBK的不可映射字符
* 鍒涘缓鏃堕棿:2018骞?04鏈?29鏃? 14:43
^
D:\WorkSpace\AndroidStudio2\BintrayUpload\bintrayuploadlib\src\main\java\com\cjs\widget\demo\bintrayuploadlib\Constant.java:7: 错误: 编码GBK的不可映射字符
* 鍒涘缓鏃堕棿:2018骞?04鏈?29鏃? 14:43
^
6 个错误
FAILURE: Build failed with an exception.
* What went wrong:
Execution failed for task ':bintrayuploadlib:releaseAndroidJavadocs'.
> Javadoc generation failed. Generated Javadoc options file (useful for troubleshooting): 'D:\WorkSpace\AndroidStudio2\BintrayUpload\bintrayuploadlib\build\tmp\releaseAndroidJavadocs\javadoc.options'
额,又报错了。这次是字符编码报错。然后就开始在网上找资料,就找到这篇。照着他的说法,我在project级别的gradle加入了:
allprojects {
tasks.withType(Javadoc) {
options{
encoding "UTF-8"
charSet 'UTF-8'
links "http://docs.oracle.com/javase/7/docs/api"
}
}
}
额,居然成功了。
> Configure project :app
Observed package id 'build-tools;22.0.0' in inconsistent location 'E:\CodingSoft\android-sdk-v2\build-tools\android-5.1' (Expected 'E:\CodingSoft\android-sdk-v2\build-tools\22.0.0')
Observed package id 'system-images;android-15;default;mips' in inconsistent location 'E:\CodingSoft\android-sdk-v2\system-images\android-15\mips' (Expected 'E:\CodingSoft\android-sdk-v2\system-images\android-15\default\mips')
Running dex as a separate process.
To run dex in process, the Gradle daemon needs a larger heap.
It currently has 512 MB.
For faster builds, increase the maximum heap size for the Gradle daemon to at least 1536 MB.
To do this set org.gradle.jvmargs=-Xmx1536M in the project gradle.properties.
For more information see https://docs.gradle.org/current/userguide/build_environment.html
> Task :app:lint
Ran lint on variant debug: 8 issues found
Ran lint on variant release: 8 issues found
Wrote HTML report to file:///D:/WorkSpace/AndroidStudio2/BintrayUpload/app/build/reports/lint-results.html
Wrote XML report to file:///D:/WorkSpace/AndroidStudio2/BintrayUpload/app/build/reports/lint-results.xml
> Task :bintrayuploadlib:lint
Ran lint on variant debug: 4 issues found
Ran lint on variant release: 4 issues found
Wrote HTML report to file:///D:/WorkSpace/AndroidStudio2/BintrayUpload/bintrayuploadlib/build/reports/lint-results.html
Wrote XML report to file:///D:/WorkSpace/AndroidStudio2/BintrayUpload/bintrayuploadlib/build/reports/lint-results.xml
BUILD SUCCESSFUL in 1m 23s
126 actionable tasks: 124 executed, 2 up-to-date
我为什么要说居然呢。因为之前的项目,我加了这句是报了另一个编码错误的。解决办法是添加:
tasks.withType(Javadoc).all {
enabled = false
}
如果你们遇到了就换成这个吧。这样的话,代码就上传成功了。你可以在bintray查看:
现在,点击一下Add to jCenter填一下描述,就可以等待审核了。审核成功后,你绑定邮箱会收到消息。然后你的bintray会收到类似这样消息:
。