echarts tooltip輪播

新建loopShowTooltip.js并引入引入

import { loopShowTooltip } from "../../../utils/loopShowTooltip.js"

loopShowTooltip.js文件

/**
 * echarts tooltip輪播
 * @param chart ECharts實(shí)例
 * @param chartOption echarts的配置信息
 * @param options object 選項(xiàng)
 * {
 *  interval    輪播時(shí)間間隔,單位毫秒逢勾,默認(rèn)為2000
 *  loopSeries  boolean類型桅打,默認(rèn)為false剪撬。
 *              true表示循環(huán)所有series的tooltip炒瘸,false則顯示指定seriesIndex的tooltip
 *  seriesIndex 默認(rèn)為0达传,指定某個(gè)系列(option中的series索引)循環(huán)顯示tooltip碌更,
 *              當(dāng)loopSeries為true時(shí)瓶籽,從seriesIndex系列開(kāi)始執(zhí)行恃鞋。
 *  updateData  自定義更新數(shù)據(jù)的函數(shù)崖媚,默認(rèn)為null;
 *              用于類似于分頁(yè)的效果恤浪,比如總數(shù)據(jù)有20條畅哑,chart一次只顯示5條,全部數(shù)據(jù)可以分4次顯示水由。
 * }
 * @returns {{clearLoop: clearLoop}|undefined}
 */
