1. 使用加flag
$(function() {
$.getJSON('http://www.highcharts.com/samples/data/jsonp.php?filename=aapl-ohlcv.json&callback=?', function(data) {
// split the data set into ohlc and volume
var ohlc = [],
volume = [],
flagData = [],
dataLength = data.length;
console.log(data);
for (i = 0; i < dataLength; i++) {
ohlc.push([
data[i][0], // the date
data[i][1], // open
data[i][2], // high
data[i][3], // low
data[i][4] // close
]);
volume.push([
data[i][0], // the date
data[i][5] // the volume
])
if(i % 20 == 0) {
flagData.push({
x : data[i][0],
y : data[i][2],
title : 'A',
text : 'Shape: "squarepin"'
});
}
if(i % 27 == 0) {
flagData.push({
x : data[i][0],
y : data[i][2],
title : 'B',
text : 'Shape: "squarepin"'
});
}
}
// set the allowed units for data grouping
var groupingUnits = [[
'week', // unit name
[1] // allowed multiples
], [
'month',
[1, 2, 3, 4, 6]
]];
// create the chart
$('#container').highcharts('StockChart', {
rangeSelector: {
inputEnabled: $('#container').width() > 480,
selected: 1
},
title: {
text: 'AAPL Historical'
},
yAxis: [{
title: {
text: 'OHLC'
},
height: '60%',
lineWidth: 2
}, {
title: {
text: 'Volume'
},
top: '65%',
height: '35%',
offset: 0,
lineWidth: 2
}],
series: [{
type: 'candlestick',
name: 'AAPL',
data: ohlc,
dataGrouping: {
units: groupingUnits
}
}, {
type: 'column',
name: 'Volume',
data: volume,
yAxis: 1,
dataGrouping: {
units: groupingUnits
}
},{
type : 'flags',
data : flagData,
onSeries : 'dataseries',
shape : 'squarepin',
width : 16
}]
});
});
});
http://api.highcharts.com/highstock#series.data.marker
http://jsfiddle.net/gh/get/jquery/1.9.1/highslide-software/highcharts.com/tree/master/samples/stock/demo/flags-shapes/