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