//廖雪峰的博客的这个教程的答案
//https://www.liaoxuefeng.com/wiki/001434446689867b27157e896e74d51a89c25cc8b43bdb3000/00143449990549914b596ac1da54a228a6fa9643e88bc0c000#0 var
canvas = document.getElementById('stock-canvas'),
width = canvas.width,
height = canvas.height,
ctx = canvas.getContext('2d');
console.log(JSON.stringify(data[0])); // {"date":"20150602","open":4844.7,"close":4910.53,"high":4911.57,"low":4797.55,"vol":62374809900,"change":1.69}
ctx.clearRect(0, 0, width, height); //已知函数传进来的data是一个数组,数组的每个元素是一个对象,格式如下
//{"date":"20150602","open":4844.7,"close":4910.53,"high":4911.57,"low":4797.55,"vol":62374809900,"change":1.69}
//其中我们能用到的是 open , close, high, low
//解释一下四个参数的含义,我们知道K线图的形状 类似于汉字 中 其中
//high表示的是中字中间一竖的最上边一点的Y坐标,
//low 是中字中间一竖的最下边一点的Y坐标,
//如果open大于close,则表示股票交易结束的时候比开始的时候低了,则要用绿色表示
//open是中字中间的口的上边一横的Y坐标,
//close是下边一横的Y坐标 //data = data.slice(data.length-2)
console.log("width="+width+" heigth="+height ); //计算最上和最下的留白
liubai = 0.01 * height;
arangeY = {
startY : liubai,
endY : height-liubai
}; calcBulk = function(inputdata, xrange, arangeY){
var widthPerBulk = xrange/inputdata.length;
//绘制节点信息列表
var paintBulkList = [];
//绘制的一个节点
var paintBulk = {color:null, lineStart:{x:0, y:0},lineEnd:{x:0, y:0}, boxStart:{x:0, y:0},boxEnd:{x:0, y:0}};
//求最高点
var highest = inputdata.reduce(function(x,y){
x => {if(x.high) x.high; else x;}
if(x>y.high)
{
return x;
}
else
{
return y.high;
}
});
//求最低点
var lowest = inputdata.reduce(function(x,y){
x => {if(x.low) x.low; else x;}
if(x<y.low)
{
return x;
}
else
{
return y.low;
}
}); //每个点数对应多少像素
var hightRate = (arangeY.endY - arangeY.startY)/(highest-lowest);
console.log("high="+highest+" low="+lowest+" rate="+hightRate);
for(let i=0;i<inputdata.length;i++)
{
//计算颜色
var boxColor = "";
var boxStartVal = NaN;
var boxHeightVal = NaN;
if(inputdata[i].open > inputdata[i].close)
{//green
boxColor = "#dc0000";
boxStartVal = inputdata[i].close;
}
else
{//red
boxColor = "#1caa3d";
boxStartVal = inputdata[i].open;
}
boxHeightVal = Math.abs(inputdata[i].open-inputdata[i].close); paintBulkList.push({color:boxColor,
lineStart:{x:Math.round((i*widthPerBulk)+(widthPerBulk/2)), y:Math.round(arangeY.startY+(inputdata[i].low-lowest)*hightRate)},
lineEnd:{x:Math.round((i*widthPerBulk)+(widthPerBulk/2)), y:Math.round(arangeY.startY+(inputdata[i].high-lowest)*hightRate)},
boxStart:{x:Math.round((i*widthPerBulk)+1), y:Math.round(arangeY.startY+(boxStartVal-lowest)*hightRate)},
boxRange:{width:Math.round(widthPerBulk-2), height:Math.round(arangeY.startY+boxHeightVal*hightRate)}});
} return paintBulkList;
} paintList = calcBulk(data, width, arangeY);
console.log("paintList="+JSON.stringify(paintList));
//画图
ctx.clearRect(0, 0, width, height ); //
ctx.fillStyle = '#000000'; //
ctx.fillRect(0, 0, width, height ); //
for(let i=0;i<data.length;i++)
{ ////////////////////box
ctx.fillStyle = paintList[i].color; // 设置颜色
ctx.fillRect(paintList[i].boxStart.x, paintList[i].boxStart.y, paintList[i].boxRange.width, paintList[i].boxRange.height ); //
///////////////////line
// 设置线条的颜色
ctx.strokeStyle = 'white';
// 设置线条的宽度
ctx.lineWidth = 1; // 绘制直线
ctx.beginPath();
// 起点
ctx.moveTo(paintList[i].lineStart.x, paintList[i].lineStart.y);
// 终点
ctx.lineTo(paintList[i].lineEnd.x, paintList[i].lineEnd.y);
ctx.closePath();
ctx.stroke();
}

  

