学习笔记:制作自己的依赖库(Github+JitPack)

2024-02-28 08:30

本文主要是介绍学习笔记:制作自己的依赖库(Github+JitPack),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考:
油焖茄子: Android 发布GitHub项目到JitPack
Silence潇湘夜雨: Android 发布项目到jitpack详解
EyreFree: GitHub Wiki 页面的添加和设置
(转载请注明出处)

文章目录

  • 前言
  • 1. 制作 Github 的开源库
    • 1.1 配置JitPack相关的配置信息
    • 1.2 发布到 Github / Gitee
    • 1.3 添加 Readme(可省略)
    • 1.4 编写 Wiki(可省略)
    • 1.5 创建 release 或 tag(可省略)
    • 1.6 设置分支模型(可省略)
  • 2. 利用JitPack发布依赖库
    • 2.1 在 JitPack 中编译
    • 2.2 项目中添加勋章(非必须)
  • 3. 在项目中使用自己的依赖库
  • 最后

前言

做安卓开发,免不了要使用第三方的依赖库。依赖库的使用大量减轻了我们的工作量。同样,我们也可以做一个自己的依赖库并且发布,供自己和他人使用。
这里我们以 科技仪表盘 的项目来做一个自定义 View 的依赖库。

(博主也是依据网上资料摸索着来的,文中不妥之处还望不吝赐教)

1. 制作 Github 的开源库

1.1 配置JitPack相关的配置信息

首先准备我们的项目,在项目中创建一个libiary,然后上传到github
(只需要上传lib库就好,可以有效控制依赖库的体积)

step 1. 在project项目的build.gradle添加插件以及maven设置

