在项目开发中碰到一个滑动选择金额的需求,因为是金融项目,涉及的数据都比较大,而且精确度要求还高,刚开始用了很笨的方法(利用UIScrollView动态创建一个刻度尺子,后来发现这种方法不可行,因为数据大了,会造成线程阻塞,界面假死,甚至程序崩溃),后来决定使用UICollectionView来实现一个可以与UITextField联动的滑动选择器。
思路:实现一个横向滑动的UICollectionView,每一个cell可以规定为1000(分10格,按实际需求分),再通过给定的最大值,计算cell的个数,这样就可以通过动态数据创建一个左右滑动的collectionView,最后通过collectionView的偏移量可以计算出滑动选择的结果是多少。通过scrollView的代理和监听textField的变化,可以实现滑动选择金额与手动输入金额联动。
1.新建一个继承UIScrollView的类HXBuyScrollView(继承UIView也可以),并添加一个实例方法:
该实例方法中设置了最大值,最小值,以及默认值(在collectionView中以偏移量标识)。
2.在HXBuyScrollView上实例化一个横向的UICollectionView,并设置sectionHeader和sectionFooter(为了调整样式,没有其他作用),
3.定制两个collectionView的cell,这里选择的是用xib创建的,样式如下图:
主要是第一个cell的样式跟后面的不一样,所以单独拎出来写,可以根据实际需求灵活改动。
4.通过上述实例方法设置collectionView的默认偏移量,并计算section的个数
到此为止,一个带刻度的滑动选择器基本构造完成。
5.在需要用到此滑动选择器的地方实例化并添加HXBuyScrollView:
此处添加了一条中点判别线,和底部的线条,后来仔细一想,底部的线条可以放在collectionCell上的,当时居中的判别线还是单独区分开的。添加一个UITextField,简单的实现滑动选择器和文本输入框的联动:
6.设置滑动选择的最小精度,可以根据需求来调整
文本输入的精度可以通过textField的代理实现,可根据实际需求来调整,因为涉及的是金融项目,对数字的要求比较高,所以项目中的计算包括显示都用的是NSDecimalNumber,为了精简代码,有很多计算都删除了,毕竟每个项目的需求都不一样。