iOS收藏iosroby的iOS开发文章收集

iOS 刻度尺实现

2018-07-26  本文已影响616人  披萨配可乐

前言

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

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

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

我的方案

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

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

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

实现代码

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


自定义属性

参数说明:


参数说明
说明:

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

上一篇 下一篇

猜你喜欢

热点阅读