JCenter現在是Android Studio中repositories的默認節點了,之前是Maven的,不過JCenter是兼容Maven的,所以放心使用。
- 申請Bintray賬號
- 生成jar/aar包
- 這一步需要android-maven-plugin插件,所以我們需要在項目的build.gradle(、項目最外層的build.gradle文件)中添加這個構建依賴,如下:
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.0.0'
//自動化maven打包插件
classpath 'com.github.dcendents:android-maven-gradle-plugin:1.3'
}
}
allprojects {
repositories {
jcenter()
}
}
注意自動化maven打包插件的版本,網速查到的資料寫的都是1.0或1.1;gradle升級后已經不能再用舊版本了
- 然后在你需要發布的那個module(我這里的即是library)的build.gradle里配置如下內容:
apply plugin: 'com.android.library'
apply plugin: 'com.github.dcendents.android-maven'
apply plugin: 'com.jfrog.bintray'
version = "1.6.4"
android {
compileSdkVersion 23
buildToolsVersion "23.0.3"
resourcePrefix "numchoose_"
defaultConfig {
minSdkVersion 14
targetSdkVersion 23
versionCode 31
versionName version
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
}
def siteUrl = 'https://github.com/nesror/NumChooseView' // 項目的主頁
def gitUrl = 'https://github.com/nesror/NumChooseView.git' // Git倉庫的url
group = "cn.yzapp.numchooseview" // 一般填你唯一的包名
install {
repositories.mavenInstaller {
pom {
project {
packaging 'aar'
//項目描述
name 'Android number choose view'
url siteUrl
// 開源協議
licenses {
license {
name 'The Apache Software License, Version 2.0'
url 'http://www.apache.org/licenses/LICENSE-2.0.txt'
}
}
developers {
//填寫的基本信息
developer {
id 'nestor'
name 'nestor'
email 'nestor@yzapp.cn'
}
}
scm {
connection gitUrl
developerConnection gitUrl
url siteUrl
}
}
}
}
}
// 注釋掉不上傳源碼
task sourcesJar(type: Jar) {
from android.sourceSets.main.java.srcDirs
classifier = 'sources'
}
task javadoc(type: Javadoc) {
options.encoding = "utf-8"
source = android.sourceSets.main.java.srcDirs
classpath += project.files(android.getBootClasspath().join(File.pathSeparator))
}
task javadocJar(type: Jar, dependsOn: javadoc) {
classifier = 'javadoc'
from javadoc.destinationDir
}
artifacts {
archives javadocJar
archives sourcesJar
}
Properties properties = new Properties()
properties.load(project.rootProject.file('local.properties').newDataInputStream())
bintray {
user = properties.getProperty("bintray.user")
key = properties.getProperty("bintray.apikey")
configurations = ['archives']
pkg {
repo = "maven"
name = "NumChooseView" //發布到JCenter上的項目名字
websiteUrl = siteUrl
vcsUrl = gitUrl
licenses = ["Apache-2.0"]
publish = true
}
}
- 配置好上述后需要在你的項目的根目錄上的local.properties文件里(一般這文件需gitignore,防止泄露賬戶信息)配置你的bintray賬號信息。
bintray.user=your_user_name
bintray.apikey=your_apikey
- 這一步為止,就可以把你項目生成到本地的倉庫中了,Android Studio中默認即在Android\sdk\extras\android\m2repository這里,所以我們可以通過如下命令執行生成:
- gradlew install
- 上傳到Bintray
- 上傳到Bintray需要gradle-bintray-plugin的支持,所以在最外層的build.gradle里添加構建依賴:
dependencies {
classpath 'com.android.tools.build:gradle:2.0.0'
//自動化maven打包插件
classpath 'com.github.dcendents:android-maven-gradle-plugin:1.3'
//自動上傳至Bintray平臺插件
classpath "com.jfrog.bintray.gradle:gradle-bintray-plugin:1.4"
}
- 然后執行如下命令完成上傳:
- gradlew bintrayUpload
- 申請你的Repo添加到JCenter
- https://bintray.com/bintray/jcenter ,輸入你的項目名字點擊匹配到的項目,然后寫一寫Comments再send即可,工作時間內1消失內就會批準
- 可能會檢查 “def siteUrl = 'https://github.com/nesror/NumChooseView' // 項目的主頁 ”里的項目來確認
- 使用
- 可能會遇到的問題
- 生成javaDoc報錯:
- javaDoc注釋中有中文:
- 注釋中非javadoc中規定的注解:
如(以下只有@author是可以用的):/** * @author: xxx * @time: 4/9 009-11:56. * @email: xxx@xxx.com * @desc: */
- 還有其他很多,已經忘記了