javascript 练习题目答案的更多相关文章

  1. javascript 练习题目答案2

    https://www.liaoxuefeng.com/wiki/001434446689867b27157e896e74d51a89c25cc8b43bdb3000/0014503724525055 ...

  2. javascript 练习题目答案1

    以下是这个教程的答案 https://www.liaoxuefeng.com/wiki/001434446689867b27157e896e74d51a89c25cc8b43bdb3000/00143 ...

  3. 自家人不认识自家人——考你一道有趣的Javascript小题目

    今天的内容很简单,给大家分享一个有趣的Javascript小题目. 题目很简单,就是填空: var a = ______; var b = a; alert(a==b); // alert " ...

  4. 30个你 “ 不可能全部会做 ” 的javascript题目-答案解释

    题目链接:http://www.cnblogs.com/0603ljx/p/4458127.html 1,D map对数组的每个元素调用定义的回调函数并返回包含结果的数组.["1" ...

  5. JavaScript变态题目

    刚才发现的一些变态的 JavaScript 题目,做了一下,只对了一半,特此发到园子里,和友友们分享一下.这些题目都是针对 Ecmascript 第三版的,原题里面全部都是选择题,有备选答案,这里我把 ...

  6. 偏前端 - div+mui+vue.js 制作问卷调查单页 ——题目答案由后台随机给出10道

    封装的ajax获取数据.代码可能有些是多余的,没做处理!!点击提交后有弹框,在这里我没有贴出来.第一次写博客,这些也是别人教我的,经理解后,贴出来于大家分享 ——html—— <script t ...

  7. 2013 蓝桥杯校内选拔赛 java本科B组(题目+答案)

    一.标题:正则表示     正则表达式表示了串的某种规则或规律.恰当地使用正则表达式,可以使得代码简洁.事半功倍.java的很多API都支持正则表达式作为参数.其中的String.split就是这样. ...

  8. NOIP 2018 提高组初赛试题 题目+答案+简要解析

    一.单项选择题(共 10  题,每题 2  分,共计 20  分: 每题有且仅有一个正确选项)       1. 下列四个不同进制的数中,与其它三项数值上不相等的是( ). A. (269) 16 B ...

  9. JAVASCRIPT试题及答案

    1.用jQuery编程实现获取选中复选框值的函数abc. <body> <input type="checkbox" name="aa" va ...

随机推荐

  1. JS,JQ及时监听input值的变化,MUI的input搜索框里的清除按钮的点击监听事件

    JS: document.getElementById("input对象的ID").addEventListener('input',function(){ console.log ...

  2. linux系统关闭IPv6的方式

    云服务器 ECS> Linux操作运维问题 > 应用配置 > linux系统关闭IPv6的方式 linux系统关闭IPv6的方式 IPv6被认为是IPv4的替代产品,它用来解决现有I ...

  3. AtomicInteger和count++的比较

    J2SE 5.0提供了一组atomic class来帮助我们简化同步处理.基本工作原理是使用了同步synchronized的方法实现了对一个long, integer, 对象的增.减.赋值(更新)操作 ...

  4. go struct结构体

    struct结构体 用来自定义复杂数据结构 struct里面可以包含多个字段(属性),字段可以是任意类型 struct类型可以定义方法,注意和函数的区分 struct类型是值类型 struct类型可以 ...

  5. Hive记录-Sqoop常用命令

    1.sqoop是什么 Sqoop是一款开源的数据迁移工具,主要用于Hadoop(Hive)与传统的关系型数据库(mysql...)相互之间的数据迁移. 2.sqoop的特点 sqoop的底层实现是ma ...

  6. asp.net 使用一般处理程序和ajax post实现登录以及记住密码

    1.登录页面login.aspx <%@ Page Language="C#" AutoEventWireup="true" CodeBehind=&qu ...

  7. MySQL指令

    在mysql里:文件夹就是数据库      文件就是表 创建用户: 格式:create user '用户名'@'IP地址' identified by '密码'; 说明:IP地址是用来限制用户只能在哪 ...

  8. Dom4j用Xpath获取节点——(六)

    xml文档 <?xml version="1.0" encoding="utf-8"?> <书架> <书> <书名 n ...

  9. 复制vmware主机修改网卡

    https://blog.csdn.net/gui951753/article/details/79491092

  10. 【逆向工具】IDA使用4-控制台逆向分析 Reverse004.exe 获取密码

    工具 吾爱破解版本OD.IDA6.8 OD使用-动态分析 OD快捷方式 F2 下断点,也就是指定断点的地址F3加载一个可执行程序,进行调试分析F4程序执行到光标处 F5 缩小.还原当前窗口 F7 单步 ...