/** 返回只有左Y轴的折线图*/
+ (LineChartView *)lineChartViewForLeftWithDelegate:(id)target
{
LineChartView *lineChartView = [[LineChartView alloc] init];
lineChartView.delegate = target;
lineChartView.backgroundColor = [UIColor whiteColor];
lineChartView.noDataText = @"";
lineChartView.descriptionText = @"";
lineChartView.scaleYEnabled = NO;//取消Y轴缩放
lineChartView.doubleTapToZoomEnabled = NO;//取消双击缩放
lineChartView.dragDecelerationEnabled = YES;//拖拽后是否有惯性效果
lineChartView.dragDecelerationFrictionCoef = 0.9;//拖拽后惯性效果的摩擦系数(0~1),数值越小,惯性越不明显
lineChartView.xAxis.labelPosition = XAxisLabelPositionBottom;//X轴的显示位置,
// 不绘制 右-y轴
lineChartView.rightAxis.enabled = NO;
// x 轴
lineChartView.xAxis.axisLineWidth = 0.5;
lineChartView.xAxis.axisLineColor = RGB(40, 40, 40);
// 网格线 纵线
lineChartView.xAxis.gridLineWidth = 0.5;
lineChartView.xAxis.gridColor = RGB(235, 235, 235);
// 左侧 y轴
lineChartView.leftAxis.axisLineWidth = 0.5;
lineChartView.leftAxis.axisLineColor = RGB(40, 40, 40);
// 左侧网格线 横线
lineChartView.leftAxis.gridLineWidth = 0.5;
lineChartView.leftAxis.gridColor = RGB(235, 235, 235);
// 图标右下角 描述文字
lineChartView.legend.form = ChartLegendFormSquare;
// legend 图例 大小
lineChartView.legend.formSize = 10;
// 图例文字颜色
lineChartView.legend.textColor = RGB(242, 152, 80);
lineChartView.xAxis.valueFormatter = target;
return lineChartView;
}
/** 返回有左右Y轴的折线图*/
+ (LineChartView *)lineChartViewForBothWithDelegate:(id)target;
{
LineChartView *lineChartView = [[LineChartView alloc] init];
lineChartView.delegate = target;
lineChartView.backgroundColor = [UIColor whiteColor];
lineChartView.noDataText = @"";
lineChartView.descriptionText = @"";
lineChartView.scaleYEnabled = NO;//取消Y轴缩放
lineChartView.doubleTapToZoomEnabled = NO;//取消双击缩放
lineChartView.dragDecelerationEnabled = YES;//拖拽后是否有惯性效果
lineChartView.dragDecelerationFrictionCoef = 0.9;//拖拽后惯性效果的摩擦系数(0~1),数值越小,惯性越不明显
lineChartView.xAxis.labelPosition = XAxisLabelPositionBottom;//X轴的显示位置,默认是显示在上面的
// 左侧 Y轴的起点和最大最小值、个数、未确定
// x 轴
lineChartView.xAxis.axisLineWidth = 0.5;
lineChartView.xAxis.axisLineColor = RGB(40, 40, 40);
// 网格线 纵线
lineChartView.xAxis.gridLineWidth = 0.5;
lineChartView.xAxis.gridColor = RGB(235, 235, 235);
// 左侧 y 周
lineChartView.leftAxis.axisLineWidth = 0.5;
lineChartView.leftAxis.axisLineColor = RGB(40, 40, 40);
// 左侧网格线 横线
lineChartView.leftAxis.gridLineWidth = 0.5;
lineChartView.leftAxis.gridColor = RGB(235, 235, 235);
// 右侧 y周
lineChartView.rightAxis.axisLineWidth = 0.5;
lineChartView.rightAxis.axisLineColor = RGB(40, 40, 40);
// 右侧网格线 横线
lineChartView.rightAxis.gridLineWidth = 0.5;
lineChartView.rightAxis.gridColor = RGB(235, 235, 235);
// 右侧网 横线
// 图标右下角 描述文字
lineChartView.legend.form = ChartLegendFormLine;
// legend 图例 大小
lineChartView.legend.formSize = 10;
// 图例文字颜色
lineChartView.legend.textColor = RGB(242, 152, 80);
lineChartView.xAxis.valueFormatter = target;
return lineChartView;
}
/** 返回只有左Y轴的柱状图*/
+ (BarChartView *)barChartViewWithDelegate:(id)target
{
BarChartView *barChartView = [[BarChartView alloc] init];
barChartView.delegate = target;
// 描述文字 无数据文字
barChartView.chartDescription.enabled = NO;
barChartView.noDataText = @"";
// 捏合手势 与 双击手势
barChartView.pinchZoomEnabled = NO;
barChartView.doubleTapToZoomEnabled = NO;
// 是否允许x、y轴进行缩放
barChartView.scaleYEnabled = NO;
barChartView.scaleXEnabled = NO;
barChartView.drawBarShadowEnabled = NO;
barChartView.drawGridBackgroundEnabled = NO;
// 图例设置
barChartView.legend.position = ChartLegendPositionBelowChartLeft;
barChartView.legend.font = [UIFont systemFontOfSize:10.f];
// 取消高亮
barChartView.highlightPerTapEnabled = NO;
barChartView.xAxis.drawGridLinesEnabled = NO;
barChartView.xAxis.labelPosition = XAxisLabelPositionBottom;
barChartView.xAxis.labelFont = [UIFont systemFontOfSize:10.f];
barChartView.xAxis.granularity = 1.f;
barChartView.xAxis.centerAxisLabelsEnabled = YES;
barChartView.xAxis.valueFormatter = target;
// 左 x 轴
barChartView.leftAxis.gridLineWidth = 0.5;
barChartView.leftAxis.gridColor = RGB(235, 235, 235);
barChartView.leftAxis.labelFont = [UIFont systemFontOfSize:10.f];
barChartView.leftAxis.spaceTop = 0.35;
barChartView.rightAxis.enabled = NO;
[barChartView zoomWithScaleX:2.5 scaleY:1 x:1 y:0];
return barChartView;
}
/** 返回有左右Y轴的混合图(折线图&&柱状图)*/
+ (CombinedChartView *)comChartViewWithDelegate:(id)target
{
CombinedChartView *comChartView = [[CombinedChartView alloc] init];
comChartView.delegate = target;
// 描述文字 无数据文字
comChartView.chartDescription.enabled = NO;
comChartView.noDataText = @"";
// 捏合手势 与 双击手势
comChartView.pinchZoomEnabled = NO;
comChartView.doubleTapToZoomEnabled = NO;
// 是否允许x、y轴进行缩放
comChartView.scaleYEnabled = NO;
comChartView.scaleXEnabled = NO;
comChartView.drawGridBackgroundEnabled = NO;
comChartView.drawBarShadowEnabled = NO;
comChartView.highlightPerTapEnabled = NO;
comChartView.drawOrder = @[ @(CombinedChartDrawOrderBar), @(CombinedChartDrawOrderLine)];
comChartView.legend.position = ChartLegendPositionBelowChartLeft;
comChartView.legend.font = [UIFont systemFontOfSize:10.f];
comChartView.leftAxis.gridLineWidth = 0.5;
comChartView.leftAxis.gridColor = RGB(235, 235, 235);
comChartView.leftAxis.labelFont = [UIFont systemFontOfSize:10.f];
comChartView.leftAxis.spaceTop = 0.35;
comChartView.rightAxis.gridLineWidth = 0.5;
comChartView.rightAxis.gridColor = RGB(235, 235, 235);
comChartView.rightAxis.labelFont = [UIFont systemFontOfSize:10.f];
comChartView.rightAxis.spaceTop = 0.35;
comChartView.xAxis.labelPosition = XAxisLabelPositionBottom;
comChartView.xAxis.granularity = 1.0;
comChartView.xAxis.valueFormatter = target;
comChartView.xAxis.drawGridLinesEnabled = NO;
return comChartView;
}
OC调用Charts绘制图表(初始化工具类)
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 之前一直都说要写关于绘制折线和柱状图的相关文章,之前在忙新的项目,这几天不忙,也是之前那篇文章有小伙伴问我折线与柱...
- 多系列柱状图,这里基本的就不说了,接着之前的文章,直接写到数据赋值的处理: 效果图如下: 多系列柱状图主要的几行代...
- 折线与单系列柱状图混合图表绘制数据处理赋值 效果图如下: 混合图表绘制套路基本和折线、柱状图绘制相同,主要有俩点,...
- Xcode8集成Charts 1.首先咱们先在Github下载一个最新的Charts,然后新建一个OC的工程,名字...