buildscript {// ... 省略其它代码dependencies {classpath 'com.android.tools.build:gradle:3.6.3'// 1. 添加 android-maven-gradle-plugin 插件classpath 'com.github.dcendents:android-maven-gradle-plugin:2.1'}
}allprojects {repositories {// ... 省略其它代码// 2. 添加 maven 设置maven { url 'https://jitpack.io' }}
}

需要注意的是,maven-gradle 插件与 gradle 版本是有对应关系的。否则可能会导致失败,对应关系如下所示:

Plugin VersionPlugin NameDependency InformationGradle Version
1.0android-mavencom.github.dcendents:android-maven-plugin:1.01.8+
1.1android-mavencom.github.dcendents:android-maven-plugin:1.11.12+
1.2com.github.dcendents.android-mavencom.github.dcendents:android-maven-plugin:1.22.2+
1.3com.github.dcendents.android-mavencom.github.dcendents:android-maven-gradle-plugin:1.32.4+
1.4.1com.github.dcendents.android-mavencom.github.dcendents:android-maven-gradle-plugin:1.4.12.14+
1.5com.github.dcendents.android-mavencom.github.dcendents:android-maven-gradle-plugin:1.53.0+
2.0com.github.dcendents.android-mavencom.github.dcendents:android-maven-gradle-plugin:2.04.1+
2.1com.github.dcendents.android-mavencom.github.dcendents:android-maven-gradle-plugin:2.14.6+

也可以点击 JitPack对应的版本号 查看。

step 2. 在 moudle 中 build.gradle 添加配置

apply plugin: 'com.android.library'
// 1. 【必加】 启用 android-maven 插件
apply plugin: 'com.github.dcendents.android-maven' 
// 2. 【必加】 关联Github地址, 格式为 com.github.(用户名) 
group = 'com.github.zhengweichao' android {// ...省略
}dependencies {// ...省略
}

1.2 发布到 Github / Gitee

JitPack 已经支持 Gitee(码云)上的项目了,而且码云在访问速度等方面比 Github 更为优秀,所以大家也可以发布至 Gitee 上。

1.3 添加 Readme(可省略)

(非必须内容,可跳过)
一个好的项目,都会有一个好的介绍,Readme 是大家了解一个项目的最直观的方法。建议大家还是为自己的库写一份好的简历,也许会吸引更多人使用。

1.4 编写 Wiki(可省略)

(非必须内容,可跳过)
项目中细节使用等问题,可以在wiki中进行详细讲解。
在这里插入图片描述

1.5 创建 release 或 tag(可省略)

(非必须内容,可跳过)

创建并发布relese (create new release 或者Draft a new release)

img
其实不创建 release 或者 tag 也可以进行依赖库,不过版本号可能会比较丑一些,根据你commit 的序列号生成。比如 83ae2407d12a2bfe0a4adb449094ddab9d48272b,版本号就是 83ae2407d1,那么添加依赖就会是下面这个样子:

implementation 'com.github.zhengweichao:view:83ae2407d1' 

不利于记忆,而且无法看出版本先后信息。通过创建 release 或 tag 即可解决这个问题。

1.6 设置分支模型(可省略)

(非必须内容,可跳过)
这个纯属我个人的建议。既然做了依赖库,免不了要进行更新,修复bug等操作。在这个情况下,单分支模型,可能就显得不是特别合适。那么大家可以从以下几种来挑一下自己觉得合适的开发模型。

  • 单分支模型(只创建master分支)
  • 生产/开发模型(支持master/develop 类型分支)
  • 特性/发布模型(支持master/develop/feature 类型分支)
  • 开发/发布分离模型(支持master/develop/feature/release 类型分支)
  • 开发/发布/缺陷分离模型(支持master/develop/feature/release/hotfix 类型分支)

码云新建项目时,可以直接选择分支模型创建。

2. 利用JitPack发布依赖库

官网:https://jitpack.io/
官方介绍文档:https://jitpack.io/docs/

JitPack 是一个用于 JVM 和 Android 项目的 依赖包存储库。它根据需要构建Git项目,并提供依赖(jar、aar)。类似于 JCenter 和 MavenCentral 的仓库,但是相比较而言流程更简单些,可以非常快捷地进行依赖管理。

简单来说就是以下3点:

  1. 平台方面:支持Github,支持码云;
  2. 依赖方式方面:支持Gradle,Maven等;
  3. 项目方面:支持Android项目,支持Java项目。

2.1 在 JitPack 中编译

step 1. 添加网址到 JitPack 中(复制你的项目的url),点击Look up查看

step 2. 选择版本,点击编译

如果编译状态为绿色,即代表编译成功;
如果为红色,则代表出现错误,查看JitPack文档,查找原因,一般是因为依赖库中本身的错误,所以不能通过,所以在上传之前建议先检查一遍。

2.2 项目中添加勋章(非必须)

JitPack 编译成功之后,会有一个显示版本号的勋章。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XfYQ8pvd-1587657117313)(https://img.shields.io/github/stars/zhengweichao/view.svg)]
点击可以查看图片的链接,像下面这个样子。

[![](https://jitpack.io/v/zhengweichao/view.svg)](https://jitpack.io/#zhengweichao/view)

我们可以把这个添加到我们的Readme文件中,这样大家可以很方便的看到我们的依赖库最新版本号是多少了。
当然,我们还可以添加很多丰富的勋章来标识我们的项目,甚至还可以自定义。可以到 https://shields.io/ 中查看添加。
比如 github star 数量:

![](https://img.shields.io/github/stars/zhengweichao/view.svg)

3. 在项目中使用自己的依赖库

至此,依赖库就已经弄好了,我们可以在项目中愉快的使用了。使用步骤也很简单。

step 1. 项目的 build.gradle 中添加 maven 设置

// ...
allprojects {repositories {// ...maven { url 'https://jitpack.io' }}
}

step 2. 模块的 build.gradle 中添加依赖

// ...
dependencies {// ...implementation 'com.github.zhengweichao:view:83ae2407d1'
}

step 3. 同步一下之后,就可以愉快的使用自己的依赖库啦~

最后

文中很多内容作者也是首次接触,难免有所纰漏,还望不吝赐教。最后希望大家都可以有自己的开源库,互帮互助,发扬开源文化,共同推动技术进步啦~~

这篇关于学习笔记:制作自己的依赖库(Github+JitPack)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/754943

相关文章

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

Spring-DI依赖注入全过程

《Spring-DI依赖注入全过程》SpringDI是核心特性,通过容器管理依赖注入,降低耦合度,实现方式包括组件扫描、构造器/设值/字段注入、自动装配及作用域配置,支持灵活的依赖管理与生命周期控制,... 目录1. 什么是Spring DI?2.Spring如何做的DI3.总结1. 什么是Spring D

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

在Linux系统上连接GitHub的方法步骤(适用2025年)

《在Linux系统上连接GitHub的方法步骤(适用2025年)》在2025年,使用Linux系统连接GitHub的推荐方式是通过SSH(SecureShell)协议进行身份验证,这种方式不仅安全,还... 目录步骤一:检查并安装 Git步骤二:生成 SSH 密钥步骤三:将 SSH 公钥添加到 github

Java Spring的依赖注入理解及@Autowired用法示例详解

《JavaSpring的依赖注入理解及@Autowired用法示例详解》文章介绍了Spring依赖注入(DI)的概念、三种实现方式(构造器、Setter、字段注入),区分了@Autowired(注入... 目录一、什么是依赖注入(DI)?1. 定义2. 举个例子二、依赖注入的几种方式1. 构造器注入(Con

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM

IDEA Maven提示:未解析的依赖项的问题及解决

《IDEAMaven提示:未解析的依赖项的问题及解决》:本文主要介绍IDEAMaven提示:未解析的依赖项的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录IDEA Maven提示:未解析的依编程赖项例如总结IDEA Maven提示:未解析的依赖项例如