<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<jsp:include page="/include/head_new.jsp"></jsp:include>
<style type="text/css">
.select_ul{
height:30px;
background:#ddd;
}
.select_ul li{
height:22px;
margin:4px 0 0 10px;
float:left;
cursor:pointer;
line-height:22px;
padding:0 4px;
}
.select_ul li.current{
background:#bbb;
border-radius:3px;
font-weight:bold;
}
</style>
<script src="/sts/js/highcharts/highstock.src.js"></script>
<script type="text/javascript">
Date.prototype.Format = function (fmt) { //author: meizz
var o = {
"M+": this.getMonth() + 1, //月份
"d+": this.getDate(), //日
"h+": this.getHours(), //小时
"m+": this.getMinutes(), //分
"s+": this.getSeconds(), //秒
"q+": Math.floor((this.getMonth() + 3) / 3), //季度
"S": this.getMilliseconds() //毫秒
};
if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
for (var k in o)
if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
return fmt;
};
var quoteTypeFlag = 0;
/**
quoteType:K线类型,1-1分钟,2-5分钟,3-15分钟,4-30分钟,5-1小时,6-2小时,7-4小时, * 8-1天,9-1星期,10-1个月,11-1季度,12一年
*/
$(function() {
if(quoteTypeFlag == 0){
// 如果用户没有触发 则默认显示1小时的数据K线
listRealtimeQuote(5);
}
});
function quoteType(type){
// 显示 highstock
listRealtimeQuote(type);
// 如果是用户触发 则赋值给 quoteTypeFlag
quoteTypeFlag = type;
}
</script>
<div class="content ptlr10">
<ul class="select_ul">
<li onclick="quoteType(1)" id="l1">1分</li>
<li onclick="quoteType(2)" id="l2">5分</li>
<li onclick="quoteType(3)" id="l3">15分</li>
<li onclick="quoteType(4)" id="l4">30分</li>
<li onclick="quoteType(5)" id="l5">1时</li>
<li onclick="quoteType(6)" id="l6">2时</li>
<li onclick="quoteType(7)" id="l7">4时</li>
<li onclick="quoteType(8)" id="l8">1日</li>
<li onclick="quoteType(9)" id="l9">1周</li>
<li onclick="quoteType(10)" id="l10">1月</li>
<li onclick="quoteType(11)" id="l11">1季度</li>
<li onclick="quoteType(12)" id="l12">1年</li>
</ul>
</div>
<div id="container" style="height: 500px; min-width: 310px"></div>
function listRealtimeQuote (quoteType) {
var pointCode = 0,proName="";
if(quoteType >5){
pointCode = 4;
}else if(0< pointCode<=7){
pointCode = 4;
}
$.ajax({
url: '/data/realtimeQuoteListMarket.do?quoteType='+quoteType,
type: 'GET',
dataType: 'json',
success:function(json){
// split the data set into ohlc and volume
var ohlc = [],
volume = [],
data = json.object;
if(data == null){
return;
}
proName = data[0].contractCode;
var arr=[];
for (i = 0; i < data.length; i++) {
var dt = data[i].quoteBeginDate;
var time = dt.substring(0,4)+"/"+dt.substring(4,6)+"/"+dt.substring(6,8)+"/"+dt.substring(8,10)+":"+dt.substring(10,12)+":"+dt.substring(12,14);
var dtime = new Date(Date.parse(time)).getTime();
ohlc.push([
dtime,//data[i].quoteBeginDate, // the date (new Date(Date.parse("2014/03/28/09:05:01"))).getTime()
parseFloat(data[i].open), // open
parseFloat(data[i].high), // high
parseFloat(data[i].low), // low
parseFloat(data[i].close) // close
]);
volume.push([
dtime, // the date
parseFloat(data[i].endVol) // the volume
]);
}
var quickSort = function(arr) {
if (arr.length <= 1) { return arr; }
var pivotIndex = Math.floor(arr.length / 2);
var pivot = arr.splice(pivotIndex, 1)[0];
var left = [];
var right = [];
for (var i = 0; i < arr.length; i++){
if (arr[i][0] < pivot[0]) {
left.push(arr[i]);
} else {
right.push(arr[i]);
}
}
return quickSort(left).concat([pivot], quickSort(right));
};
ohlc.sort(function(a,b){return a[0]-b[0]});
volume=quickSort(volume);
// set the allowed units for data grouping
var groupingUnits = [
['minute',[1,5,15, 30]],
['hour',[1, 2,4]],
['day',[1]],
['week',[1]],
['month',[1]],
['year',[1]]
];
// create the chart
$('#container').highcharts('StockChart', {plotOptions: {// 绘制颜色
candlestick: {
color: '#1BA767',
upColor: '#E24439'
}
},
rangeSelector: {
enabled:false
},
inputDateFormat: '%H:%M:%S.%L',
inputEditDateFormat: '%H:%M:%S.%L',
lang:{
months: ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'],
shortMonths: ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一', '十二'],
weekdays: ['星期天', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'],
exportButtonTitle:'导出PDF',
printButtonTitle:'打印报表'
},
credits :{
enabled:false
},
tooltip: {
valueDecimals: 2,
useHTML: true,
formatter: function() {
var ctime = new Date('1970, 1, 1');
ctime.setTime(parseInt(this.x));
var year = ctime.getUTCFullYear();
var month = ctime.getUTCMonth() + 1;
var day = ctime.getUTCDate();
var time = ctime.toLocaleTimeString();
return year + '-' + month + '-' + day + " " + time +"<br/>"+
'<span style="color:{series.color}">\u25CF</span><b> '+proName+'</b><br/>'+
'开盘价: '+this.points[0].point.open+'<br/>' +
'收盘价: '+this.points[0].point.close+'<br/>' +
'最高价: '+this.points[0].point.high+'<br/>' +
'最低价: '+this.points[0].point.low+'<br/>' ;
}
},
title: {
text: '产品指数'
},
yAxis: [{
labels: {
align: 'right',
x: -3
},
title: {
text: '蜡烛图'
},
height: '60%',
lineWidth: 2
}, {
labels: {
align: 'right',
x: -3
},
title: {
text: '条形图'
},
top: '65%',
height: '35%',
offset: 0,
lineWidth: 2
}],
series: [{
type: 'candlestick',
name: proName,
data: ohlc,
dataGrouping: {
units: groupingUnits
}
,pointWidth: pointCode // 蜡烛图的宽度
}]
});
}});///////////////
分享到:
相关推荐
highstock实现K线图绘制,实现功能如下: 1.根据用户选择的时间区间,显示最高价和最低价。 2.点击最高价或最低价的flags会显示出相应的时间。 3.动态改变X轴时间显示格式(%Y %Y-%m %m-%d),防止样式重叠在一起...
Highstock 支持直线图、折线图、面积图、面积曲线图、柱形图、散点图、蜡烛图(OHLC)、K线图、标签图、面积范围图、柱形范围图等多种图表, 其中很多图表可以集成在同一个图形中形成混合图 config-syntax简单的...
Highstock 支持直线图、折线图、面积图、面积曲线图、柱形图、散点图、蜡烛图(OHLC)、K线图、标签图、面积范围图、柱形范围图等多种图表, 其中很多图表可以集成在同一个图形中形成混合图 config-syntax简单的...
对于股票图或K线图,Highcharts提供了Highstock插件,专门用于绘制时间序列数据,如股票价格。K线图由开盘价、收盘价、最高价和最低价四个元素组成,形似蜡烛,因此也被称为蜡烛图。在Highstock中,你可以通过`...
基于的手势识别系统可控制灯的亮_3
untitled2.zip
S7-1500和分布式外围系统ET200MP模块数据
anaconda配置pytorch环境
高校教室管理系统,主要的模块包括查看首页、个人中心、教师管理、学生管理、教室信息管理、教师申请管理、学生申请管理、课时表管理、教师取消预约管理、学生取消预约管理等功能。
半挂汽车列车横向稳定性控制研究:基于模糊PID与制动力矩分配的联合仿真分析在典型工况下的表现,半挂汽车列车在典型工况下的横向稳定性控制研究:基于模糊PID与制动力矩分配的联合仿真分析,半挂汽车列车4自由度6轴整车model,横向稳定性控制,在低附着系数路面,进行典型3个工况,角阶跃,双移线,方向盘转角。 采用算法:模糊PID,制动力矩分配,最优滑移率滑膜控制。 以上基于trucksim和simulink联合仿真,有对应 p-a-p-e-r参考 ,关键词: 1. 半挂汽车列车 2. 4自由度6轴整车model 3. 横向稳定性控制 4. 低附着系数路面 5. 典型工况(角阶跃、双移线、方向盘转角) 6. 模糊PID算法 7. 制动力矩分配 8. 最优滑移率滑膜控制 9. Trucksim和Simulink联合仿真 10. P-A-P-E-R参考; 用分号隔开上述关键词为:半挂汽车列车; 4自由度6轴整车model; 横向稳定性控制; 低附着系数路面; 典型工况; 模糊PID算法; 制动力矩分配; 最优滑移率滑膜控制; Trucksim和Simulink联合仿真; P-A-P-E-R参考
路径规划人工势场法及其改进算法Matlab代码实现,路径规划人工势场法及其改进算法Matlab代码实现,路径规划人工势场法以及改进人工势场法matlab代码,包含了 ,路径规划; 人工势场法; 改进人工势场法; MATLAB代码; 分隔词“;”。,基于Matlab的改进人工势场法路径规划算法研究
本文介绍了范德堡大学深脑刺激器(DBS)项目,该项目旨在开发和临床评估一个系统,以辅助从规划到编程的整个过程。DBS是一种高频刺激治疗,用于治疗运动障碍,如帕金森病。由于目标区域在现有成像技术中可见性差,因此DBS电极的植入和编程过程复杂且耗时。项目涉及使用计算机辅助手术技术,以及一个定制的微定位平台(StarFix),该平台允许在术前进行图像采集和目标规划,提高了手术的精确性和效率。此外,文章还讨论了系统架构和各个模块的功能,以及如何通过中央数据库和网络接口实现信息共享。
三菱FX3U步进电机FB块的应用:模块化程序实现电机换算,提高稳定性和移植性,三菱FX3U步进电机换算FB块:模块化编程实现电机控制的高效性与稳定性提升,三菱FX3U 步进电机算FB块 FB块的使用可以使程序模块化简单化,进而提高了程序的稳定性和可移植性。 此例中使用FB块,可以实现步进电机的算,已知距离求得脉冲数,已知速度可以求得频率。 程序中包含有FB和ST内容;移植方便,在其他程序中可以直接添加已写好的FB块。 ,三菱FX3U;步进电机换算;FB块;程序模块化;稳定性;可移植性;距离与脉冲数换算;速度与频率换算;FB和ST内容;移植方便。,三菱FX3U步进电机换算FB块:程序模块化与高稳定性实现
光伏逆变器TMS320F28335设计方案:Boost升压与单相全桥逆变,PWM与SPWM控制,MPPT恒压跟踪法实现,基于TMS320F28335DSP的光伏逆变器设计方案:Boost升压与单相全桥逆变电路实现及MPPT技术解析,光伏逆变器设计方案TMS320F28335-176资料 PCB 原理图 源代码 1. 本设计DC-DC采用Boost升压,DCAC采用单相全桥逆变电路结构。 2. 以TI公司的浮点数字信号控制器TMS320F28335DSP为控制电路核心,采用规则采样法和DSP片内ePWM模块功能实现PWM和SPWM波。 3. PV最大功率点跟踪(MPPT)采用了恒压跟踪法(CVT法)来实现,并用软件锁相环进行系统的同频、同相控制,控制灵活简单。 4.资料包含: 原理图,PCB(Protel或者AD打开),源程序代码(CCS打开),BOM清单,参考资料 ,核心关键词:TMS320F28335-176; 光伏逆变器; 升压; 逆变电路; 数字信号控制器; 规则采样法; ePWM模块; PWM; SPWM波; MPPT; 恒压跟踪法; 原理图; PCB; 源程序代码; BOM
centos9内核安装包
昆仑通态触摸屏与两台台达VFD-M变频器通讯实现:频率设定、启停控制与状态指示功能接线及设置说明,昆仑通态TPC7062KD触摸屏与两台台达VFD-M变频器通讯程序:实现频率设定、启停控制与状态指示,昆仑通态MCGS与2台台达VFD-M变频器通讯程序实现昆仑通态触摸屏与2台台达VFD-M变频器通讯,程序稳定可靠 器件:昆仑通态TPC7062KD触摸屏,2台台达VFD-M变频器,附送接线说明和设置说明 功能:实现频率设定,启停控制,实际频率读取等,状态指示 ,昆仑通态MCGS; 台达VFD-M变频器; 通讯程序; 稳定可靠; 频率设定; 启停控制; 实际频率读取; 状态指示; 接线说明; 设置说明,昆仑通态MCGS与台达VFD-M变频器通讯程序:稳定可靠,双机控制全实现
研控步进电机驱动器方案验证通过,核心技术成熟可生产,咨询优惠价格!硬件原理图与PCB源代码全包括。,研控步进电机驱动器方案验证通过,核心技术掌握,生产准备,咨询实际价格,包含硬件原理图及PCB源代码。,研控步进电机驱动器方案 验证可用,可以生产,欢迎咨询实际价格,快速掌握核心技术。 包括硬件原理图 PCB源代码 ,研控步进电机驱动器方案; 验证可用; 可生产; 核心技术; 硬件原理图; PCB源代码,研控步进电机驱动器方案验证通过,现可生产供应,快速掌握核心技术,附硬件原理图及PCB源代码。
高质量的OPCClient_UA源码分享:基于C#的OPC客户端开发源码集(测试稳定、多行业应用实例、VS编辑器支持),高质量OPC客户端源码解析:OPCClient_UA C#开发,适用于VS2019及多行业现场应用源码分享,OPCClient_UA源码OPC客户端源码(c#开发) 另外有opcserver,opcclient的da,ua版本的见其他链接。 本项目为VS2019开发,可用VS其他版本的编辑器打开项目。 已应用到多个行业的几百个应用现场,长时间运行稳定,可靠。 本项目中提供测试OPCClient的软件开发源码,有详细的注释,二次开发清晰明了。 ,OPCClient_UA; OPC客户端源码; C#开发; VS2019项目; 稳定可靠; 详细注释; 二次开发,OPC客户端源码:稳定可靠的C#开发实现,含详细注释支持二次开发
毕业设计