mark 百度Echarts统计图表
* 百度Echarts统计图表* @author cuichen* @version 1.0* @since 1.0* @date 2015-11-16*/@Controller@RequestMapping(value = "ks/chart")public class KSChartController extends BaseController {@RequestMapping(value = "/line")@ResponseBodypublic Object line(HttpSession session,HttpServletResponse response, HttpServletRequest request,ModelMap modelMap, String sqlx, String sqly, String sqlz) throws Exception {sqlx= HtmlUtils.htmlUnescape(sqlx);sqly= HtmlUtils.htmlUnescape(sqly);sqlz= HtmlUtils.htmlUnescape(sqlz);List<Map<Object, Object>> xList = DBUtils.executeQuery(sqlx, false);List<Map<Object, Object>> yList = DBUtils.executeQuery(sqly, false);List<Map<Object, Object>> zList = DBUtils.executeQuery(sqlz, false);Map<String, Object> option = new HashMap<String, Object>();Map<String, Object> xAxis = new HashMap<String, Object>();List<String> data = new ArrayList<String>();for(int i=0; i<xList.size(); i++) {data.add(xList.get(i).get("VALUE").toString());}xAxis.put("data", data);option.put("xAxis", xAxis);Map<String, Object> legend = new HashMap<String, Object>();data = new ArrayList<String>();for(int i=0; i<zList.size(); i++) {data.add(zList.get(i).get("NAME").toString());}legend.put("data", data);option.put("legend", legend);List<Map<Object, Object>> series = new ArrayList<Map<Object,Object>>();for(int i=0; i<zList.size(); i++) {Map<Object, Object> zMap = zList.get(i);Map<Object, Object> seriesMap = new HashMap<Object, Object>();String zKey = zMap.get("KEY").toString();seriesMap.put("zkey", zKey);seriesMap.put("name", zMap.get("NAME"));seriesMap.put("type", "line");List<Double> yData = new ArrayList<Double>();for(int j=0; j<xList.size(); j++) {Map<Object, Object> xMap = xList.get(j);String xkey = xMap.get("KEY").toString();boolean isAdd = false;for(int k=0; k<yList.size(); k++) {Map<Object, Object> yMap = yList.get(k);if(yMap.get("ZKEY") != null && yMap.get("XKEY") != null && zKey.equals(yMap.get("ZKEY").toString()) && xkey.equals(yMap.get("XKEY").toString())) {yData.add(Double.parseDouble(yMap.get("VALUE").toString()));isAdd = true;break;}}if(!isAdd) {yData.add(0D);}}seriesMap.put("data", yData);series.add(seriesMap);}option.put("series", series);return option;}@RequestMapping(value = "/bar")@ResponseBodypublic Object bar(HttpSession session,HttpServletResponse response, HttpServletRequest request,ModelMap modelMap, String sqlx, String sqly, String sqlz) throws Exception {sqlx= HtmlUtils.htmlUnescape(sqlx);sqly= HtmlUtils.htmlUnescape(sqly);sqlz= HtmlUtils.htmlUnescape(sqlz);List<Map<Object, Object>> xList = DBUtils.executeQuery(sqlx, false);List<Map<Object, Object>> yList = DBUtils.executeQuery(sqly, false);List<Map<Object, Object>> zList = DBUtils.executeQuery(sqlz, false);Map<String, Object> option = new HashMap<String, Object>();Map<String, Object> xAxis = new HashMap<String, Object>();List<String> data = new ArrayList<String>();for(int i=0; i<xList.size(); i++) {data.add(xList.get(i).get("VALUE").toString());}xAxis.put("data", data);option.put("xAxis", xAxis);Map<String, Object> legend = new HashMap<String, Object>();data = new ArrayList<String>();for(int i=0; i<zList.size(); i++) {data.add(zList.get(i).get("NAME").toString());}legend.put("data", data);option.put("legend", legend);List<Map<Object, Object>> series = new ArrayList<Map<Object,Object>>();for(int i=0; i<zList.size(); i++) {Map<Object, Object> zMap = zList.get(i);Map<Object, Object> seriesMap = new HashMap<Object, Object>();String zKey = zMap.get("KEY").toString();seriesMap.put("name", zMap.get("NAME"));seriesMap.put("type", "bar");if(zMap.get("STACK")!=null && StringUtils.isNoneBlank(zMap.get("STACK").toString())) {seriesMap.put("stack", zMap.get("STACK").toString());}List<Double> yData = new ArrayList<Double>();for(int j=0; j<xList.size(); j++) {Map<Object, Object> xMap = xList.get(j);String xkey = xMap.get("KEY").toString();boolean isAdd = false;for(int k=0; k<yList.size(); k++) {Map<Object, Object> yMap = yList.get(k);if(yMap.get("ZKEY") != null && yMap.get("XKEY") != null && zKey.equals(yMap.get("ZKEY").toString()) && xkey.equals(yMap.get("XKEY").toString())) {yData.add(Double.parseDouble(yMap.get("VALUE").toString()));isAdd = true;break;}}if(!isAdd) {yData.add(0D);}}seriesMap.put("data", yData);series.add(seriesMap);}option.put("series", series);return option;}@RequestMapping(value = "/pie")@ResponseBodypublic Object pie(HttpSession session,HttpServletResponse response, HttpServletRequest request,ModelMap modelMap, String sqlx, String sqly, String sqlz) throws Exception {sqlx= HtmlUtils.htmlUnescape(sqlx);sqly= HtmlUtils.htmlUnescape(sqly);sqlz= HtmlUtils.htmlUnescape(sqlz);List<Map<Object, Object>> xList = DBUtils.executeQuery(sqlx, false);List<Map<Object, Object>> yList = DBUtils.executeQuery(sqly, false);List<Map<Object, Object>> zList = DBUtils.executeQuery(sqlz, false);Map<String, Object> option = new HashMap<String, Object>();Map<String, Object> legend = new HashMap<String, Object>();List<String> data = new ArrayList<String>();for(int i=0; i<xList.size(); i++) {data.add(xList.get(i).get("VALUE").toString());}legend.put("data", data);option.put("legend", legend);List<Map<Object, Object>> series = new ArrayList<Map<Object,Object>>();for(int i=0; i<zList.size(); i++) {Map<Object, Object> zMap = zList.get(i);Map<Object, Object> seriesMap = new HashMap<Object, Object>();List<Map<Object, Object>> seriesData = new ArrayList<Map<Object,Object>>();String zKey = zMap.get("KEY").toString();seriesMap.put("name", zMap.get("NAME"));seriesMap.put("type", "pie");seriesMap.put("zkey", zKey);for(int j=0; j<xList.size(); j++) {Map<Object, Object> xMap = xList.get(j);String xkey = xMap.get("KEY").toString();String xvalue = xList.get(j).get("VALUE").toString();boolean isAdd = false;for(int k=0; k<yList.size(); k++) {Map<Object, Object> yMap = yList.get(k);if(yMap.get("ZKEY") != null && yMap.get("XKEY") != null && zKey.equals(yMap.get("ZKEY").toString()) && xkey.equals(yMap.get("XKEY").toString())) {Map<Object, Object> sd = new HashMap<Object, Object>();sd.put("value", Double.parseDouble(yMap.get("VALUE").toString()));sd.put("name", xvalue);seriesData.add(sd);isAdd = true;break;}}if(!isAdd) {Map<Object, Object> sd = new HashMap<Object, Object>();sd.put("value", 0D);sd.put("name", xvalue);seriesData.add(sd);}}seriesMap.put("data", seriesData);series.add(seriesMap);}option.put("series", series);return option;}}
mark 百度Echarts统计图表的更多相关文章
- 完整版ajax+百度echarts实现统计图表demo并随着窗口大小改变而自适应
1.前言 百度Echarts会常用到我们的项目中做统计,api很详细,demo也非常之多,我们常用的是应有尽有了,做一些小项目的时候,百度echarts的demo已足够用了.今天呢.主要是跟小白讲一下 ...
- 百度echarts可以做什么
百度echarts可以做什么 一.总结 一句话总结:可视化做的很好,各种图都有.而且支持动态数据. 二.百度eCharts体验 前言 从昨天开始给项目里添加一些图表对比功能,上一个项目里使用的是Hig ...
- WPF仿百度Echarts人口迁移图
GitHub地址:https://github.com/ptddqr/wpf-echarts-map/tree/master 关于大名鼎鼎的百度Echarts我就不多说了 不了解的朋友直接看官方的例子 ...
- C#+JQuery+.Ashx+百度Echarts实现全国省市地图和饼状图动态数据图形报表的统计
在目前的一个项目中,需要用到报表表现数据,这些数据有多个维度,需要同时表现出来,同时可能会有大量数据呈现的需求,经过几轮挑选,最终选择了百度的echarts作为报表基础类库.echarts功能强大,界 ...
- 百度echarts使用--y轴label数字太长难以全部显示
问题: 今天遇到个小问题,我们系统前端呈现使用了百度echarts.在绘制折线图的时候,因为数字过大,导致显示出现了问题. 解决方案: 左边y轴的值默认是根据我们填充进去的值来默认分割的,因为原始值就 ...
- 百度ECharts数据绑定诀窍
百度Echarts的功能还是蛮好用的.. 不能说多好但是也不次.. 下边就分享一些数据绑定经验..对在处理过程中的思路有一些帮助... 报表里用的最多的可以说是 饼状图和柱形图.. 饼状图里当然是包括 ...
- 使用百度Echarts制作力导向图
最近项目需求制作一个力导向图来展示企业的画像等关系信息,故想到了百度Echarts的关系图,在这使用Echarts3.0版本来实现.先上效果图,再看代吗 哎,本来想整个工程扔出来,发现好像没地方上传附 ...
- 网页图表类框架(插件)——百度eCharts和Highcharts
ECharts, 缩写来自Enterprise Charts,商业级数据图表,一个纯Javascript的图表库, 可以流畅的运行在PC和移动设备上,兼容当前绝大部分浏览器(IE6/7/8/9 /10 ...
- 微信小说分销系统设计之使用百度Echarts地图统计功能统计微信粉丝地域分布情况
/** 转载请保留博客园原地址以及版权声明,请勿恶意修改,本博客中的内容均属于技术交流,请勿用于商业用途,谢谢配合 * 作者:杨浩瑞 QQ:1420213383 独立博客:http://www. ...
随机推荐
- Go常用功能总结一阶段
1. go语言从键盘获取输入内容 <1. 最简单的办法是使用 fmt 包提供的 Scan 和 Sscan 开头的函数.请看以下程序: package main import "fmt& ...
- Android -- Camera源码简析,启动流程
com.android.camera.Camera.java,主要的实现Activity,继承于ActivityBase. ActivityBase 在ActivityBase中执行流程: onCre ...
- ListView 控件与 内容
1)由控件获取内容:ListViewItem item = Utilities.GetVisualParent<ListViewItem>(chx); if (item == null) ...
- Win10系统下面的TR1008解决方案
最近为了体验高大上的Win10系统,于是就把本本原来的Win7旗舰版 升级 到了Win10专业版.之后又在本本上部署了cognos,但是在打开Transform导入IQD数据源的时候就报错了,错误和之 ...
- poj_1681_高斯消元
这道题和之前的把那一道1222很类似.仅仅只是一定要注意一下对于无解的推断. /*########################################################### ...
- Window 下安装 Redis
Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. 一.Window 下安装 redis https://github.com/MicrosoftArchive/r ...
- STL - 容器 - 运行期指定排序准则
RuntimeCmp.hpp #include <set> using namespace std; // type for runtime sorting criterion class ...
- ZH奶酪:标准偏差
标准偏差 标准偏差(Std Dev,Standard Deviation) -统计学名词.一种量度数据分布的分散程度之标准,用以衡量数据值偏离算术平均值的程度.标准偏差越小,这些值偏离平均值就越少,反 ...
- HDU1698:Just a Hook(线段树区间更新)
Problem Description In the game of DotA, Pudge’s meat hook is actually the most horrible thing for m ...
- android kernel控制台初始化过程
对于我们的android平台,控制台被定义到了串口1上,因此初始化过程就是把控制台的输出配置到串口1上 对kernel控制台初始化是在挂载文件系统之前,由于没有串口的设备文件,不能通过打开设备文件来访 ...