最近的项目里面用到了饼图和条形统计图,饼图用的是PNChart来做的,这个库感觉用起来也简单,但是做条形统计图的时候就特别蛋疼(不知道是不是我姿势没对),反正就是各种问题,然后就想到换一种框架,最后选定了iOS-ECharts,ECharts是百度团队开发的。iOS-ECharts是Pluto Y封装的,蛋疼的是一句注释都没有,要对照着百度的文档来看,这个框架的效果倒是牛皮哄哄的,第一次加载会有点慢,要等一下,还有就是在配置PYOption的时候,属性特别的多,不管是用block还是创建对象来设置都看着比较多,没办法,还是得一个一个的设置好。我自己单独又封装了一遍,用起来变得稍微简单一些了。至少看着没那么大一堆的东西在那放着。不吐槽了。先看下demo的效果吧(只做了4个条形图哦)

暂时就做了这四种样式,感觉比较常用的,还有更复杂的要求的,可以参考Pluto Y写的Demo,demo链接在此各个参数的参考手册在此

最后一张图是我要用到的效果,看着挺简单的,绕了我好久才知道怎么做。原因是忽略了一个属性,在PYCartesianSeries里面有个属性是stack,这个属性是用来做堆积图的,就好像图二这种,当你添加了多个series的时候,并且把stack值设置成一致,就会堆积起来,如果不一致就会变成图三,变成类似于分组的展示,当然这些bar的宽度都是可调的,还能放大缩小(暂时没做这个功能,可以参考大神demo),然后就是颜色的问题,在配置PYOption的时候,这个东西里面有一个color,类型为id,实际就是传一个数组就好了,每种颜色对应一个类别legend.data,当颜色个数没类别多时就会循环利用颜色值。调用代码如下:

    self.option = [XBZPYOptionManager configOptionWithStack:@[@"common", @"common", @"common"]];
self.option.color = @[@"#FF0000", @"#00FF00", @"#0000FF"];
self.option.legend.data = @[@"水果", @"肉类", @"蛋类"].mutableCopy;
self.option.xAxis.firstObject.data = @[@"苹果", @"香蕉", @"鸡肉", @"鸭蛋", @"恐龙蛋"].mutableCopy;
self.option.series[].nameEqual(@"水果").dataEqual(@[@"", @"", @"-", @"-", @"-"]);
self.option.series[].nameEqual(@"肉类").data = @[@"-", @"-", @"", @"-", @"-"].mutableCopy;
self.option.series[].nameEqual(@"蛋类").data = @[@"-", @"-", @"-", @"", @""].mutableCopy; [self.echartsView setOption:self.option];
[self.echartsView loadEcharts];
XBZPYOptionManager这个类是我自己封装了一遍(里面预先设置了一些通用的属性,后面就根据不同的要求修改数据源就好了),根据传入的stack个数来创建相应个数的series,也就是类别legend对应的数据源设置类,我将他们的stack都设置成一致,然后不同类别的
数据都使用@"-"进行补位,本来应该叠加到一起的三种柱状图就此变成了一种(机智如我),然后就实现了图四的样子,再来看看stack不同的时候:
    self.option = [XBZPYOptionManager configOptionWithStack:@[@"one", @"two", @"three"]];
self.option.color = @[@"#AA0000", @"#00AA00", @"#0000AA"];
self.option.legend.data = @[@"水果", @"肉类", @"蛋类"].mutableCopy;
self.option.xAxis.firstObject.data = @[@"一月份", @"二月份", @"三月份", @"四月份", @"五月份"].mutableCopy;
self.option.series[].nameEqual(@"水果").dataEqual(@[@"", @"", @"", @"", @""]);
self.option.series[].nameEqual(@"肉类").data = @[@"", @"", @"", @"", @""].mutableCopy;
self.option.series[].nameEqual(@"蛋类").data = @[@"", @"", @"", @"", @""].mutableCopy; [self.echartsView setOption:self.option];
[self.echartsView loadEcharts];

大的类型依旧不变,stack的值都互不相同,将x轴的数据变成按月来做统计,然后数据不补位,如此便得到了图三的效果,这个是比较容易的,看大神的demo就很容易知道。其他两种就不多说了。都差不多类似了。之前网上找来找去都是一篇文章,然后放弃了,最后加了他们的群也没给我整明白,还是得靠自己,反复的看demo终于让我找到了这个问题所在。在此基础上还可以做更多灵活的变通。希望可以帮到跟我遇到一样问题的盆友。

最后附上我这个demo的地址,(里面我也没写啥注释,哈哈,基本的属性还是得看文档和自己实践才能印象深刻)

