博客
关于我
Highcharts之动态数据实时折线图(时间折线图)
阅读量:339 次
发布时间:2019-03-04

本文共 2249 字,大约阅读时间需要 7 分钟。

一、前言

想要实现的效果是,每秒钟动态获取后台数据,进行显示,在网上找了下,先看了下Echarts的效果:

这种效果,还行,我想显示的有3条数据,然后又看下了Highcharts,发现了他也有这种效果:

然后我在他的示例上修改成了如下:

两个Y轴显示文字。

 

二、源码

代码如下:

    
Highcharts Example

后台模拟了一个简单的数据:

@GetMapping("vintage")    @ResponseBody    public List
>> vintage(){ List
>> resultList = Lists.newArrayList(); List
> oneList = Lists.newArrayList(); List
> twoList = Lists.newArrayList(); List
> shoList = Lists.newArrayList(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); Date now = new Date(); for (int i = 0; i < 20; i++) { Calendar nowTime = Calendar.getInstance(); nowTime.add(Calendar.MINUTE, i); List
ss = Lists.newArrayList(); ss.add(nowTime.getTimeInMillis()); ss.add(new Long((long)getRandom(100,i))); oneList.add(ss); System.out.println(sdf.format(nowTime.getTime())); } resultList.add(oneList); for (int i = 0; i < 20; i++) { Calendar nowTime = Calendar.getInstance(); nowTime.add(Calendar.MINUTE, i+2); List
ss = Lists.newArrayList(); ss.add(nowTime.getTimeInMillis()); ss.add(new Long((long)getRandom(100,i))); twoList.add(ss); System.out.println(sdf.format(nowTime.getTime())); } resultList.add(twoList); for (int i = 0; i < 20; i++) { Calendar nowTime = Calendar.getInstance(); nowTime.add(Calendar.MINUTE, i+3); List
ss = Lists.newArrayList(); ss.add(nowTime.getTimeInMillis()); ss.add(new Long((long)getRandom(100,i))); shoList.add(ss); System.out.println(sdf.format(nowTime.getTime())); } resultList.add(shoList); return resultList; } public int getRandom(int max,int min){ Random random = new Random(); int s = random.nextInt(max)%(max-min+1) + min; System.out.println(s); return s; }

这个有个问题是数据初始化:

series: [{        name: 'Random data',        data: (function () {            // generate an array of random data            var data = [],                time = (new Date()).getTime(),                i;            for (i = -19; i <= 0; i += 1) {                data.push({                    x: time + i * 1000,                    y: Math.random()                });            }            return data;        }())    }]

如果series为空的话,在load: function ()中如果有数据的话,好像不能正常显示,所以需要在series也要初始化下数据,最终修改成如下:

    
Highcharts Example

 

你可能感兴趣的文章
nginx:Error ./configure: error: the HTTP rewrite module requires the PCRE library
查看>>
Nginx、HAProxy、LVS
查看>>
Nginx下配置codeigniter框架方法
查看>>
Nginx中使用expires指令实现配置浏览器缓存
查看>>
Nginx之二:nginx.conf简单配置(参数详解)
查看>>
Nginx代理websocket配置(解决websocket异常断开连接tcp连接不断问题)
查看>>
Nginx代理初探
查看>>
nginx代理地图服务--离线部署地图服务(地图数据篇.4)
查看>>
Nginx代理外网映射
查看>>
Nginx代理模式下 log-format 获取客户端真实IP
查看>>
Nginx代理解决跨域问题(导致图片只能预览不能下载)
查看>>
Nginx代理访问提示ERR_CONTENT_LENGTH_MISMATCH
查看>>
Nginx代理配置详解
查看>>
Nginx代理静态资源(gis瓦片图片)实现非固定ip的url适配网络环境映射ip下的资源请求解决方案
查看>>
Nginx代理静态资源(gis瓦片图片)实现非固定ip的url适配网络环境映射ip下的资源请求解决方案
查看>>
Nginx使用proxy_cache指令设置反向代理缓存静态资源
查看>>
Nginx入门教程-简介、安装、反向代理、负载均衡、动静分离使用实例
查看>>
nginx反向代理
查看>>
Nginx反向代理
查看>>
nginx反向代理、文件批量改名及统计ip访问量等精髓总结
查看>>