export function loopShowTooltip(chart, chartOption, options) {
    let defaultOptions = {
        interval: 2000,
        loopSeries: false,
        seriesIndex: 0,
        updateData: null,
        shunXu: "zhengXu", //播放順序 默認(rèn)正序  zhengXu daoXu
    };

    if (!chart || !chartOption) {
        return;
    }
    if (options) {
        options.interval = options.interval || defaultOptions.interval;
        options.loopSeries = options.loopSeries || defaultOptions.loopSeries;
        options.seriesIndex = options.seriesIndex || defaultOptions.seriesIndex;
        options.updateData = options.updateData || defaultOptions.updateData;
        options.zhengXu = options.zhengXu || defaultOptions.zhengXu;
    } else {
        options = defaultOptions;
    }




    let dataIndex = -1; // 數(shù)據(jù)索引荠呐,初始化為-1,是為了判斷是否是第一次執(zhí)行
    let seriesIndex = 0; // 系列索引
    let timeTicket = 0;
    let seriesLen = chartOption.series.length; // 系列個(gè)數(shù)
    let dataLen = 0; // 某個(gè)系列數(shù)據(jù)個(gè)數(shù)
    let chartType; // 系列類型
    let first = true;
    let lastShowSeriesIndex = 0;
    let lastShowDataIndex = 0;

    if (seriesLen === 0) {
        return;
    }

    // 待處理列表
    // 不循環(huán)series時(shí)seriesIndex指定顯示tooltip的系列砂客,不指定默認(rèn)為0直秆,指定多個(gè)則默認(rèn)為第一個(gè)
    // 循環(huán)series時(shí)seriesIndex指定循環(huán)的series,不指定則從0開(kāi)始循環(huán)所有series鞭盟,指定單個(gè)則相當(dāng)于不循環(huán)圾结,指定多個(gè)
    // 要不要添加開(kāi)始series索引和開(kāi)始的data索引?


    // 如果設(shè)置的seriesIndex無(wú)效齿诉,則默認(rèn)為0
    if (options.seriesIndex < 0 || options.seriesIndex >= seriesLen) {
        seriesIndex = 0;
    } else {
        seriesIndex = options.seriesIndex;
    }

    /**
     * 清除定時(shí)器
     */
    function clearLoop() {
        if (timeTicket) {
            clearInterval(timeTicket);
            timeTicket = 0;
        }

        chart.off('mousemove', stopAutoShow);
        zRender.off('mousemove', zRenderMouseMove);
        zRender.off('globalout', zRenderGlobalOut);
    }

    /**
     * 取消高亮
     */
    function cancelHighlight() {
        /**
         * 如果dataIndex為0表示上次系列完成顯示筝野,如果是循環(huán)系列,且系列索引為0則上次是seriesLen-1粤剧,否則為seriesIndex-1歇竟;
         * 如果不是循環(huán)系列,則就是當(dāng)前系列抵恋;
         * 如果dataIndex>0則就是當(dāng)前系列焕议。
         */
        let tempSeriesIndex = dataIndex === 0 ? options.loopSeries ? seriesIndex === 0 ? seriesLen - 1 : seriesIndex -
            1 : seriesIndex : seriesIndex;
        let tempType = chartOption.series[tempSeriesIndex].type;

        if (tempType === 'pie' || tempType === 'radar' || tempType === 'map') {
            chart.dispatchAction({
                type: 'downplay',
                seriesIndex: lastShowSeriesIndex,
                dataIndex: lastShowDataIndex,
            }); // wait 系列序號(hào)為0且循環(huán)系列,則要判斷上次的系列類型是否是pie弧关、radar
        }
    }

    /**
     * 自動(dòng)輪播tooltip
     */
    function autoShowTip() {
        let invalidSeries = 0;
        let invalidData = 0;

        function showTip() {
            // chart不在頁(yè)面中時(shí)盅安,銷毀定時(shí)器
            let dom = chart.getDom();
            if (document !== dom && !document.documentElement.contains(dom)) {
                clearLoop();
                return;
            }

            // 判斷是否更新數(shù)據(jù)
            if (
                dataIndex === 0 &&
                !first &&
                typeof options.updateData === 'function'
            ) {
                options.updateData();
                chart.setOption(chartOption);
            }

            let series = chartOption.series;
            let currSeries = series[seriesIndex];
            if (!series || series.length === 0 || !currSeries || !currSeries.type || !currSeries.data || !currSeries
                .data.length) {
                return;
            }

            chartType = currSeries.type; // 系列類型
            dataLen = currSeries.data.length; // 某個(gè)系列的數(shù)據(jù)個(gè)數(shù)

            let tipParams = {
                seriesIndex: seriesIndex
            };
            switch (chartType) {
                case 'pie':
                    // 處理餅圖中數(shù)據(jù)為0或系列名為空的不顯示tooltip
                    if (!currSeries.data[dataIndex].name || currSeries.data[dataIndex].name === '空' || !currSeries.data[
                            dataIndex].value) {
                        invalidData += 1;
                        dataIndex = (dataIndex + 1) % dataLen;
                        if (options.loopSeries && dataIndex === 0) {
                            // 數(shù)據(jù)索引歸0表示當(dāng)前系列數(shù)據(jù)已經(jīng)循環(huán)完
                            // 無(wú)效數(shù)據(jù)個(gè)數(shù)個(gè)總數(shù)據(jù)個(gè)數(shù)相等唤锉,則該系列無(wú)效
                            if (invalidData === dataLen) {
                                invalidSeries += 1;
                            }

                            // 新系列,重置無(wú)效數(shù)據(jù)個(gè)數(shù)
                            invalidData = 0;

                            // 系列循環(huán)遞增1
                            seriesIndex = (seriesIndex + 1) % seriesLen;
                            // 系列數(shù)循環(huán)至起始值時(shí)重置無(wú)效系列數(shù)
                            if (seriesIndex === options.seriesIndex) {
                                if (seriesLen !== invalidSeries) {
                                    // 下一次系列輪回别瞭,重置無(wú)效系列數(shù)
                                    invalidSeries = 0;
                                    showTip();
                                } else {
                                    // 下一次系列輪回窿祥,重置無(wú)效系列數(shù)
                                    invalidSeries = 0;
                                    clearLoop();
                                }
                            } else {
                                showTip();
                            }
                        } else if (!options.loopSeries && dataIndex === 0) {
                            if (dataLen !== invalidData) {
                                invalidData = 0;
                                showTip();
                            } else {
                                invalidData = 0;
                                clearLoop();
                            }
                        } else {
                            showTip();
                        }

                        return;
                    }
                    // eslint-disable-next-line no-fallthrough
                    case 'map':
                    case 'chord':
                        tipParams.name = currSeries.data[dataIndex].name;
                        break;
                    case 'radar': // 雷達(dá)圖
                        tipParams.seriesIndex = seriesIndex;
                        // tipParams.dataIndex = dataIndex;
                        break;
                    case 'lines': // 線圖地圖上的lines忽略
                        dataIndex = 0;
                        seriesIndex = (seriesIndex + 1) % seriesLen;
                        invalidSeries++; // 記錄無(wú)效系列數(shù),如果無(wú)效系列數(shù)和系列總數(shù)相等則取消循環(huán)顯示
                        if (seriesLen !== invalidSeries) {
                            showTip();
                        } else {
                            clearLoop();
                        }
                        return;
                    default:
                        tipParams.dataIndex = dataIndex;
                        break;
            }

            if (chartType === 'pie' || chartType === 'radar' || chartType === 'map') {
                if (!first) {
                    cancelHighlight();
                }

                // 高亮當(dāng)前圖形
                chart.dispatchAction({
                    type: 'highlight',
                    seriesIndex: seriesIndex,
                    dataIndex: dataIndex,
                });
            }

            // 顯示 tooltip
            tipParams.type = 'showTip';
            chart.dispatchAction(tipParams);

            lastShowSeriesIndex = seriesIndex;
            lastShowDataIndex = dataIndex;

            //如果是倒序
            if (options.shunXu == "daoXu") {
                if (first) {
                    dataIndex = dataLen - 1;
                } else {
                    dataIndex--;
                    if (dataIndex < 0) {
                        dataIndex = dataLen - 1;
                    }
                }
            } else {
                dataIndex = (dataIndex + 1) % dataLen;
                if (options.loopSeries && dataIndex === 0) {
                    // 數(shù)據(jù)索引歸0表示當(dāng)前系列數(shù)據(jù)已經(jīng)循環(huán)完
                    invalidData = 0;
                    seriesIndex = (seriesIndex + 1) % seriesLen;
                    if (seriesIndex === options.seriesIndex) {
                        invalidSeries = 0;
                    }
                }
            }
            if (options.loopSeries && dataIndex === 0) {
                // 數(shù)據(jù)索引歸0表示當(dāng)前系列數(shù)據(jù)已經(jīng)循環(huán)完
                invalidData = 0;
                seriesIndex = (seriesIndex + 1) % seriesLen;
                if (seriesIndex === options.seriesIndex) {
                    invalidSeries = 0;
                }
            }

            first = false;
        }

        showTip();
        timeTicket = setInterval(showTip, options.interval);
    }



    // 關(guān)閉輪播
    function stopAutoShow() {
        if (timeTicket) {
            clearInterval(timeTicket);
            timeTicket = 0;

            if (chartType === 'pie' || chartType === 'radar' || chartType === 'map') {
                cancelHighlight();
            }
        }
    }
    //從頭開(kāi)始
    function Retart() {
        first = true;
        stopAutoShow()
        autoShowTip();
    }

    let zRender = chart.getZr();

    function zRenderMouseMove(param) {
        if (param.event) {
            // 阻止canvas上的鼠標(biāo)移動(dòng)事件冒泡
            // param.event.cancelBubble = true;
        }
        stopAutoShow();
    }

    // 離開(kāi)echarts圖時(shí)恢復(fù)自動(dòng)輪播
    function zRenderGlobalOut() {
        // console.log("移出了")
        // console.log(timeTicket)
        if (!timeTicket) {
            autoShowTip();
        }
    }

    // 鼠標(biāo)在echarts圖上時(shí)停止輪播
    chart.on('mousemove', stopAutoShow);
    zRender.on('mousemove', zRenderMouseMove);
    zRender.on('globalout', zRenderGlobalOut);

    autoShowTip();

    return {
        Retart: Retart,
        clearLoop: clearLoop
    };
}

