echarts-auto-tooltip.js 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. (function (global) {
  2. global.tools = global.tools || {};
  3. /**
  4. * echarts tooltip 自动轮播
  5. * @author liuyishi
  6. * @param chart
  7. * @param chartOption
  8. * @param options
  9. * {
  10. * interval 轮播时间间隔,单位毫秒,默认为2000
  11. * loopSeries boolean类型,默认为false。
  12. * true表示循环所有series的tooltip,false则显示指定seriesIndex的tooltip
  13. * seriesIndex 默认为0,指定某个系列(option中的series索引)循环显示tooltip,
  14. * 当loopSeries为true时,从seriesIndex系列开始执行.
  15. * }
  16. * @returns {{clearLoop: clearLoop}}
  17. */
  18. tools.loopShowTooltip = function (chart, chartOption, options) {
  19. var defaultOptions = {
  20. interval: 2000,
  21. loopSeries: false,
  22. seriesIndex: 0,
  23. updateData: null
  24. };
  25. if (!chart || !chartOption) {
  26. return {};
  27. }
  28. var dataIndex = 0; // 数据索引,初始化为-1,是为了判断是否是第一次执行
  29. var seriesIndex = 0; // 系列索引
  30. var timeTicket = 0;
  31. var seriesLen = chartOption.series.length; // 系列个数
  32. var dataLen = 0; // 某个系列数据个数
  33. var chartType; // 系列类型
  34. var first = true;
  35. // 不循环series时seriesIndex指定显示tooltip的系列,不指定默认为0,指定多个则默认为第一个
  36. // 循环series时seriesIndex指定循环的series,不指定则从0开始循环所有series,指定单个则相当于不循环,指定多个
  37. // 要不要添加开始series索引和开始的data索引?
  38. if (options) {
  39. options.interval = options.interval || defaultOptions.interval;
  40. options.loopSeries = options.loopSeries || defaultOptions.loopSeries;
  41. options.seriesIndex = options.seriesIndex || defaultOptions.seriesIndex;
  42. options.updateData = options.updateData || defaultOptions.updateData;
  43. } else {
  44. options = defaultOptions;
  45. }
  46. // 如果设置的seriesIndex无效,则默认为0
  47. if (options.seriesIndex < 0 || options.seriesIndex >= seriesLen) {
  48. seriesIndex = 0;
  49. } else {
  50. seriesIndex = options.seriesIndex;
  51. }
  52. function autoShowTip() {
  53. function showTip() {
  54. // 判断是否更新数据
  55. if (dataIndex === 0 && !first && typeof options.updateData === "function") {
  56. options.updateData();
  57. chart.setOption(chartOption);
  58. }
  59. var series = chartOption.series;
  60. chartType = series[seriesIndex].type; // 系列类型
  61. dataLen = series[seriesIndex].data.length; // 某个系列的数据个数
  62. var tipParams = {seriesIndex: seriesIndex};
  63. switch (chartType) {
  64. case 'map':
  65. case 'pie':
  66. case 'chord':
  67. tipParams.name = series[seriesIndex].data[dataIndex].name;
  68. break;
  69. case 'radar': // 雷达图
  70. tipParams.seriesIndex = seriesIndex;
  71. tipParams.dataIndex = dataIndex;
  72. break;
  73. default:
  74. tipParams.dataIndex = dataIndex;
  75. break;
  76. }
  77. if (chartType === 'pie' || chartType === 'radar') {
  78. // 取消之前高亮的图形
  79. chart.dispatchAction({
  80. type: 'downplay',
  81. seriesIndex: options.loopSeries ? (seriesIndex === 0 ? seriesLen - 1 : seriesIndex - 1) : seriesIndex,
  82. dataIndex: dataIndex === 0 ? dataLen - 1 : dataIndex - 1
  83. });
  84. // 高亮当前图形
  85. chart.dispatchAction({
  86. type: 'highlight',
  87. seriesIndex: seriesIndex,
  88. dataIndex: dataIndex
  89. });
  90. }
  91. // 显示 tooltip
  92. tipParams.type = 'showTip';
  93. chart.dispatchAction(tipParams);
  94. dataIndex = (dataIndex + 1) % dataLen;
  95. if (options.loopSeries && dataIndex === 0 && !first) { // 数据索引归0表示当前系列数据已经循环完
  96. seriesIndex = (seriesIndex + 1) % seriesLen;
  97. }
  98. first = false;
  99. }
  100. showTip();
  101. timeTicket = setInterval(showTip, options.interval);
  102. }
  103. // 关闭轮播
  104. function stopAutoShow() {
  105. if (timeTicket) {
  106. clearInterval(timeTicket);
  107. timeTicket = 0;
  108. if (chartType === 'pie' || chartType === 'radar') {
  109. // 取消高亮的图形
  110. chart.dispatchAction({
  111. type: 'downplay',
  112. seriesIndex: options.loopSeries ? (seriesIndex === 0 ? seriesLen - 1 : seriesIndex - 1) : seriesIndex,
  113. dataIndex: dataIndex === 0 ? dataLen - 1 : dataIndex - 1
  114. });
  115. }
  116. }
  117. }
  118. var zRender = chart.getZr();
  119. function zRenderMouseMove(param) {
  120. if (param.event) {
  121. // 阻止canvas上的鼠标移动事件冒泡
  122. param.event.cancelBubble = true;
  123. }
  124. stopAutoShow();
  125. }
  126. // 离开echarts图时恢复自动轮播
  127. function zRenderGlobalOut() {
  128. if (!timeTicket) {
  129. autoShowTip();
  130. }
  131. }
  132. // 鼠标在echarts图上时停止轮播
  133. chart.on('mousemove', stopAutoShow);
  134. zRender.on('mousemove', zRenderMouseMove);
  135. zRender.on('globalout', zRenderGlobalOut);
  136. autoShowTip();
  137. return {
  138. clearLoop: function () {
  139. if (timeTicket) {
  140. clearInterval(timeTicket);
  141. timeTicket = 0;
  142. }
  143. chart.off('mousemove', stopAutoShow);
  144. zRender.off('mousemove', zRenderMouseMove);
  145. zRender.off('globalout', zRenderGlobalOut);
  146. }
  147. };
  148. };
  149. })(window);