配置项如下
var data = [[10, 'ctrl'], [52, 'alt'], [200, 'esc'], [334, 'cmd'], [390, 'option'], [330, 'delete'], [220, 'shift']].map(function (entry, index) {
entry.unshift(index);
return entry;
});
echarts.graphic.Mask = echarts.graphic.extendShape({
type: 'mask',
shape: {
x: 0,
y: 0,
width: 0,
height: 0
},
buildPath: function (ctx, shape) {
var height = shape.height;
var width = shape.width;
var x = shape.x;
var y = shape.y;
var cx = x + width / 2;
var cy = y + height / 2;
ctx.arc(cx, cy, width / 2, 0, Math.PI * 2, true);
ctx.rect(x - 1, y - 1, width + 2, height + 2);
ctx.closePath();
}
});
option = {
color: ['#3398DB'],
tooltip : {
trigger: 'axis',
axisPointer : { // 坐标轴指示器,坐标轴触发有效
type : 'shadow' // 默认为直线,可选为:'line' | 'shadow'
}
},
grid: {
left: '3%',
right: '4%',
bottom: 150,
containLabel: true
},
xAxis : [
{
type : 'category',
data : ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'],
axisTick: {
aliganWithLabel: true
}
}
],
yAxis : [
{
type : 'value'
}
],
series : [
{
name:'直接访问',
type:'bar',
barWidth: '60%',
data: data
},
{
type: 'custom',
renderItem: function (params, api) {
var xValue = api.value(0);
var bandWidth = api.size([1, 0])[0] * 0.5;
var x = api.coord([xValue, 0])[0] - bandWidth / 2;
var y = params.coordSys.y + params.coordSys.height + 30;
return {
type: 'group',
children: [{
type: 'mask',
shape: {
x: x,
y: y,
width: bandWidth,
height: bandWidth
},
style: {
fill: '#eee',
stroke: null
},
styleEmphasis: {
fill: '#eee',
text: api.value(2),
textPosition: 'bottom',
textFill: '#333'
},
z2: 10
}, {
type: 'image',
style: {
x: x,
y: y,
width: bandWidth,
height: bandWidth,
image: ''
}
}]
}
},
encode: {
tooltip: [2]
},
data: data
}
]
};