使用方法

showLoop() {
      this.tootipTimer && this.tootipTimer.clearLoop();
      this.tootipTimer = 0;
      // 調(diào)用輪播的方法
      // myChart為Echarts容器實(shí)例
      this.tootipTimer = loopShowTooltip(this.chartMap, this.option, {
        interval: 2000, // 輪播間隔時(shí)間
        loopSeries: true, // 是否開(kāi)啟輪播循環(huán)
        // shunXu: "daoXu", // 顯示順序
        // loopSeries: boolean類型蝙寨,默認(rèn)為false晒衩。true表示循環(huán)所有series的tooltip;false則顯示指定seriesIndex的tooltip墙歪。
        // seriesIndex: 默認(rèn)為0听系,指定某個(gè)系列(option中的series索引)循環(huán)顯示tooltip,當(dāng)loopSeries為true時(shí)虹菲,從seriesIndex系列開(kāi)始執(zhí)行跛锌。
      })
},
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市届惋,隨后出現(xiàn)的幾起案子髓帽,更是在濱河造成了極大的恐慌,老刑警劉巖脑豹,帶你破解...
    沈念sama閱讀 211,376評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件郑藏,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡瘩欺,警方通過(guò)查閱死者的電腦和手機(jī)必盖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)俱饿,“玉大人歌粥,你說(shuō)我怎么就攤上這事∨牟海” “怎么了失驶?”我有些...
    開(kāi)封第一講書人閱讀 156,966評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)枣购。 經(jīng)常有香客問(wèn)我嬉探,道長(zhǎng),這世上最難降的妖魔是什么棉圈? 我笑而不...
    開(kāi)封第一講書人閱讀 56,432評(píng)論 1 283
  • 正文 為了忘掉前任涩堤,我火速辦了婚禮,結(jié)果婚禮上分瘾,老公的妹妹穿的比我還像新娘胎围。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,519評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布白魂。 她就那樣靜靜地躺著汽纤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪碧聪。 梳的紋絲不亂的頭發(fā)上冒版,一...
    開(kāi)封第一講書人閱讀 49,792評(píng)論 1 290
  • 那天液茎,我揣著相機(jī)與錄音逞姿,去河邊找鬼。 笑死捆等,一個(gè)胖子當(dāng)著我的面吹牛滞造,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播栋烤,決...
    沈念sama閱讀 38,933評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼谒养,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了明郭?” 一聲冷哼從身側(cè)響起买窟,我...
    開(kāi)封第一講書人閱讀 37,701評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎薯定,沒(méi)想到半個(gè)月后始绍,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,143評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡话侄,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,488評(píng)論 2 327
  • 正文 我和宋清朗相戀三年亏推,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片年堆。...
    茶點(diǎn)故事閱讀 38,626評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡吞杭,死狀恐怖变丧,靈堂內(nèi)的尸體忽然破棺而出芽狗,到底是詐尸還是另有隱情,我是刑警寧澤痒蓬,帶...
    沈念sama閱讀 34,292評(píng)論 4 329
  • 正文 年R本政府宣布,位于F島的核電站谊却,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏乙嘀。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,896評(píng)論 3 313
  • 文/蒙蒙 一虎谢、第九天 我趴在偏房一處隱蔽的房頂上張望婴噩。 院中可真熱鬧擎场,春花似錦、人聲如沸几莽。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,742評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)章蚣。三九已至站欺,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間纤垂,已是汗流浹背矾策。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留峭沦,地道東北人贾虽。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像熙侍,于是被迫代替她去往敵國(guó)和親榄鉴。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,494評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容