abi*_*964 91 javascript highcharts highstock angularjs
我有一个要求,绘制运行历史一个的任务在Highcharts.它需要将任务的运行历史显示为水平条.我在下面的更新中添加了其他要求.最近我发现StockChartinverted不支持该选项,并且StockChart中只有navigator和rangeSelector可用.因此我正在使用这些功能.
因此,为了达到要求,我创建了类似于这个jsfiddle示例的东西(在浏览时发现某处不记得来源),并在我之前的问题的帮助下结束了这个plunker链接,感谢Pawel Fus
更新问题以避免混淆
其他要求:
显示只有那些任务,其运行在一个特定的日期和时间范围.如果运行次数太多,例如运行次数超过10次,则需要有一种方法,只能使用可滚动显示其他任务的y轴显示10个任务. plunker链接到问题
上述拔毛器的问题解释.
如果你从上面的plunker检查下面的截图,时间范围是从12/12/2014 09:32:26,12/12/2014 10:32:26并且只有2个任务已经运行m_ARRAYV_SALES_ZIG1_CALL2_VOD__C_OB&m_ZIG2_HCP_MERGE_IB_CN.但是我可以看到之间的另一个任务,LILLY_C甚至没有在这个日期时间范围内运行.(在实际数据中,有超过10个任务使这个图表混乱,甚至不属于这个日期时间范围)
此外,如果你注意到最右边的角落时间从转移09:38到19:20.19:20是m_ZIG2_HCP_MERGE_IB_CN任务的结束时间.
以下是我的图表选项
var chart_options = {
chart: {
renderTo: 'container',
height: 600
},
title: {
},
credits: {
enabled: false
},
xAxis: {
type: 'datetime',
gridLineWidth: 1,
tickInterval: 1 * 3600 * 1000,
dateTimeLabelFormats: {
month: '%b %e, %Y'
}
},
yAxis: {
tickInterval: 1,
gridLineWidth: 1,
labels: {
formatter: function() {
if (tasks[this.value]) {
return tasks[this.value].name;
}
}
},
startOnTick: false,
endOnTick: false,
title: {
text: 'Task'
}
},
rangeSelector: {
selected: 0,
buttons: [ {
type: "minute",
count: 60,
text: "1h"
}, {
type: "minute",
count: 180,
text: "3h"
}, {
type: "minute",
count: 300,
text: "5h"
}],
inputDateFormat: '%m/%d/%Y %H:%M:%S',
inputEditDateFormat: '%m/%d/%Y %H:%M:%S',
inputBoxWidth: 120
},
navigator: {
enabled: false
},
legend: {
enabled: false
},
tooltip: {
shared: false,
formatter: function() {
var str = '';
str += 'Task: ' + this.series.name + '<br>';
str += 'From: ' + Highcharts.dateFormat('%m/%d/%y %H:%M', this.point.from) + '<br>';
str += 'To: ' + Highcharts.dateFormat('%m/%d/%y %H:%M', this.point.to) + '<br>';
return str;
}
},
plotOptions: {
line: {
lineWidth: 10,
marker: {
enabled: true
},
dataLabels: {
enabled: true,
align: 'left',
formatter: function() {
return this.point.options && this.point.options.label;
}
},
states:{
hover:{
lineWidth:10
}
}
},
series: {
cursor: 'pointer',
point: {
events: {
click: function () {
var query = '{ "task_id": "'+this.task_id+'","start_time": '+this.from+',"exclude_interval": '+opExcludeMinutes+',"size": 10 }';
$scope.taskName = this.series.name;
$scope.isTaskSelected = false;
$scope.operationalReportAgentTaskHistoryServiceRequest(query);
}
}
}
}
},
series: seriesData
};
Run Code Online (Sandbox Code Playgroud)
所以经过几个小时的挖掘,我刚刚找到了罪魁祸首(或者我真的希望如此).问题是您对yAxis标签格式化程序的定义:
yAxis: {
tickInterval: 1,
gridLineWidth: 1,
labels: {
formatter: function() { // THIS IS THE PROBLEM
if (tasks[this.value]) {
return tasks[this.value].name;
}
}
},
startOnTick: false,
endOnTick: false,
title: {
text: 'Task'
}
},
Run Code Online (Sandbox Code Playgroud)
您实际上没有检查是否应该根据task.intervals(参见json.js)显示标签.格式化程序的简单更新(Plunker)似乎有效:
yAxis: {
tickInterval: 1,
gridLineWidth: 1,
labels: {
formatter: function () {
console.log("scripts.js - yAxis.labels.formatter", this.value);
if (tasks[this.value]) {
//if (tasks[this.value].name === 'LILLY_C') {
var _xAxis = this.chart.axes[0];
var _task = tasks[this.value];
var _show = false;
// Not optimized for large collections
for (var _i = 0; _i < _task.intervals.length; _i++) {
var _int = _task.intervals[_i];
if (_xAxis.min <= _int.to) {
_show = true;
}
}
console.log("scripts.js - yAxis.labels.formatter",
tasks[this.value].name,
_show,
_xAxis.min,
_xAxis.max,
_task.intervals
);
if (_show) {
return tasks[this.value].name;
} else {
return;
}
//}
//return tasks[this.value].name;
}
}
},
startOnTick: false,
endOnTick: false,
title: {
text: 'Task'
}
},
Run Code Online (Sandbox Code Playgroud)
请参阅Plunker进行演示.
yAxis标签的含义是: 如果您在图表中看到运行或者图表右侧有运行,则显示标签.请修改条件
if (_xAxis.min <= _int.to) {
Run Code Online (Sandbox Code Playgroud)
如你所愿.
免责声明:我不使用Highcharts,所以这个答案试图解释问题,而不是建议Highcharts解决问题的方法.
得到教训:
yaxis-plugin.js 与问题无关.console.log()以了解发生了什么.| 归档时间: |
|
| 查看次数: |
3908 次 |
| 最近记录: |