关于charts的系列视图介绍传送门:

iOS 图表工具charts介绍

iOS 图表工具charts之LineChartView

iOS 图表工具charts之BarChartView

iOS 图表工具charts之PieChartView

iOS 图表工具charts之CandleStickChartView

iOS 图表工具charts之CombinedChartView

CandleStickChartView在charts中可以用来绘制K线图,由于charts是基于swift开发的,如果需要和objective-C混编(通过pod的方式不用管),可以参考我的上几篇文章iOS OC中桥接swift第三方库》,这里主要讲的是CandleStickChartView的一些常用属性和一些基本用法,实际情况以开发为准

CandleStickChartView的基本属性介绍

    CandleStickChartView *chartView = [[CandleStickChartView alloc] init];
//设置偏移
[chartView setExtraOffsetsWithLeft:10 top:10 right:10 bottom:10];
//开启border
chartView.drawBordersEnabled = YES;
chartView.borderLineWidth = .5f;
chartView.borderColor = UIColor.blackColor;
//设置背景
chartView.drawGridBackgroundEnabled = NO;
chartView.gridBackgroundColor = [UIColor grayColor];
//无内容显示
chartView.noDataText = @"";
//关闭描述
chartView.chartDescription.enabled = NO;
chartView.chartDescription.text = @"tiny`s kLineChart demo";
//关闭图例
chartView.legend.enabled = NO;
//缩放
chartView.scaleXEnabled = YES;
chartView.scaleYEnabled = NO;
chartView.autoScaleMinMaxEnabled = YES;
chartView.highlightPerTapEnabled = YES;
chartView.highlightPerDragEnabled = NO;
chartView.pinchZoomEnabled = NO; //手势捏合
chartView.dragEnabled = YES; //开启拖拽
chartView.dragDecelerationFrictionCoef = 0.5; //0 1 惯性
chartView.doubleTapToZoomEnabled = NO;
//代理
chartView.delegate = self; //leftAxis
ChartYAxis *rightAxis = chartView.rightAxis;
rightAxis.enabled = YES;
rightAxis.labelPosition = YAxisLabelPositionInsideChart;
rightAxis.drawGridLinesEnabled = YES;
rightAxis.gridLineDashLengths = @[@2,@4];
rightAxis.labelTextColor = UIColor.blackColor;
rightAxis.labelFont = [UIFont systemFontOfSize:10];
rightAxis.decimals = 2;
rightAxis.labelCount = 6; //设置显示最大点数
rightAxis.forceLabelsEnabled = YES; //强制label个数
// leftAxis.inverted = YES;
//设置样式
LeftAxisFormatter *leftFormatter = [LeftAxisFormatter new];
leftFormatter.digital = 2;
rightAxis.valueFormatter = leftFormatter; //rightAxis
ChartYAxis *leftAxis = chartView.leftAxis;
leftAxis.enabled = NO; //xAxis
ChartXAxis *xAxis = chartView.xAxis;
xAxis.enabled = YES;
xAxis.labelPosition = XAxisLabelPositionBottom;
xAxis.labelCount = 2; //设置显示点数
xAxis.forceLabelsEnabled = YES; //强制label个数
xAxis.avoidFirstLastClippingEnabled = YES; //避免文字显示不全 这个属性很重要
xAxis.granularityEnabled = YES; //设置重复不显示
//不画线
xAxis.drawGridLinesEnabled = NO;
xAxis.spaceMin = 0.5;
xAxis.spaceMax = 0.5;

CandleChartDataEntry代码每个柱子图形

    NSMutableArray *array = [NSMutableArray array];
for (int i = 0; i < datas.count; i++) {
NSDictionary *dict = datas[i];
double high = [dict[@"dbHighPrice"] doubleValue];
double low = [dict[@"dbLowPrice"] doubleValue];
double open = [dict[@"dbOpenPrice"] doubleValue];
double close = [dict[@"dbClosePrice"] doubleValue];
CandleChartDataEntry *entry = [[CandleChartDataEntry alloc] initWithX:(i) shadowH:high shadowL:low open:open close:close];
[array addObject:entry];
}

CandleChartDataSet代码所有的柱子的集合

    CandleChartDataSet *set = [[CandleChartDataSet alloc] initWithEntries:array label:@"kLine DataSet"];
