Android Studio将module打包并放到github

2020-06-08  本文已影响0人  零星瓢虫

前言

平时开发中,我们经常会使用到通过 gradle 依赖三方的工具。例如我们常用的 okHttp 、 EventBus 等框架。那么这些代码是如何部署到远程并且供我们使用的呢?接下来就来看一下如何去实现。

maven

maven 其实就是为我们提供了进行托管我们代码的地址,我们可以相关代码进行上传到 maven,同时其他人如果觉得你写的比较好就可以通过依赖获取相关代码。maven 就类似于一个 git 或者 svn 的仓库。

把自己的项目部署到 maven 中

image.png

上面项目中,我们有一个 jnilib 的 library 。这个项目是我们创建的为了进行 jni 调用的一个示例 library 。接下来我们去把这个 library 部署到 maven 中,并供其它项目依赖使用。

1 首先需要在 jnilib 的 build.gradle 中进行一些配置:

//上传的maven库中
apply plugin: 'maven'

uploadArchives {
    repositories.mavenDeployer {
        def mavenDirPath = file('D:\\mavendir') // 本地存放目录(自行选择),可放在gradle.properties文件中引用
        repository(url:"file://${mavenDirPath.absolutePath}") // 必须双引号,单引号不会转义$
        pom.project {
            groupId "com.harusty.maven" // 可以随意取,一般取包名
            artifactId "jnisay" // 可以随意取,一般取库的名字
            version "1.0.0" // 版本号
        }
    }
}

apply plugin: 'maven' 应用 maven 的插件。
可以看到我们配置了本地的 maven 缓存目录,以及库的包名、库名、版本号的信息,根据自己的习惯进行命名。

2 生成aar文件

定义好了相关配置信息,就可以去编译进行刷新生成 jnilib 的相关文件:

image.png

点击Run "MyApplication ...",或者我们去执行gradlew :jinlib:uploadArchives命令

此时会在本地目录中生成相关文件,我这里定义的本地D盘,去看一看:

image.png image.png

我这里因为之前改过版本号为1.0.1,所以会生成两个文件夹。库的升级也就是这样去做的。

这样,我们已经在本地生成了文件,接下来就只需要上传到远程就可以了。

3 上传本地文件到远程
上传到github的地址:

image.png

拿到地址信息,https://github.com/harusty/jnisay/

4 本地配置信息,下载部署在 git 上的文件:
github 的地址信息
https://github.com/harusty/jnisay/
进行修改:
https://raw.githubusercontent.com/harusty/jnisay/master
即 github.com ——> raw.githubusercontent.com
在末尾追加 master 分支

根目录下 build.gradle 进行地址信息配置:

allprojects {
    repositories {
        google()
        jcenter()
        maven{
            url "https://raw.githubusercontent.com/harusty/jnisay/master"
        }
    }
}

在需要使用该库的build.gradle文件的dependencies添加依赖:

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'androidx.appcompat:appcompat:1.0.2'
    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
    implementation 'com.harusty.maven:jnisay:1.0.0'
//    compile project(path: ':jnilib')
}

上面我们同时屏蔽了本地对 library 的依赖。

5 刷新 build.gradle 文件,下载对应部署在 git 上的 library 文件。

image.png

成功下载后我们可以在 External Libraries 中看到上述的 aar 文件。

注意:

在下载过程中我们有可能连接不上 raw.githubusercontent.com,导致下载 aar 文件失败。可以通过修改 Host 文件解决:

通过IPAddress.com首页,输入raw.githubusercontent.com查询到真实IP地址
199.232.28.133
C:\Windows\System32\drivers\etc
hosts文件
添加 以下内容并保存即可恢复
199.232.28.133 raw.githubusercontent.com

6 运行文件,调用 jnilibs 里的方法。

public class JNIUtils {
    static {
        System.loadLibrary("demo");
    }

    public static  native String sayHelloFromJNI();
}

这里用的 jni ,native 层会返回一个字符串。关于 jni 相关可查看
jni 调用的相关文章,这里知道会返回一个字符串。

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        final TextView tv = findViewById(R.id.jni_click);
        tv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                tv.setText(JNIUtils.sayHelloFromJNI());
            }
        });
    }
}

功能可正常调用即部署成功。如果本地升级了,同时升级 maven 配置的版本号即可,并进行上传至 git 。

uploadArchives {
    repositories.mavenDeployer {
        def mavenDirPath = file('D:\\mavendir') // 本地存放目录(自行选择),可放在gradle.properties文件中引用
        repository(url:"file://${mavenDirPath.absolutePath}") // 必须双引号,单引号不会转义$
        pom.project {
            groupId "com.harusty.maven" // 可以随意取,一般取包名
             artifactId "jnisay" // 可以随意取,一般取库的名字
            version "1.0.3" //升级 版本号
        }
    }
}

升级到 1.0.3 版本。

上一篇下一篇

猜你喜欢

热点阅读