27

我正在创建一个登录屏幕以用于多个不同的 android 应用程序。什么是最好的打包方式,以便其他人可以在他们的应用程序上使用我的登录功能。如果我们要进行更改,最好它会为他们自动同步。***编辑**** 似乎将其打包到库模块中是最好的选择。如何上传这个模块,这样如果我们对这个模块进行更新,它将无缝更新,而无需从 github 中提取。

谢谢!

4

5 回答 5

20

如果您已将代码推送到 GitHub,那么使用 JitPack 可以轻松共享库 (aar )

您的用户只需将存储库添加到他们的 build.gradle:

repositories {
    jcenter()
    maven { url "https://jitpack.io" }
}

然后将您的 GitHub 存储库作为依赖项:

dependencies {
    // ...
    compile 'com.github.YourUsername:Repo:Release'
}

好处是您不必上传您的库。JitPack 会在后台检查 GitHub 上的代码并进行编译。当您在 GitHub 上发布新版本时,它可供其他人使用。

还有一个关于如何准备 Android 项目的指南。

于 2015-07-08T08:22:08.380 回答
5

将相关的类变成一个库模块——您似乎已经知道如何做到这一点——然后使用 Gradle Bintray 插件将其上传到JCenter

假设您将build.gradle 设置为com.ryangroup - newsom,设置为1.0并且项目名称是android-log-in-screenversion

(部分)android-log-in-screen/build.gradle

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath "com.jfrog.bintray.gradle:gradle-bintray-plugin:0.6"
    }
}

apply plugin: 'com.jfrog.bintray'

group = 'com.ryan-newsom'
version = '1.0'

bintray {
    // Omitted for brevity, refer to the examples on GitHub.
}

然后,您(或其他任何人)可以通过添加以下内容在您的项目中使用它:

(部分)other-project/build.gradle

repositories {
    jcenter()
}

dependencies {
    compile "com.ryan-newsom:android-log-in-screen:1.0"
}

然后将从 JCenter 中提取该库并将其添加到类路径中。

于 2015-07-07T11:25:57.957 回答
3

您可以将库打包成 AAR 格式。它还将包含您在登录模块中使用的资源。之后,您可以将 AAR 库格式推送到 bintray(这是免费的,并允许您设置自己的存储库)。

然后,您的协作者可以使用如下所示的依赖项访问该库:

编译 'com.newsom:awesome-login-screen:0.5'

如果您正在使用 AndroidStudio/Gradle 并希望将其推送到 bintray,请查看此入门教程。https://github.com/jimcoven/android-bintray-kit

于 2015-07-07T17:18:16.107 回答
2

创建 lib 并使其可供其他开发人员使用的最佳方法是创建 AAR,以便开发人员可以使用依赖项将其导入项目中。

过程相当漫长。以下是发布库应遵循的主要步骤:

我写了一篇关于它的帖子,想要了解更多细节,你可以看这里。这是一个名为 maven_push.gradle 的 gradle 文件:

apply plugin: 'maven'
apply plugin: 'signing'

def sonatypeRepositoryUrl
if (isReleaseBuild()) {
    println 'RELEASE BUILD
    sonatypeRepositoryUrl = hasProperty('RELEASE_REPOSITORY_URL') ? RELEASE_REPOSITORY_URL
            : "https://oss.sonatype.org/service/local/staging/deploy/maven2/"
} else {
    println 'SNAPSHOT BUILD'
    sonatypeRepositoryUrl = hasProperty('SNAPSHOT_REPOSITORY_URL') ? SNAPSHOT_REPOSITORY_URL
            : "https://oss.sonatype.org/content/repositories/snapshots/"

}

def getRepositoryUsername() {
    return hasProperty('nexusUsername') ? nexusUsername : ""
}

def getRepositoryPassword() {
    return hasProperty('nexusPassword') ? nexusPassword : ""
}

afterEvaluate { project ->
    uploadArchives {
        repositories {
            mavenDeployer {
                beforeDeployment { MavenDeployment deployment -> signing.signPom(deployment) }

                pom.artifactId = POM_ARTIFACT_ID

                repository(url: sonatypeRepositoryUrl) {
                    authentication(userName: getRepositoryUsername(), password: getRepositoryPassword())
                }

                pom.project {
                    name POM_NAME
                    packaging POM_PACKAGING
                    description POM_DESCRIPTION
                    url POM_URL

                    scm {
                        url POM_SCM_URL
                        connection POM_SCM_CONNECTION
                        developerConnection POM_SCM_DEV_CONNECTION
                    }

                    licenses {
                        license {
                            name POM_LICENCE_NAME
                            url POM_LICENCE_URL
                            distribution POM_LICENCE_DIST
                        }
                    }

                    developers {
                        developer {
                            id POM_DEVELOPER_ID
                            name POM_DEVELOPER_NAME
                        }
                    }
                }
            }
        }
    }

    signing {
        required { isReleaseBuild() && gradle.taskGraph.hasTask("uploadArchives") }
        sign configurations.archives
    }

    task androidJavadocs(type: Javadoc) {
        source = android.sourceSets.main.allJava
        classpath += project.files(android.plugin.getRuntimeJarList().join(File.pathSeparator))
    }

    task androidJavadocsJar(type: Jar, dependsOn: androidJavadocs) {
        classifier = 'javadoc'
        //basename = artifact_id
        from androidJavadocs.destinationDir
    }

    task androidSourcesJar(type: Jar) {
        classifier = 'sources'
        //basename = artifact_id
        from android.sourceSets.main.allSource
    }

    artifacts {
        //archives packageReleaseJar
        archives androidSourcesJar
        archives androidJavadocsJar
    }
}

而 gradle.properties 是:

VERSION_NAME= 
VERSION_CODE=1
GROUP=
POM_DESCRIPTION=
POM_URL=
POM_SCM_URL= POM_SCM_CONNECTION=
POM_SCM_DEV_CONNECTION=scm:git@github.com:
POM_LICENCE_NAME=The Apache Software License, Version 2.0 POM_LICENCE_URL=http://www.apache.org/licenses/LICENSE-2.0.txt POM_LICENCE_DIST=repo 
POM_DEVELOPER_ID=
POM_DEVELOPER_NAME=

还有另一种方法,但我没有尝试,它似乎更容易。看看jitpack

希望它可以帮助你。

于 2015-07-08T07:26:00.080 回答
1

根据您的来源制作包或 jar,并将其发布在 git hub 上,您可以从 ide 引用 git 以导入或检查更新。

于 2015-06-09T20:00:25.533 回答