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

 

你可能感兴趣的文章
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>