在开发中,我们在引用第三方开源控件的时候,经常会给出如下的gradle dependencies
compile 'com.android.support:appcompat-v7:22.2.0'
不用再下载,导入等复杂的操作。到底是如何做到的呢?其实是android studio去build.gradle里面定义的Maven仓库中去下载了这些library。
那我们如果想将自己的作品上传到jcenter 共别人来这样很方便的引用,该怎么做呢?
Gradle支持以下仓库格式:Ivy仓库;Maven仓库;Flat directory仓库。
如果使用过早期的Android Studio,我们会发现其默认仓库是Maven Central,后来改为了JCenter,可参见这篇文章Android Studio – Migration from Maven Central to JCenter,其实Maven Central (由sonatype.org维护的Maven仓库)和Center(由 bintray.com维护的Maven仓库)是两个标准的Apache Maven文件服务器,都是Maven仓库。Apache Maven是Apache开发的一个工具,提供了用于贡献library的文件服务器。
JCenter:
allprojects { repositories { jcenter() }
}
Maven Central:
allprojects { repositories { mavenCentral() }
}
同时,我们还看到有类似如下代码:
repositories { maven { url 'https://maven.fabric.io/public' }
}
这是作者将library放到了自己定义的Maven仓库服务器上,需要定义服务器地址。
在将library上传到JCenter之前,我们看一下Maven仓库中library是如何在项目中引用的。
compile 'com.squareup.retrofit2:retrofit:2.0.0-beta3'
这里看到的是compile 后被三个: 分割;即
compile 'GROUP_ID:ARTIFACT_ID:VERSION'
其中,GROUP_ID
属性指定依赖的分组
ARTIFACT_ID
属性指定依赖的名称
VERSION
属性指定外部依赖的版本
当我们添加上述依赖的时候,gradle就会获得相应路径,如上:gradle会到http://jcenter.bintray.com/com/squareup/retrofit2/retrofit/2.0.0-beta3/,并下载相应的library进行编译。
根目录下
找到local.properties
文件,如果没有,就创建一个。输入如下信息bintray.user= [your name]
bintray.apikey= [your api key]
build.gradle(不是library)
添加maven依赖,最终信息如下buildscript {
//构建过程依赖的仓库
repositories {
jcenter()
}
//构建过程需要依赖的库
dependencies {
classpath 'com.android.tools.build:gradle:1.5.0'
classpath 'com.github.dcendents:android-maven-gradle-plugin:1.3'
classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.2'
}
}
//这里面配置整个项目依赖的仓库,这样每个module就不用配置仓库了
allprojects {
repositories {
jcenter()
}
}
library的model
里面创建local.properties
文件,配置library相关信息。#developer
developer.id=BoBoMEe
developer.name=bobomee
[email protected]
#project
project.name=AutoScrollLoopViewPager
project.groupId=com.bobomee.android
project.artifactId=scrollloopviewpager
project.packaging=aar
project.siteUrl=https://github.com/BoBoMEe/AutoScrollLoopViewPager
project.gitUrl=https://github.com/BoBoMEe/AutoScrollLoopViewPager.git
project.issueUrl='https://github.com/BoBoMEe/AutoScrollLoopViewPager/issues'
#javadoc
javadoc.name=AutoScrollLoopViewPager
library的model
里面创建上传脚本bintrayUpload.gradle,添加如下信息。apply plugin: 'com.github.dcendents.android-maven'
apply plugin: 'com.jfrog.bintray'
// load properties
Properties properties = new Properties()
File localPropertiesFile = project.file("local.properties");
if(localPropertiesFile.exists()){
properties.load(localPropertiesFile.newDataInputStream())
}
File projectPropertiesFile = project.rootProject.file('local.properties');
if(projectPropertiesFile.exists()){
properties.load(projectPropertiesFile.newDataInputStream())
}
// read properties
def projectName = properties.getProperty("project.name")
def projectGroupId = properties.getProperty("project.groupId")
def projectArtifactId = properties.getProperty("project.artifactId")
def projectVersionName = android.defaultConfig.versionName
def projectPackaging = properties.getProperty("project.packaging")
def projectSiteUrl = properties.getProperty("project.siteUrl")
def projectGitUrl = properties.getProperty("project.gitUrl")
def projectDesc = properties.getProperty("project.desc")
def projectIssueUrl = properties.getProperty("project.issueUrl")
def developerId = properties.getProperty("developer.id")
def developerName = properties.getProperty("developer.name")
def developerEmail = properties.getProperty("developer.email")
def bintrayUser = properties.getProperty("bintray.user")
def bintrayApikey = properties.getProperty("bintray.apikey")
def javadocName = properties.getProperty("javadoc.name")
group = projectGroupId
// This generates POM.xml with proper parameters
install {
repositories.mavenInstaller {
pom {
project {
name projectName
groupId projectGroupId
artifactId projectArtifactId
version projectVersionName
packaging projectPackaging
url projectSiteUrl
licenses {
license {
name 'The Apache Software License, Version 2.0'
url 'http://www.apache.org/licenses/LICENSE-2.0.txt'
}
}
developers {
developer {
id developerId
name developerName
email developerEmail
}
}
scm {
connection projectGitUrl
developerConnection projectGitUrl
url projectSiteUrl
}
}
}
}
}
task writeNewPom << {
pom.writeTo("$buildDir/"+projectVersionName+".pom.xml")
}
// This generates sources.jar
task sourcesJar(type: Jar) {
from android.sourceSets.main.java.srcDirs
classifier = 'sources'
}
task javadoc(type: Javadoc) {
source = android.sourceSets.main.java.srcDirs
classpath += project.files(android.getBootClasspath().join(File.pathSeparator))
}
// This generates javadoc.jar
task javadocJar(type: Jar, dependsOn: javadoc) {
classifier = 'javadoc'
from javadoc.destinationDir
}
artifacts {
archives javadocJar
archives sourcesJar
}
// javadoc configuration
javadoc {
options{
encoding "UTF-8"
charSet 'UTF-8'
author true
version projectVersionName
links "http://docs.oracle.com/javase/7/docs/api"
title javadocName
}
}
// bintray configuration
bintray {
user = bintrayUser
key = bintrayApikey
configurations = ['archives']
pkg {
repo = "maven"
name = projectName
desc =projectDesc
websiteUrl = projectSiteUrl
issueTrackerUrl = projectIssueUrl
vcsUrl = projectGitUrl
licenses = ["Apache-2.0"]
labels = ['android']
publish = true
publicDownloadNumbers = true
}
}
library的build.gradle
中引入此脚本即可,类似如下。dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
testCompile 'junit:junit:4.12'
compile 'com.android.support:appcompat-v7:22.2.0'
} //引入bintrayUpload.gradle脚本
apply from: "bintrayUpload.gradle"
ps:在gitignoe中要添加项目下的local.properties文件,不要上传。
经过如上配置,我们的脚本是否可用呢,我们来上传测试一下。运行命令
./gradlew install //编译library文件(jar,pom等)
./gradlew bintrayUpload //上传library
进入bintray.com检查我们的项目是否上传成功呢?
可以查看files,如果上传成功,会有相应文件。但是我们的library只是上传成功了,并未添加到jcenter哦!如果想让所有人一键引用的话,还需要添加到jcenter。
如图因为我的已经添加到了jcenter,所以下方有个linked to(1)
,第一次上传应该会不同。
在详情页中找到Maven Central
标签,鼠标放上去它会提示你去提交到JCenter进行审核,点击进入后,写点内容就可以了,审核过后即可引用了。
当linked to 部分发生变化的时候,我们可以通过URL(如:http://jcenter.bintray.com/com/bobomee/android/scrollloopviewpager/)查看一下文件是否存在,如果存在,即可在studio中引用了。