博客
关于我
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

 

你可能感兴趣的文章
Member var and Static var.
查看>>
memcached高速缓存学习笔记001---memcached介绍和安装以及基本使用
查看>>
memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
查看>>
Memcached:Node.js 高性能缓存解决方案
查看>>
memcache、redis原理对比
查看>>
memset初始化高维数组为-1/0
查看>>
Metasploit CGI网关接口渗透测试实战
查看>>
Metasploit Web服务器渗透测试实战
查看>>
MFC模态对话框和非模态对话框
查看>>
Moment.js常见用法总结
查看>>
MongoDB出现Error parsing command line: unrecognised option ‘--fork‘ 的解决方法
查看>>
mxGraph改变图形大小重置overlay位置
查看>>
MongoDB可视化客户端管理工具之NoSQLbooster4mongo
查看>>
Mongodb学习总结(1)——常用NoSql数据库比较
查看>>
MongoDB学习笔记(8)--索引及优化索引
查看>>
mongodb定时备份数据库
查看>>
mppt算法详解-ChatGPT4o作答
查看>>
mpvue的使用(一)必要的开发环境
查看>>
MQ 重复消费如何解决?
查看>>
mqtt broker服务端
查看>>