Echarts轮播功能(echarts动画)

Echarts轮播功能

轮播方法封装

//mapchart是echarts实例、option是echarts的option
cycleshow ( mapChart, option) {
var app = {};
app. currentIndex = -1;
var timer;
//设置开始执行对应行为的时间
setTimeout(() =>{
//启动之前先把定时器清空....
clearInterval(timer);
timer = setInterval(changeStyle,2000);
},500);
//获取图表信息
const changeStyle=()=>{
//获取图表位置与数据长度
var option = mapChart.get0ption();
var dataLen =  option.series[0]?option.series[0].data.length: 0;
//取消之前高亮的图形,让下一个图形继续高亮,形成轮播的效果
mapChart.dispatchAction({
type: "downplay",
seriesIndex: 0,
dataIndex: app.currentIndex,});
app.currentIndex = (app.currentIndex + 1) % dataLen;
//高亮当前图形
mapChart.dispatchAction({
type: "highlight",
seriesIndex: 0,
dataIndex:app.currentIndex,});
//显示 tooltip
mapChart.dispatchAction({
type: "showTip",
seriesIndex: 0,
dataIndex:app.currentIndex,});
}
//定义一个mouse_flag = false;未移入
var mouse_flag = false;
mapChart.on( "mouseover", function (params) {
//鼠标移入清除计时器
mouse_flag = true;
clearInterval(timer);});
//为了判断鼠标是否在区域中还是不在区域
mapChart.on( "mouseout", function (params) {
if (params.name) {
mouse_flag = true;
//鼠标移入移开后清除高亮与计时器
mapChart.dispatchAction({
type: "downplay",});
clearInterval(timer)
}})
mapChart.on( "click", function (param){
if (mouse_flag) {
clearInterval(timer);}else {
setTimeout(() =>{//启动之前先把定时器清空
clearinterval(timer);
// setInterval调用的是函数名
timer = setInterval(changeStyle,2000);},500);
}
);
option && mapChart.setOption(option);
}


调用方法

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

此人很懒€

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值