//下降颜色 是否填充填充
set.decreasingColor = UIColorHex(0x32BE89);
set.decreasingFilled = YES;
//上升颜色 是否填充填充
set.increasingColor = UIColorHex(0xFD4C60);
set.increasingFilled = YES;
//显示美国线
//set.showCandleBar = NO;
//阴影线的宽度 颜色跟随
set.shadowWidth = 0.7;
set.shadowColorSameAsCandle = YES;
//k线柱间隙
set.barSpace = 0.15;
//是否现在十字标识
set.drawHorizontalHighlightIndicatorEnabled = NO;
set.drawVerticalHighlightIndicatorEnabled = NO;
//轴线方向
set.axisDependency = AxisDependencyRight;
//不显数字
set.drawValuesEnabled = NO;

CandleChartData

    //创建数据
CandleChartData *candleData = [[CandleChartData alloc] initWithDataSet:set];
//赋值
self.chartView.data = candleData;

一些需要注意的点:

1.显示美国线

    CandleChartDataSet:
set.showCandleBar = NO

2.影线的颜色跟随k线,这样就会根据k线值自动变成绿色或者红色

    CandleChartDataSet:
set.shadowWidth = 0.7;
set.shadowColorSameAsCandle = YES;

3.k线上升颜色,是否填充等属性,用来设置上升颜色下降颜色,是否是空心实心k线

    CandleChartDataSet:
//下降颜色 是否填充填充
set.decreasingColor = UIColorHex(0x32BE89);
set.decreasingFilled = YES;
//上升颜色 是否填充填充
set.increasingColor = UIColorHex(0xFD4C60);
set.increasingFilled = NO;

4.是否显示k线值

    CandleChartDataSet:
//不显数字
set.drawValuesEnabled = NO;

5.是否显示十字光标

    CandleChartDataSet:
set.drawHorizontalHighlightIndicatorEnabled = NO;
set.drawVerticalHighlightIndicatorEnabled = NO;

6.轴线方向 AxisDependencyRight 这样当我们滑动k线的时候k线会根据当前k线最大值和最小值调整缩放比例

    CandleChartDataSet:
//轴线方向
set.axisDependency = AxisDependencyRight;

7.k线设置缩放比例,最大缩放值 最小缩放值

    //最大缩放值 最小缩放值  y轴不缩放 minScl maxScl根据实际情况调整
[self.chartView setScaleMinima:minScl scaleY:1];
[self.chartView.viewPortHandler setMaximumScaleX:maxScl];

8.当前缩放比例设置

    CGAffineTransform srcMatrix = _chartView.viewPortHandler.touchMatrix;
//scl根据实际情况设置当前缩放比例
srcMatrix.a = scl;
[self.chartView.viewPortHandler refreshWithNewMatrix:srcMatrix chart:self.chartView invalidate:YES];

9.k线移动到指定位置 第一次需要滚动到最新值

    //开局移动到最右边xMax为最大x轴值
[self.chartView moveViewToX:self.chartView.data.xMax];

10.选中k线,拿到当前选中的点的x轴坐标,以便于拿到选中的model

//k线代理方法
-(void)chartValueSelected:(ChartViewBase *)chartView entry:(ChartDataEntry *)entry highlight:(ChartHighlight *)highlight{
NSInteger index = highlight.x;
//index为当前选中的x值
if(index < self.datas.count){
//根据当前的index能拿到对应的数据模型
Model *model = self.datas[index];
}
}

其他待续

转载请标注来源:https://www.cnblogs.com/qqcc1388/

