JS+html5 canvas实现的简单绘制折线图效果示例
2017-03-13 10:23
1391 查看
本文实例讲述了JS+html5 canvas实现的简单绘制折线图效果。分享给大家供大家参考,具体如下:
1、实例代码:
<!DOCTYPE html> <html> <head> <meta charset='utf-8'> <title>画图</title> <style> #divContainer{ margin-top: 20px; text-align: center; } #cv{ width: 300px; height: 200px; border-bottom: 2px solid #000; border-left: 2px solid #000; } </style> </head> <body> <div id="divContainer"> 铝锭价走势图<br/> <canvas id="cv">你的设备不支持图表数据显示</canvas> </div> <script> (function(){ window.onload = function(){ //数据源 var dict = [ {x: "2015-04-24", y: 13400}, {x: "2015-04-25", y: 13380}, {x: "2015-04-26", y: 13370}, {x: "2015-04-27", y: 13370}, {x: "2015-04-28", y: 13380} ] //数据源提取 var len = dict.length; var xArr = [], yArr = [], tmp_yArr = []; for(var i=0; i<len; i++){ xArr.push(i * 60); tmp_yArr.push(dict[i].y); } var tmp_minY = Math.min.apply(Math, tmp_yArr);//最小值 var tmp_maxY = Math.max.apply(Math, tmp_yArr);//最大值 if(tmp_maxY - tmp_minY <= 100){ for(var i=0; i<len; i++){ yArr.push(tmp_yArr[i] - tmp_minY + 50);//与最小的做比较 } } else{//如果相差太大会导致图表不美观 for(var i=0; i<len; i++){ yArr.push(tmp_yArr[i] / 500); } } var minY = Math.min.apply(Math, yArr); var maxY = Math.max.apply(Math, yArr); //canvas 准备 var canvas = document.getElementById("cv");//获取canvas画布 var ctx = canvas.getContext("2d"); //画折线 for(var i=0 ;i<len; i++){ var x = xArr[i]; var y = maxY - yArr[i] + minY; if(i === 0){ ctx .moveTo(x, y); } else{ ctx .lineTo(x, y); } } ctx .stroke(); //画点 for(var i=0; i<len; i++){ var x = xArr[i]; var y = maxY - yArr[i] + minY; var xMemo = dict[i].x; var yMemo = "¥" + dict[i].y; ctx.beginPath(); ctx.fillStyle = "#000"; ctx.arc(x, y, 2, 0, 2*Math.PI);//画点 ctx.fill(); ctx.fillText(yMemo, x + 3, y - 10); ctx.fillText(xMemo, x + 3, canvas.height - 10, 40);//画文字 } } })(); </script> </body> </html>
2、运行效果图如下:
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript图形绘制技巧总结》、《JavaScript图片操作技巧大全》、《JavaScript运动效果与技巧汇总》、《JavaScript切换特效与技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
您可能感兴趣的文章:
- JS+HTML5 Canvas实现简单的写字板功能示例
- Javascript HTML5 Canvas实现的一个画板
- html5+javascript制作简易画板附图
- javascript结合html5 canvas实现(可调画笔颜色/粗细/橡皮)的涂鸦板
- js+html5实现canvas绘制圆形图案的方法
- js+html5实现canvas绘制镂空字体文本的方法
- js+html5绘制图片到canvas的方法
- js HTML5 Canvas绘制转盘抽奖
- javascript+HTML5 Canvas绘制转盘抽奖
- JavaScript+html5 canvas绘制的小人效果
- 原生JS+HTML5实现的可调节写字板功能示例
相关文章推荐
- JS+HTML5 Canvas实现简单的写字板功能示例
- js+html5实现canvas绘制简单矩形的方法
- JS基于ocanvas插件实现的简单画板效果代码(附demo源码下载)
- html5实现canvas阴影效果示例
- jQuery插件HighCharts绘制简单2D折线图效果示例【附demo源码】
- JS实现的简单轮播图运动效果示例
- js+html5实现canvas绘制圆形图案的方法
- js实现canvas绘制的图形的拖动效果
- rainday.js实现canvas绘制下雨的效果
- JS实现简单的浮动碰撞效果示例
- js+html5实现canvas绘制镂空字体文本的方法
- JS基于HTML5的canvas标签实现炫目的色相球动画效果实例
- js+html5实现canvas绘制镂空字体文本的方法
- js+html5实现canvas绘制椭圆形图案的方法
- js+html5实现canvas绘制网页时钟的方法
- chart.js + bootstrap +jquery.js 实现的 html5 图表绘制效果
- JS实现的简单折叠展开动画效果示例
- canvas-nest.js基于html5 canvas绘制的网页背景效果
- js canvas实现擦除效果示例代码