博客
关于我
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 默认事务隔离级别下锁分析
查看>>
Mysql--逻辑架构
查看>>
MySql-2019-4-21-复习
查看>>
mysql-5.6.17-win32免安装版配置
查看>>
mysql-5.7.18安装
查看>>
MySQL-Buffer的应用
查看>>
mysql-cluster 安装篇(1)---简介
查看>>
mysql-connector-java.jar乱码,最新版mysql-connector-java-8.0.15.jar,如何愉快的进行JDBC操作...
查看>>
mysql-connector-java各种版本下载地址
查看>>
mysql-EXPLAIN
查看>>
MySQL-Explain的详解
查看>>
mysql-group_concat
查看>>
MySQL-redo日志
查看>>
MySQL-【1】配置
查看>>
MySQL-【4】基本操作
查看>>
Mysql-丢失更新
查看>>
Mysql-事务阻塞
查看>>
Mysql-存储引擎
查看>>
mysql-开启慢查询&所有操作记录日志
查看>>