使用第三方库iOS-ECharts做柱状图的心得的更多相关文章

  1. python中常用第三方库记录

    python中有很多很好用的第三方库,现在记录一下这些库以及如何下载 一.virtualenv,这是一个可以将生产环境隔离开的python库,非常好用 在linux下使用pip install vir ...

  2. iOS开发常用第三方库

    UI 动画 网络相关 Model 其他 数据库 缓存处理 PDF 图像浏览及处理 摄像照相视频音频处理 响应式框架 消息相关 版本新API的Demo 代码安全与密码 测试及调试 AppleWatch ...

  3. IOS常用第三方库《转》

    UI 动画 网络相关 Model 其他 数据库 缓存处理 PDF 图像浏览及处理 摄像照相视频音频处理 响应式框架 消息相关 版本新API的Demo 代码安全与密码 测试及调试 AppleWatch ...

  4. iOS 第三方库、插件、知名博客总结

    iOS 第三方库.插件.知名博客总结 用到的组件 1.通过CocoaPods安装 项目名称 项目信息 AFNetworking 网络请求组件 FMDB 本地数据库组件 SDWebImage 多个缩略图 ...

  5. iOS常用第三方库大全,史上最全第三方库收集

    下拉刷新 EGOTableViewPullRefresh – 最早的下拉刷新控件. SVPullToRefresh – 下拉刷新控件. MJRefresh – 仅需一行代码就可以为UITableVie ...

  6. iOS非常全的第三方库

    iOS ● 非常全的三方库.插件.大牛博客等等   github排名:https://github.com/trending, github搜索:https://github.com/search. ...

  7. 最全面的iOS和Mac开源项目和第三方库汇总

    标签: UI 下拉刷新 EGOTableViewPullRefresh – 最早的下拉刷新控件. SVPullToRefresh – 下拉刷新控件. MJRefresh – 仅需一行代码就可以为UIT ...

  8. iOS:实现图片的无限轮播(二)---之使用第三方库SDCycleScrollView

    iOS:实现图片的无限轮播(二)---之使用第三方库SDCycleScrollView 时间:2016-01-19 19:13:43      阅读:630      评论:0      收藏:0   ...

  9. ios常用的第三方库

    ios开发中有可能用到的第三方库进行记录一下: 注:资料信息来源于网络 自己整理  https://developer.apple.com/reference(苹果官方文档) https://gith ...

随机推荐

  1. (C/C++) 用函数返回一个结构体

    方法一: 参数里含有指向指针的指针. 注意:如果函数参数里只有一个指向结构体的指针,是无法正确地返回结构体的值的.原因在于在编译的时候,会对入参p产生一个备份_p. 参考此文:http://www.c ...

  2. C# 获取窗口句柄并且关闭应用程序

    原文:http://www.cnblogs.com/oraclejava/articles/1549025.html public class User32API { private static H ...

  3. Hush Framework框架配置(转)

    在写这篇文章的时候,楼主已经饿的不行了,因为我从3点开始就在折腾Hush Framework,走了很多弯路,打铁要趁热,先把基本的过程记录下来,留待以后翻阅,同时记录其中容易走弯路的地方,特别是对于一 ...

  4. Idea工具使用

    Idea Project与module的理解 1.基础环境的搭建 1.1.IDEA使用--字体.编码和基本设置 2.插件的安装 2.1.在IDEA中配置Gauge环境 2.2.IdeaVim的安装:: ...

  5. wpf 转型 android开发总结

    今年马上就要过去了,这一年中我经历了从wpf转型到qt/qml,然后最近又要开始搞android,从我个人的经验来看不论是qml还是android从框架和设计上都跟wpf类似,并且移动端的设计因为很多 ...

  6. GIT团队合作探讨之一-保持工作同步的概念和实践

    感谢英文原文作者,这是我看到的关于git协同工作写的最清晰简洁的文章了: https://www.atlassian.com/git/tutorials/syncing/git-push SVN使用一 ...

  7. 【NLP_Stanford课堂】语言模型3

    一.产生句子 方法:Shannon Visualization Method 过程:根据概率,每次随机选择一个bigram,从而来产生一个句子 比如: 从句子开始标志的bigram开始,我们先有一个( ...

  8. POI读取xls和xlsx

    import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import  ...

  9. linux下生成带符号的随机密码

    cat /dev/urandom |tr -dc "[:graph:]"|fold -w 15|head 结果如下:

  10. 《C++ Primer Plus》读书笔记之——处理数据

    本文旨在记录在阅读<C++ Primer Plus>第五版的过程中,一些重点的知识点,方便以后查阅.本文将不断更新...... 一.第三章 处理数据 1.无符号整型不能存储负数值,其优点是 ...