配置项如下
var data = [0.4, 0.5, 0.6, 0.5, 0.2, 0.1, 0.4, 0.5, 0.8, 0.5, 0.2, 0.1];
var lineData = [];
data.forEach((v, i) => {
lineData.push(
[i, v]
);
});
option = {
backgroundColor: '#043065',
tooltip: {},
color: ['#00f8ff'],
xAxis: {
data: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12],
boundaryGap: 0,
axisLine: {
show: true,
lineStyle: {
color: 'rgba(135,140,147,0.8)',
}
},
axisLabel: {
textStyle: {
color: '#ddd'
}
},
},
yAxis: {
//name: 'mg/L',
axisLine: {
show: true,
lineStyle: {
color: 'rgba(135,140,147,0.8)',
}
},
axisLabel: {
textStyle: {
color: '#ddd'
}
},
splitLine: {
show: false
}
},
series: [{
name: '2018',
type: 'line',
//smooth: true,
symbol: 'image://',
symbolSize: 42,
showSymbol: false,
lineStyle: {
color: {
colorStops: [{
offset: 1,
color: 'rgb(130, 30, 255)'
},
{
offset: 0,
color: 'rgb(82, 207, 255)'
}
]
},
// color: {
// colorStops: [{
// offset: 0,
// color: '#821eff'
// },
// {
// offset: 1,
// color: '#204fff'
// }
// ],
// }
// width: 3
},
areaStyle: { //区域填充样式
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: 'rgba(0, 236, 255, 0.5)'
}, {
offset: 1,
color: 'rgba(0, 136, 212, 0)'
}], false),
shadowColor: 'rgba(0, 0, 0, 0.1)',
shadowBlur: 10
}
},
data: data
},
{
name: '2018',
type: 'effectScatter',
zlevel: 3,
//showSymbol: false,
symbolSize: function(val, params) {
//console.log(val, o);
/* //按数值大小
if(val < 0.6){
return 0;
}
return Math.max(val * 20, 8);
*/
//按拐点
var idx = params.dataIndex;
var pre = data[idx - 1];
var next = data[idx + 1];
if (pre && next &&
(
(params.data > pre && params.data > next) ||
(params.data < pre && params.data < next)
)
) {
return Math.max(val * 20, 8);
}
return 0;
},
showEffectOn: 'render',
rippleEffect: {
brushType: 'fill',
color: '#e66',
scale: 5
},
itemStyle: {
color: '#f55'
},
hoverAnimation: true,
data: data
},
{
type: 'lines',
polyline: true,
coordinateSystem: 'cartesian2d',
zlevel: 2,
effect: {
show: true,
period: 8,
trailLength: .5,
//color: 'rgba(255,255,255,.3)',
color: 'rgb(130, 30, 255, .5)',
symbolSize: [4, 10]
},
lineStyle: {
normal: {
//color: '#f00',
width: 0,
//curveness: 1
}
},
data: [{
coords: lineData
}]
},
{
type: 'lines',
polyline: true,
coordinateSystem: 'cartesian2d',
zlevel: 2,
effect: {
show: true,
period: 8,
trailLength: 1,
delay: 1000,
color: 'rgb(82, 207, 255, .5)',
symbolSize: [4, 10]
},
lineStyle: {
normal: {
//color: '#f00',
width: 0,
//curveness: 1
}
},
data: [{
coords: lineData
}]
},
{
type: 'lines',
polyline: true,
coordinateSystem: 'cartesian2d',
zlevel: 2,
effect: {
show: true,
period: 8,
trailLength: 1,
delay: 3000,
color: 'rgb(130, 30, 255, .5)',
symbolSize: [4, 10]
},
lineStyle: {
normal: {
//color: '#f00',
width: 0,
//curveness: 1
}
},
data: [{
coords: lineData
}]
},
{
type: 'lines',
polyline: true,
coordinateSystem: 'cartesian2d',
zlevel: 2,
effect: {
show: true,
period: 8,
trailLength: 1,
delay: 5000,
color: 'rgb(82, 207, 255, .5)',
symbolSize: [4, 10]
},
lineStyle: {
normal: {
//color: '#f00',
width: 0,
//curveness: 1
}
},
data: [{
coords: lineData
}]
},
]
};
var timeTicket = null;
function autohover(myChart, dataLength, time) {
var count = 0;
function startFn() {
myChart.dispatchAction({
type: 'downplay',
seriesIndex: 0, //serieIndex的索引值 可以触发多个
});
myChart.dispatchAction({
type: 'highlight',
seriesIndex: 0,
dataIndex: (count) % dataLength
});
myChart.dispatchAction({
type: 'showTip',
seriesIndex: 0,
dataIndex: (count) % dataLength
});
count++;
}
timeTicket && clearInterval(timeTicket);
timeTicket = setInterval(startFn, time);
myChart.on('mouseover', function(params) {
clearInterval(timeTicket);
});
myChart.on('mouseout', function(params) {
timeTicket && clearInterval(timeTicket);
timeTicket = setInterval(startFn, time);
});
}
autohover(myChart, data.length, 1000);