折线图与曲线图可以显示随时间而变化的连续数据,因此非常适用于显示在相等时间间隔下数据的趋势。本文将结合Highcharts,生成一个城市气温变化折线图和一个随时间动态即时显示CPU走势的曲线图。

如果您看了本站前面两篇关于Highcharts的文章,应该对Highcharts有所了解,所以本文侧重JS配置来完成图表的设计。如果您还不知道什么是Highcharts,请先阅读本站前面的文章。

1、城市气温变化折线图

通过以下配置,可以生成一个带网格的、显示数据点具体数据的、可放大的、去除LOGO标签的折线图。具体请看代码和注释

var chart;  $(function() {      chart = new Highcharts.Chart({          chart: {              renderTo: 'chart_line', //图表放置的容器,DIV              defaultSeriesType: 'line', //图表类型line(折线图),              zoomType: 'x'   //x轴方向可以缩放          },          credits: {              enabled: false   //右下角不显示LOGO          },          title: {              text: '主要城市月平均气温' //图表标题          },          subtitle: {              text: '2011年'  //副标题          },          xAxis: {  //x轴              categories: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月',   '11月', '12月'], //x轴标签名称              gridLineWidth: 1, //设置网格宽度为1              lineWidth: 2,  //基线宽度              labels:{y:26}  //x轴标签位置:距X轴下方26像素          },          yAxis: {  //y轴              title: {text: '平均气温(°C)'}, //标题              lineWidth: 2 //基线宽度          },          plotOptions:{ //设置数据点              line:{                  dataLabels:{                      enabled:true  //在数据点上显示对应的数据值                  },                  enableMouseTracking: false //取消鼠标滑向触发提示框              }          },          legend: {  //图例              layout: 'horizontal',  //图例显示的样式:水平(horizontal)/垂直(vertical)              backgroundColor: '#ffc', //图例背景色              align: 'left',  //图例水平对齐方式              verticalAlign: 'top',  //图例垂直对齐方式              x: 100,  //相对X位移              y: 70,   //相对Y位移              floating: true, //设置可浮动              shadow: true  //设置阴影          },          exporting: {              enabled: false  //设置导出按钮不可用          },          series: [{  //数据列              name: '北京',              data: [ - 4.6, -2.2, 4.5, 13.1, 19.8, 24.0, 25.8, 24.4, 19.3, 12.4, 4.1, -2.7]          },          {              name: '广州',              data: [13.3, 14.4, 17.7, 21.9, 24.6, 27.2, 30.8, 32.1, 27.2, 23.7, 21.3, 15.6]          }]      });  });  

2、CPU使用记录走势图

通过相关配置,可以生成一个随着时间变化(每隔5秒更新一次)的曲线图。

var chart;  $(function() {      chart = new Highcharts.Chart({          chart: {              renderTo: 'chart_spline', //图表放置的容器,DIV              defaultSeriesType: 'spline', //图表类型为曲线图              events: {                  load: function() {                       var series = this.series[0];                      //每隔5秒钟,图表更新一次,y数据值在0-100之间的随机数                      setInterval(function() {                          var x = (new Date()).getTime(), // 当前时间                          y = Math.random()*100;                           series.addPoint([x, y], true, true);                      },                      5000);                  }              }          },          title: {              text: 'CPU使用记录走势图'  //图表标题          },          xAxis: { //设置X轴              type: 'datetime',  //X轴为日期时间类型              tickPixelInterval: 150  //X轴标签间隔          },          yAxis: { //设置Y轴              title: '',              max: 100, //Y轴最大值              min: 0  //Y轴最小值          },          tooltip: {//当鼠标悬置数据点时的提示框              formatter: function() { //格式化提示信息                  return 'CPU使用率'+                  Highcharts.dateFormat('%H:%M:%S', this.x) +''+                   Highcharts.numberFormat(this.y, 2)+'%';              }          },          legend: {              enabled: false  //设置图例不可见          },          exporting: {              enabled: false  //设置导出按钮不可用          },          credits: {              text: 'Helloweba.com', //设置LOGO区文字              url: 'http://www.helloweba.com' //设置LOGO链接地址          },          series: [{              data: (function() { //设置默认数据,                  var data = [],                  time = (new Date()).getTime(),                  i;                    for (i = -19; i <= 0; i++) {                      data.push({                          x: time + i * 5000,                           y: Math.random()*100                      });                  }                  return data;              })()          }]      });  });  

注意,当X轴类型为datetime日期时间型的,需要设置时区,在开头加上以下代码即可:

Highcharts.setOptions({      global: {          useUTC: false      }  });  

//本文转载

使用Highcharts生成折线图与曲线图的更多相关文章

  1. 使用Highcharts生成折线图_at last

    //数据库数据的读取,读取数据后数据格式的转换,还有highchart数据源的配置,伤透了脑筋. anyway,最终开张了.哈哈! 数据库连接:conn_orcale.php <?php $db ...

  2. chart.js插件生成折线图时数据普遍较大时Y轴数据不从0开始的解决办法[bubuko.com]

    chart.js插件生成折线图时数据普遍较大时Y轴数据不从0开始的解决办法,原文:http://bubuko.com/infodetail-328671.html 默认情况下如下图 Y轴并不是从0开始 ...

  3. HighCharts基本折线图

    1.设计源码 <!DOCTYPE html> <!-- To change this license header, choose License Headers in Projec ...

  4. 利用JFreeChart生成折线图 (4) (转自 JSP开发技术大全)

    利用JFreeChart生成折线图 (4) (转自 JSP开发技术大全) 14.4 利用JFreeChart生成折线图 通过JFreeChart插件,既可以生成普通效果的折线图,也可以生成3D效果的折 ...

  5. highcharts实例教程一:结合php与mysql生成折线图

    Highcharts是一款纯javascript和html5编写的图表库,不仅几乎能兼容所有pc浏览器,而且对ios和android手机端的兼容 性也不错,它能够很简单便捷的在Web网站或Web应用中 ...

  6. .NET 使用 Highcharts生成扇形图 柱形图

    1.首先新建一个.NET网站,如图所示: 2.引用所需要的js类库,如下图 highcharts.js可以在网上搜索就可以找到下载了. 3.在Default.aspx页面引用js 4.在 body 下 ...

  7. 【EXCEL-折线图】百折不挠 | 用EXCEL画出与众不同的折线图(曲线图)

    很多熟悉EXLCE的朋友都知道EXCEL在生成统计图表方面的强大功能,我们在写各类总结.报告.方案等文档时常涉及到各类统计数字,将统计数字用图表的形式展示出来,既直观又美观.下面我分享一种不一样的折线 ...

  8. Highcharts之折线图

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  9. Android自定义控件:图形报表的实现(折线图、曲线图、动态曲线图)(View与SurfaceView分别实现图表控件)

    图形报表很常用,因为展示数据比较直观,常见的形式有很多,如:折线图.柱形图.饼图.雷达图.股票图.还有一些3D效果的图表等. Android中也有不少第三方图表库,但是很难兼容各种各样的需求. 如果第 ...

随机推荐

  1. Xamarin生成的APK大小分析

    原文:Xamarin生成的APK大小分析 刚接触Xamarin都会被Xamarin的售价吓一跳,另外就是它生成的APK大小,官方也有相关的说明,这里加上自己的理解同意讲解下: 以下是针对Android ...

  2. gdb运行时结合汇编堆栈分析

    一.从源代码文件到可执行文件         从C文件到可执行文件,一般来说需要两步,先将每个C文件编译成.o文件,再把多个.o文件和链接库一起链接成可执行文件.但具体来说,其实是分为四步,下面以ex ...

  3. ReactNative遇到的一些坑

    1. 如果通过一个url进行下载上传操作,这个url中包含有中文的话,一定要记得将这个url转为URLEncode编码. 如: encodeURI('http://test/有中文.doc'); 2. ...

  4. poj2186 Popular Cows --- 强连通

    给一个有向图,问有多少结点是其它全部结点都能够到达的. 等价于,在一个有向无环图上,找出度为0 的结点.假设出度为0的结点仅仅有一个,那么这个就是答案.假设大于1个.则答案是0. 这题有环.所以先缩点 ...

  5. 利用虚拟光驱实现 将WINDOWS文件供虚拟机中的UBUNTU共享

    此方法只能实现(至少目前我发现只能这样)将文件传递给虚拟机中的ubuntu 中,供ubuntu系统阅读,拷贝等,但不能将ubuntu中的数据传递给windows. 即:每次更新windows的数据到u ...

  6. FlashFXP使用教程

    点FlashFXP菜单栏“站点-站点管理”打开站点管理器.然后点新建站点,输入站点名称(随意),确定.   编辑站点管理器里新建的站点的相关信息,包括站点名称.地址.用户名称.密码等.编辑完成,点应用 ...

  7. Sql Sever 字符串截取汉字

    最近需要在SQL的字符串中截取汉字,利用unicode函数判断字符的unicode编码,根据编码范围过滤掉非汉字字符. 写成了一个function /*@str 需要获取汉字的字符串*/ create ...

  8. C#控件大小随窗体大小等比例变化

    相信很多博友在开发初次接触学习C# winForm时,当窗体大小变化时,窗体内的控件并没有随着窗体的变化而变化,最近因为一个项目工程的原因,也需要解决这个问题.通过查阅和学习,这个问题得到了解决,或许 ...

  9. oracle中 some、any、all 三者的区别及个人总结,归纳!

    any :如果是大于号时( a > b ),那么a中所有大于b中最小的那个数的值,就会被输出出来. 如果是小于号时( a < b ),那么a中所有小于b中最大的那个数的值,就会被输出出来. ...

  10. C++小知识之Map用法

    Map是c++的一个标准容器,她提供了很好一对一的关系,在一些程序中建立一个map可以起到事半功倍的效果,总结了一些map基本简单实用的操作! 1. map最基本的构造函数:    map<st ...