android万能接口,万能接口库 Android Omnipotent

原标题:万能接口库 Android Omnipotent

1.前言

开发中,类与类之间交互又以下几种方式:

53a3466583b9889ca44a60f5fb9528ab.png

类之间交互方式

上述那么多种方式都具备各种缺点,是否有一种方式能解决上述的大部分缺点呢?

Omnipotent 库(万能接口库),它就是解决样式重复代码、类之间交互耦合而诞生,还具备使用简单、链式调用的特点。

本文特点:图片多,字体少

2.目录

c3e27c2aaf3ef9445c90a6046a7ed99f.png

目录 3.简介

a387f21afada70fd5e8187006ee11fd0.png

介绍 4.原理4.1 举个例子

Activity与Fragment接口交互(Fragment需要把自己的数据发送至Activity)

cef937d29f0d3d7efd370e70c48c42ab.png

类与类接口交互

上面的例子,在正常使用是没有任何问题,假如遇到以下情况:

1)因业务需求变换/迭代,需要修改接口的函数为无参有返回。

2)新增多个Fragment时,需要创建多个不同接口类。

3)接口函数中参数类型变换或者参数数量增多。

这些问题都会让你的代码增加修改成本与难度,而且不便于维护、迭代。

4.2 结合Omnipotent

那Omnipotent是如何解决这样的问题呢?我们通过上图例子结合解析如下图:

fee46b30110f35bf0c93911c5926b48c.png

Omnipotent原理

从上图可视,Omnipotent充当接口的管理者同时,也是接口函数调用者,触发回调。

Omnipotent还是类之间交互的桥梁,把它们之间进行解耦。

5.使用

5.1 API使用

f73f91db9f09b2b454690b2a1f8aaa30.png

API 5.2 如何在项目使用Omnipotent?

第一步:allprojects {

repositories {

...

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

}

}

第二步:

dependencies{

implementation'com.github.linhaojian:Omnipotent:1.2'

}

5.3 示例

2cd31d7102e1095d3d8bad1ee865cb9e.gif

omnipotent

Omnipotent示例传送门: https://github.com/linhaojian/Omnipotent

6.设计思想

e8d3ae06ce46961e6935fa5fa25d705a.png

设计思想 7.总结

到此,Omnipotent库就介绍完毕,希望能在开发过程中帮助大家。

如果喜欢我的分享,可以点击 关注 或者 赞,你们支持是我分享的最大动力 。

作者github:https://github.com/linhaojian

责任编辑:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JQuery Sparkline 是一个基于 jQuery 的小型图表,可以帮助你在网页上快速绘制各种类型的小型图表,如折线图、柱状图、饼图等。下面是 JQuery Sparkline 的一些说明: 1. 引入 JQuery 和 Sparkline 插件 在使用 Sparkline 之前,需要先引入 jQuery 和 Sparkline 插件,可以通过以下代码来实现: ``` <script src="https://code.jquery.com/jquery-3.5.1.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-sparklines/2.1.2/jquery.sparkline.min.js"></script> ``` 2. 创建图表 可以通过以下代码来创建一个基本的折线图: ``` <div class="sparkline"></div> <script> $('.sparkline').sparkline([5, 6, 7, 2, 0, -4, -2, 4], { type: 'line' }); </script> ``` 在此示例中,我们使用 `sparkline` 类来定义一个 DIV 元素,并将其转换为一个折线图。Sparkline 插件可以接受一组数据和一些选项参数,用于定义图表的类型、大小、颜色等。 3. 支持的图表类型 除了折线图之外,Sparkline 还支持以下类型的图表: - 柱状图:`type: 'bar'` - 堆积图:`type: 'bar', stackedBarColor: ['#aaf', '#afa', '#faa']` - 离散图:`type: 'discrete'` - 面积图:`type: 'line', fillColor: '#cdf'` - 饼图:`type: 'pie'` - 三角形图:`type: 'tristate'` - 范围图:`type: 'box'` 4. 自定义选项 Sparkline 支持许多选项参数,可以根据需要进行自定义,例如: ``` $('.sparkline').sparkline([5, 6, 7, 2, 0, -4, -2, 4], { type: 'line', width: '120px', height: '40px', lineColor: '#f00', fillColor: '#fcc' }); ``` 在此示例中,我们自定义了图表的宽度、高度、线条颜色和填充颜色。 5. 更多信息 如果想了解更多关于 Sparkline 的使用和选项参数,请参考官方文档:http://omnipotent.net/jquery.sparkline/

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值