//联系人:石虎 QQ: 1224614774昵称:嗡嘛呢叭咪哄
一、k线图概念
k线图:有最新价、收盘价、开盘价、最高价、最低价、均价、卖量、买量等等。而我们需要展示给用户看的第一眼就是把它们全部绘制为k线图,直观。还有部分要转化为数值直接推动;
蜡烛:需要用到收盘价、开盘价、最高价、最低价;红色是涨(国内),开盘价在上,收盘价在下;绿色是相反的;
效果图:
- 采用 CAShapeLayer + UIBezierPath绘制,绘制效率高,占用内存低
- 底层视图是UIScrollView,ScrollView上面添加一个View,所有的绘制在这个View上完成。体验流畅丝滑,FPS平均在55帧以上
- 指标支持MACD WR KDJ,指标计算采用TALib,方便扩展
- 横竖屏切换
-
右拉加载更多数据
三、CAShapeLayer思路
- 所有的绘制在UIView上面,UIView底层是一个ScrollView
- 设置K线之间的间距与可视区域想要显示的K线个数,动态计算出K线的宽度。之所以没有直接设置K线宽度,是为了保证每次滑动的时候,屏幕内总是占满整数倍的K线个数。
- 通过k线的个数,计算出当前View的与它的父视图ScrollView的宽度
- KVO监听ScrollView的contentOffset属性,计算每次滑动将要显示的K线数组(currentDisplayArray)
- 计算currentDisplayArray的最大值与最小值,然后得出每一根K线对应屏幕的坐标,绘图