iOS 刻度尺实现

前言

最近工作中有个刻度尺的需求,要求:
1、支持整数(一位)、小数
2、最大值和最小值范围控制
3、能支持较大数字精度(如:最大数据10000)

之前由于项目进度,在网上找了个刻度尺,原理是使用drawRect实现刻度尺的绘制,然后根据偏移量来计算当前值。这种方案有以下缺点:
1、数值不能过大。因为采用drawRect方式,每次都是将所有的刻度一次性绘制出来,耗时较长
2、内存占用过大。单个刻度尺在drawRect这种吃内存的方式下,每个刻度尺真机占用约300M以上内存,由于我们这边需求中有血压(舒张压和收缩压)这种需要两个刻度尺的,在iPhone6设备上,如果多次点击刻度视图,导致内存占用超过系统预警内存,而被watchdog直接杀掉了进程

所以我们的目的是自己写一个内存占用小且速度快的刻度尺。

我的方案

由于刻度尺是连续滑动的,所以这里我采用的是使用UICollectionView来实现。好处是显而易见的:
循环利用cell来布局刻度尺,速度快,内存占用小,样式更好控制。

目前实现方案中,支持水平和垂直方向,支持滑动选中,支持样式自定义,具体参考如下图:
实现效果图

上图是在模拟器中运行,一个控制器中添加4个,整个工程运行占用45M内存,已经达到了我们的目的。

实现代码

为了满足多种方案,所以在刻度尺拥有许多自定义参数:


自定义属性

参数说明:


参数说明
说明:
  • 顶部距离即刻度尺的起始位置

  • 刻度尺的方向由numberDirection属性决定,枚举值如下:

    刻度尺方向

  • 该刻度尺最多支持一位小数,小数由isDecimal决定

  • selectionEnableYES 时,刻度尺在滑动停止后,自动选中数字

  • 如当前布局不能满足需求时,可以在 RulerCollectionViewCell 文件中修改刻度尺的布局


2019.11.25 更新
1、新增刻度尺循环滚动功能
2、新增offset属性,每次按照指定的offset个刻度进行位置偏移。(默认是单个刻度偏移)
3、优化代码

循环刻度尺

实现原理参照collectionView实现无限循环滚动卡片

以上为此刻度尺的实现方案和说明,demo在这里。
如有错误或疑问,欢迎在评论区指正

你可能感兴趣的:(iOS 刻度尺实现)