Подтвердить что ты не робот

Как создать свою собственную библиотеку Android и разместить ее

Я работаю над созданием экрана входа в систему, который будет использоваться с несколькими различными приложениями для Android. Каким будет лучший способ его упаковки, чтобы другие пользователи могли использовать мою функцию входа в свои приложения. Было бы предпочтительно, чтобы он автоматически синхронизировался для них, если бы мы вносили изменения. ***РЕДАКТИРОВАТЬ**** Кажется, упаковка в библиотечный модуль - лучший вариант. Как можно загружать этот модуль, чтобы, если мы сделаем обновление для этого модуля, он будет без проблем обновляться без необходимости использовать github.

Спасибо!

4b9b3361

Ответ 1

Если вы поместили свой код в GitHub, то совместное использование библиотеки (aar) легко с JitPack.

Ваши пользователи просто должны добавить репозиторий в свой файл build.gradle:

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

а затем ваш репозиторий GitHub как зависимость:

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

Приятно, что вам не нужно загружать свою библиотеку. За кулисами JitPack проверит код из GitHub и скомпилирует его. Когда вы публикуете новую версию GitHub, она становится доступной для других пользователей.

Существует также руководство о том, как подготовить проект Android.

Ответ 2

Сделайте соответствующие классы в библиотечном модуле - вы уже знаете, как это сделать - и затем используйте Gradle плагин Bintray чтобы загрузить его в JCenter.

Предположим, вы установили group в build.gradle в com.ryan-newsom, version в 1.0, а имя проекта - Android-log-in-screen.

(часть) 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 и добавится в путь к классам.

Ответ 3

Вы можете упаковать библиотеку в формат AAR. Он также будет содержать ресурсы, которые вы использовали в своем модуле входа в систему. После этого вы можете форматировать формат библиотеки AAR до bintray (что бесплатно, и позволяет настроить собственный репозиторий).

Затем ваши сотрудники могут получить доступ к библиотеке, используя зависимость, которая выглядит следующим образом:

compile 'com.newsom: awesome-login-screen: 0.5'

Проверьте этот учебник для начинающих, если вы используете AndroidStudio/ Gradle и хотите нажать его на bintray. https://github.com/jimcoven/android-bintray-kit

Ответ 4

Лучший способ создать lib и сделать его доступным для других разработчиков - это создать AAR, чтобы разработчики могли импортировать его в свой проект, используя зависимостей.

Процесс довольно длинный. Вот основные шаги, которые вам следует предпринять, чтобы опубликовать ваш lib:

  • Зарегистрируйте учетную запись и создайте новый билет (https://issues.sonatype.org)
  • Загрузка (если вы используете OS X) GPGTools (http://www.gpgtools.org/)
  • Изменить файлы проекта gradle
  • Создать ключ подписи Build
  • подпишите и опубликуйте свои файлы в промежуточном репозитории

Я написал сообщение об этом, и для получения более подробной информации вы можете посмотреть здесь. Это фрагмент файла gradle maven_push.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:[email protected]:
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.

Надеюсь, это поможет вам.

Ответ 5

сделайте пакет или банку в зависимости от вашего источника и разместите его на узле git, вы можете ссылаться на git на ваш идеал для импорта или проверки обновлений.