前言
最近工作中有个刻度尺的需求,要求:
1、支持整数(一位)、小数
2、最大值和最小值范围控制
3、能支持较大数字精度(如:最大数据10000)
之前由于项目进度,在网上找了个刻度尺,原理是使用drawRect实现刻度尺的绘制,然后根据偏移量来计算当前值。这种方案有以下缺点:
1、数值不能过大。因为采用drawRect方式,每次都是将所有的刻度一次性绘制出来,耗时较长
2、内存占用过大。单个刻度尺在drawRect这种吃内存的方式下,每个刻度尺真机占用约300M以上内存,由于我们这边需求中有血压(舒张压和收缩压)这种需要两个刻度尺的,在iPhone6设备上,如果多次点击刻度视图,导致内存占用超过系统预警内存,而被watchdog直接杀掉了进程
所以我们的目的是自己写一个内存占用小且速度快的刻度尺。
我的方案
由于刻度尺是连续滑动的,所以这里我采用的是使用UICollectionView来实现。好处是显而易见的:
循环利用cell来布局刻度尺,速度快,内存占用小,样式更好控制。
上图是在模拟器中运行,一个控制器中添加4个,整个工程运行占用45M内存,已经达到了我们的目的。
实现代码
为了满足多种方案,所以在刻度尺拥有许多自定义参数:
参数说明:
说明:
顶部距离即刻度尺的起始位置
-
刻度尺的方向由
numberDirection
属性决定,枚举值如下:
该刻度尺最多支持一位小数,小数由
isDecimal
决定selectionEnable
为YES
时,刻度尺在滑动停止后,自动选中数字如当前布局不能满足需求时,可以在
RulerCollectionViewCell
文件中修改刻度尺的布局
2019.11.25 更新
1、新增刻度尺循环滚动功能
2、新增offset属性,每次按照指定的offset个刻度进行位置偏移。(默认是单个刻度偏移)
3、优化代码
实现原理参照collectionView实现无限循环滚动卡片
以上为此刻度尺的实现方案和说明,demo在这里。
如有错误或疑问,欢迎在评论区指正😁