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在这里。
如有错误或疑问,欢迎在评论区指正😁

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,301评论 25 708
  • 今天我畫了張震,為此我感覺, 明天會很不一樣。
    小黃薊馬阅读 473评论 0 0
  • 看火影接触到鼬 从最开始的好奇 到现在的心疼 为了最心爱的弟弟 不惜一切代价也会保护他啊 看到有人说过这样一句话 ...
    oCC酱o阅读 1,416评论 2 2
  • 故事讲的是一个神话一般的人物,他的嗅觉超乎灵敏,似乎天生就是做香水的人物,从恶臭的地方出生,工作,好死不死...
    Nice丨阅读 387评论 0 0
  • 今天白天爸爸一个人带你,第一次呀,我也想看看他是不是可以把你带好。 你已经14个月,会走路了,只是有时候还走得不稳...
    兮之轩阁阅读 303评论 0 0