iOS 图表工具charts之CandleStickChartView(K线)的更多相关文章

  1. iOS 图表工具charts之CombinedChartView

    关于charts的系列视图介绍传送门: iOS 图表工具charts介绍 iOS 图表工具charts之LineChartView iOS 图表工具charts之BarChartView iOS 图表 ...

  2. iOS 图表工具charts之LineChartView

    关于charts的系列视图介绍传送门: iOS 图表工具charts介绍 iOS 图表工具charts之LineChartView iOS 图表工具charts之BarChartView iOS 图表 ...

  3. iOS 图表工具charts介绍

    charts是一个很好的绘图工具,功能非常强大,可以用来绘制折线,柱状图,饼状图,k线图,k线分时图,雷达图,气泡图等等,charts是一款仿照安卓 MPAndroidChart而来的一个基于swif ...

  4. iOS 图表工具charts之BarChartView

    关于charts的系列视图介绍传送门: iOS 图表工具charts介绍 iOS 图表工具charts之LineChartView iOS 图表工具charts之BarChartView iOS 图表 ...

  5. iOS 图表工具charts之PieChartView

    关于charts的系列视图介绍传送门: iOS 图表工具charts介绍 iOS 图表工具charts之LineChartView iOS 图表工具charts之BarChartView iOS 图表 ...

  6. JHChart 1.1.0 iOS图表工具库中文ReadMe

    JHChart(最新版本1.1.0) 好吧,的确当前的github上已经存有不少的iOS图表工具库,然而,当公司的项目需要图表时,几乎没有哪个第三方能够完全满足我的项目需求.无奈之下,本人不得不花费一 ...

  7. JHChart iOS图表工具库1.0.3新版本详解

    前言. 从2016年4月14日开始,本人着手开发了JHChart图表工具库.经过断断续续的开发,截止到现在,已经实现了折线图.柱状图.饼状图.环形图和表格样式的图表功能.为了方便使用,我已经将一个简单 ...

  8. iOS图表库Charts集成与使用

    Charts是一个很优秀的图表库,它支持Android.iOS.tvOS和macOS,这样使用起来,可以节省学习成本,可以从GitHub上了解更多信息.本文记录在iOS项目上的集成与使用. Chart ...

  9. iOS 使用Charts框架 折线,柱状,K线,饼状,雷达全攻略

    我是前言: 大约几个月前我在某平台写了一篇文章, 文中简单地介绍了Charts两种图表的样式的使用, 不过有种意犹未尽的感觉, 利用周末的空闲时间再次看了看, 有了新的收获, 今天发出来,分享给大家, ...

随机推荐

  1. 4.flask第三方组件

    1.flask-session的使用 在flask中,有一个app.session_interface = SecureCookieSessionInterface(),也就是存session,调用o ...

  2. 多线程 - 线程通信 suspend-resume wait-notify park-unpark 伪唤醒

    线程通信(如 线程执行先后顺序,获取某个线程执行的结果等)有多种方式: 文件共享 线程1 --写入--> 文件 < --读取-- 线程2 网络共享 变量共享 线程1 --写入--> ...

  3. CAS JDK 证书错误学习笔记

    通过之前生产上发现的问题总结得出以下结论:  问题现象就是:由F5 进行分发到cas 两个服务端 导致 客户端访问时  (时好时坏的现象 ) 通过在服务端的查看apahce 的访问日志得出的结论  发 ...

  4. C++的一些黑暗料理

    本文中的“黑暗料理”仅限本人在学习C++的过程中感觉易忘.有趣.不为大多数人所知的一些特性. 1. C++中int型数据在VC++环境下最小值为什么是 -32678,而不是-32677,其中涉及到原码 ...

  5. Codeforces 999

    A /*Huyyt*/ #include<bits/stdc++.h> #define mem(a,b) memset(a,b,sizeof(a)) using namespace std ...

  6. 前端面试题-clearfix(清除浮动)

    一.浮动的概念 浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止.由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样. 二.浮动的影响 1. ...

  7. silverlight发布设置

    HTTP头 - MIME类型.xap xapapplication/x-silverlight .xaml application/xaml+xml

  8. cgi 检索Cookie信息

    Cookie信息检索页非常简单,Cookie信息存储在CGI的环境变量HTTP_COOKIE中,存储格式如下: key1=value1;key2=value2;key3=value3.... 以下是一 ...

  9. 计蒜客 window画图

    在 Windows 的"画图"工具里,可以绘制各种各样的图案.可以把画图当做一个标准的二维平面,在其上先后绘制了 nn 条颜色互不相同的线段. 输出格式 输出 qq 行,每行一个整 ...

  10. Makefile文件试错

    1成功: src = $(wildcard ./*cpp) obj = $(patsubst %.cpp,%.o ,$(src)) target = test $(target) : $(obj) g ...