123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227 |
- (function (global) {
- global.tools = global.tools || {};
-
- tools.loopShowTooltip = function (chart, chartOption, options) {
- let defaultOptions = {
- interval: 2000,
- loopSeries: false,
- seriesIndex: 0,
- updateData: null
- };
- if (!chart || !chartOption) {
- return;
- }
- let dataIndex = 0;
- let seriesIndex = 0;
- let timeTicket = 0;
- let seriesLen = chartOption.series.length;
- let dataLen = 0;
- let chartType;
- let first = true;
- let lastShowSeriesIndex = 0;
- let lastShowDataIndex = 0;
- if (seriesLen === 0) {
- 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;
- } else {
- options = defaultOptions;
- }
-
- if (options.seriesIndex < 0 || options.seriesIndex >= seriesLen) {
- seriesIndex = 0;
- } else {
- seriesIndex = options.seriesIndex;
- }
-
- function clearLoop() {
- if (timeTicket) {
- clearInterval(timeTicket);
- timeTicket = 0;
- }
- chart.off('mousemove', stopAutoShow);
- zRender.off('mousemove', zRenderMouseMove);
- zRender.off('globalout', zRenderGlobalOut);
- }
-
- function cancelHighlight() {
-
- 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') {
- chart.dispatchAction({
- type: 'downplay',
- seriesIndex: lastShowSeriesIndex,
- dataIndex: lastShowDataIndex
- });
- }
- }
-
- function autoShowTip() {
- let invalidSeries = 0;
- let invalidData = 0;
- function showTip() {
-
- 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;
- let tipParams = {seriesIndex: seriesIndex};
- switch (chartType) {
- case 'pie':
- case 'map':
- case 'chord':
- tipParams.name = currSeries.data[dataIndex].name;
- break;
- case 'radar':
- tipParams.seriesIndex = seriesIndex;
- tipParams.dataIndex = dataIndex;
- break;
- default:
- tipParams.dataIndex = dataIndex;
- break;
- }
- if (chartType === 'pie' || chartType === 'radar') {
- if (!first) {
- cancelHighlight();
- }
-
- chart.dispatchAction({
- type: 'highlight',
- seriesIndex: seriesIndex,
- dataIndex: dataIndex
- });
- }
-
- tipParams.type = 'showTip';
-
- setTimeout(() => {
- chart.dispatchAction(tipParams);
- }, 0);
- lastShowSeriesIndex = seriesIndex;
- lastShowDataIndex = dataIndex;
- dataIndex = (dataIndex + 1) % dataLen;
- if (options.loopSeries && dataIndex === 0) {
- invalidData = 0;
- seriesIndex = (seriesIndex + 1) % seriesLen;
- if (seriesIndex === options.seriesIndex) {
- invalidSeries = 0;
- }
- }
- first = false;
- }
- showTip();
- timeTicket = setInterval(showTip, options.interval);
- }
-
- function stopAutoShow() {
- if (timeTicket) {
- clearInterval(timeTicket);
- timeTicket = 0;
- if (chartType === 'pie' || chartType === 'radar') {
- cancelHighlight();
- }
- }
- }
- let zRender = chart.getZr();
- function zRenderMouseMove(param) {
- if (param.event) {
-
- param.event.cancelBubble = true;
- }
- stopAutoShow();
- }
-
- function zRenderGlobalOut() {
- if (!timeTicket) {
- autoShowTip();
- }
- }
-
- chart.on('mousemove', stopAutoShow);
- zRender.on('mousemove', zRenderMouseMove);
- zRender.on('globalout', zRenderGlobalOut);
- autoShowTip();
- return {
- clearLoop: clearLoop
- };
- };
- })(window);
|