分段进度条&分段图标抖动动画的实现
先上图,https://github.com/Warkey1991/Jackview,觉得有用的话,希望给个star
该自定义View有三个问题需要一一实现
- 如何实现分段 ,
- 如何用canvas 实现抖动的动画效果
- 如何识别点击区域的点击事件
以下就针对三个问题提供解决思路和实战代码
a.本例中采用的是均分三段,定义一个数组A = {3,5,8},再将每一段根据A 中的A[i]的值均分,
如图
绘制进度的时候,需要先找出当前进度progress 所在的区间,然后分段绘制。具体代码如下:
//查找所在区间的索引
private fun findRange(): Int {
if (progress >= segments.last().progress) {
progressPadding = 0
return segments.size - 1
}
var index = 0
for (i in 0 until segments.size - 1) {
if (progress in segments[i].progress..segments[i + 1].progress) {
index = i + 1
}
}
if (index >= 1) {