EChar 图表实例

在这里插入图片描述

      warnChart(val) {
          var _this = this;
          let option;
          var pie = document.getElementById('warn_chart_one');
          var pieDom = Echarts.init(pie);
          option = {
            backgroundColor: 'transparent',
            series: [
              {
                name: '',
                type: 'gauge',
                radius: '75%',
                clockwise: false,
                startAngle: '90',
                endAngle: '-269.9999',
                splitNumber: 16,
                detail: {
                  show: false
                },
                pointer: {
                  show: false
                },
                axisLine: {
                  show: true,
                  lineStyle: {
                    color: [
                      [0, '#315099'],
                      [(100 - this.orderData.export_rate) / 100, '#0ff'],
                      [1, '#315099']
                    ],
                    width: 15
                  },
                  data: [0]
                },
                axisTick: {
                  show: false
                },
                splitLine: {
                  show: true,
                  length: 16,
                  lineStyle: {
                    color: '#173956',
                    width: 8
                  }
                },
                axisLabel: {
                  show: false
                }
              },
              {
                name: '中心背景',
                type: 'pie',
                zlevel: 20,
                silent: true,
                radius: ['0', '40%'],
                hoverAnimation: false,
                data: [1],
                label: {
                  show: false
                },
                color: 'rgba(9,46,195,0.2)',
                itemStyle: {
                  // color: 'rgba(9,46,195,0.2)'
                },
                labelLine: {
                  normal: {
                    show: false
                  }
                }
              }, {
                name: '中心原型边框',
                type: 'pie',
                zlevel: 20,
                silent: true,
                radius: ['40%', '42%'],
                hoverAnimation: false,
                // animation:false,
                data: [1],
                itemStyle: {
                  color: '#214F87'
                },
                labelLine: {
                  normal: {
                    show: false
                  }
                }
              }, {
                name: '外围边框',
                type: 'pie',
                zlevel: 20,
                silent: true,
                radius: ['88%', '90%'],
                hoverAnimation: false,
                // animation:false,
                data: [1],
                itemStyle: {
                  // color: '#214F87'
                  color: {
                    x: 0,
                    y: 0,
                    x2: 0,
                    y2: 1,
                    colorStops: [{
                      offset: 0, color: '#17FCFE' // 0% 处的颜色
                    }, {
                      offset: 1, color: 'rgba(9,46,195,0.2)' // 100% 处的颜色
                    }],
                    global: false // 缺省为 false
                  }
                },
                labelLine: {
                  normal: {
                    show: false
                  }
                }
              }, {
                name: '外围边框',
                type: 'pie',
                zlevel: 20,
                silent: true,
                radius: ['96%', '98%'],
                hoverAnimation: false,
                // animation:false,
                data: [1],
                itemStyle: {
                  color: {
                    x: 0,
                    y: 0,
                    x2: 1,
                    y2: 0,
                    colorStops: [{
                      offset: 0, color: '#17FCFE' // 0% 处的颜色
                    }, {
                      offset: 0.9, color: 'rgba(9,46,195,0.2)' // 100% 处的颜色
                    }, {
                      offset: 1, color: 'rgba(9,46,195,0.2)' // 100% 处的颜色
                    }],
                    global: false // 缺省为 false
                  }
                },
                labelLine: {
                  normal: {
                    show: false
                  }
                }
              }
            ]
          }
          pieDom.setOption(option, true);
          pieDom.off('click'); //防止触发两次点击事件
          pieDom.resize();
          window.addEventListener('resize', function () {
            pieDom.resize();
          });
          //  监听dom变化,自适应echarts
          let chartObserver = new ResizeObserver(() => {
            pieDom.resize();
          });
          chartObserver.observe(pieDom.getDom());
        },

在这里插入图片描述

      quarterChart2(item, id) {
          var echartData = [];
          item.forEach((val,dataIndex) => {
            echartData.push({ name: val.name, value: val.num,dataIndex});
          });
          var data = echartData;
          var option;
          let _this = this;
          var dom = document.getElementById(id);
          var ChartDom = new_echarts.init(dom);
          var giftImageUrl =
            '';
          var scale = 1;
          var rich = {
            yellow: {
              color: '#ffc72b',
              fontSize: 16 * scale,
              padding: [5, 0],
              align: 'center'
            },
            total: {
              color: '#ffc72b',
              fontSize: 40 * scale,
              align: 'center'
            },
            white: {
              color: '#fff',
              align: 'center',
              fontSize: 14 * scale,
              padding: [6, 0]
            },
            blue: {
              color: '#49dff0',
              fontSize: 16 * scale,
              align: 'center'
            },
            hr: {
              borderColor: '#0b5263',
              width: '100%',
              borderWidth: 1,
              height: 0
            }
          };
          var arrName = getArrayValue(data, 'name');
          var arrValue = getArrayValue(data, 'value');
          var sumValue = eval(arrValue.join('+'));
          var objData = array2obj(data, 'name');
          function getArrayValue(array, key) {
            var key = key || 'value';
            var res = [];
            if (array) {
              array.forEach(function (t) {
                res.push(t[key]);
              });
            }
            return res;
          }

          function array2obj(array, key) {
            var resObj = {};
            for (var i = 0; i < array.length; i++) {
              resObj[array[i][key]] = array[i];
            }
            return resObj;
          }
          option = {
            legend: {
              bottom: 'bottom',
              left: 'center',
              padding: [0, 0, 50, 0],
              textStyle: {
                color: '#cde3ff',
                fontSize: 16
              },
              formatter: function (params) {
                if (params.length > 12) {
                  return params.slice(0, 12) + '\n' + params.slice(12);
                } else {
                  return params;
                }
              }
            },
            tooltip: {
              show: true,
              trigger: 'item',
              confine: true,
                  formatter: function (val) {
                  var dotHtml = ``;
                  const tip =
                    `<div class='custom-tooltip-style'> ` + dotHtml + `<div class='custom-tooltip-text'>${val.name}</div>

                    <div class='custom-tooltip-num'>
                        <span class="ym-dialog-screen--echart-tooltip_tow${val.dataIndex}"></span> 
                        <span class="ym_fff_text">   企业数(家)</span>
                        <span  class="ym_blue_text">${val.value}家</span>
                    </div>
                    <div class='custom-tooltip-num'>
                      <span class="ym-dialog-screen--echart-tooltip_tow_null"></span> 
                      <span class="ym_fff_text"> 占比 </span>
                      <span  class="ym_blue_text">${((objData[val.name].value / sumValue) * 100).toFixed(1)}%</span>
                    </div> 
                  </div>`;
                  return tip;
              },
              textStyle: {
                rich: {
                  title: {
                    fontSize: 20,
                    lineHeight: 30,
                    color: '#6D7383'
                  },
                  value: {
                    fontSize: 18,
                    lineHeight: 20,
                    color: '#4DA1FF'
                  }
                }
              }
            },
            graphic: {
              elements: [
                {
                  type: 'image',
                  style: {
                    image: giftImageUrl,
                    width: 160 * scale,
                    height: 170 * scale
                  },
                  left: 'center',
                  top: 'center'
                }
              ]
            },
            series: [
              {
                name: '鐜姸',
                type: 'pie',
                zlevel: 1,
                silent: true,
                radius: ['35%', '47%'],
                hoverAnimation: false,
                color: [
                  'rgba(255,255,255,0.18)'
                ],
                // animation:false,
                data: [1],
                labelLine: {
                  normal: {
                    show: false
                  }
                }
              },
              {
                name: '涓昏鏁版嵁',
                zlevel: 11,
                type: 'pie',
                radius: ['37%', '45%'],
                hoverAnimation: true,
                color: [
                  new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                    {
                      offset: 0,
                      color: '#67DFD0'
                    },
                    {
                      offset: 1,
                      color: '#219EFF'
                    }
                  ]),
                  new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                    {
                      offset: 0,
                      color: '#2095E4'
                    },
                    {
                      offset: 1,
                      color: '#0E5CC5'
                    }
                  ]),
                  new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                    {
                      offset: 0,
                      color: '#D79FFE'
                    },
                    {
                      offset: 1,
                      color: '#7E65E0'
                    }
                  ]),
                  new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                    {
                      offset: 0,
                      color: '#F74FCD'
                    },
                    {
                      offset: 1,
                      color: '#A61586'
                    }
                  ]),
                  new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                    {
                      offset: 0,
                      color: '#FC7166'
                    },
                    {
                      offset: 1,
                      color: '#FC5491'
                    }
                  ]),
                  new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                    {
                      offset: 0,
                      color: '#F8CB6B'
                    },
                    {
                      offset: 1,
                      color: '#FE7B29'
                    }
                  ]),
                  new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                    {
                      offset: 0,
                      color: '#1DD888'
                    },
                    {
                      offset: 1,
                      color: '#01D7E3'
                    }
                  ]),
                  new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                    {
                      offset: 0,
                      color: '#91DF62'
                    },
                    {
                      offset: 1,
                      color: '#8BD9A5'
                    }
                  ]),
                  new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                    {
                      offset: 0,
                      color: '#A3BDED'
                    },
                    {
                      offset: 1,
                      color: '#6991C7'
                    }
                  ])
                ],
                label: {
                  normal: {
                    formatter: function (params, ticket, callback) {
                      var total = 0;
                      var percent = 0;
                      echartData.forEach(function (value, index, array) {
                        total += value.value;
                      });
                      percent = ((params.value / total) * 100).toFixed(1);
                      return (
                        '{white|' +
                        params.name +
                        '}\n{hr|}\n{yellow|' +
                        params.value +
                        '家' +
                        '}{blue|(' +
                        percent +
                        '%)}'
                      );
                    },
                    padding: [0, -5],
                    rich: rich
                  }
                },
                labelLine: {
                  normal: {
                    length: 62 * scale,
                    length2: 0,
                    lineStyle: {
                      color: '#0b5263'
                    }
                  }
                },
                // 缁熻鏁版嵁
                data: echartData
              },
              {
                name: '',
                zlevel: 10,
                type: 'gauge',
                splitNumber: 20, //鍒诲害鏁伴噺
                min: 0,
                max: 100,
                radius: '50%', //鍥捐〃灏哄
                center: ['50%', '50%'],
                startAngle: 90,
                endAngle: -269.9999,
                axisLine: {
                  show: false,
                  lineStyle: {
                    width: 0,
                    shadowBlur: 0,
                    color: [
                      [0, '#0dc2fe'],
                      [1, '#0dc2fe']
                    ]
                  }
                },
                axisTick: {
                  show: true,
                  lineStyle: {
                    color: '#106072',
                    width: 6
                  },
                  length: 4,
                  splitNumber: 5
                },
                splitLine: {
                  show: false
                },
                axisLabel: {
                  show: false
                },
                pointer: {
                  //浠〃鐩樻寚閽
                  show: 0
                },
                detail: {
                  offsetCenter: [0, '0%'], // x, y锛屽崟浣峱x
                  textStyle: {
                    // 鍏朵綑灞炴ч粯璁や娇鐢ㄥ叏灞鏂囨湰鏍峰紡锛岃瑙乀EXTSTYLE
                    color: 'rgba(255,255,255,0.18)',
                    fontSize: 50
                  },
                  formatter: function (name) {
                    var total = 0; //鏁版嵁鎬诲拰
                    var averagePercent; //缁煎悎姝g‘鐜
                    echartData.forEach(function (value, index, array) {
                      total += value.value;
                    });
                    return '{total|}';
                  },
                  rich: {
                    total: {}
                  }
                },
                data: [echartData[0].name]
              }
            ]
          };

          ChartDom.setOption(option);
          ChartDom.on('click', (params) => {
            this.baseComsumableClickItem();
          });
          window.addEventListener('resize', function () {
            ChartDom.resize();
          });
          //  监听dom变化,自适应echarts
          let chartObserver = new ResizeObserver(() => {
            ChartDom.resize();
          });
          chartObserver.observe(ChartDom.getDom());
        },

在这里插入图片描述

   quarterChart3(item, id) {
          var echartData = [];
          item.forEach((val,dataIndex) => {
            echartData.push({ name: val.name, value: val.num,dataIndex:dataIndex });
          });
          var option;
          let _this = this;
          var dom = document.getElementById(id);
          var ChartDom = new_echarts.init(dom);
          var scale = 1;
          var rich = {
            yellow: {
              color: '#ffc72b',
              fontSize: 16 * scale,
              padding: [5, 4],
              align: 'center'
            },
            total: {
              color: '#ffc72b',
              fontSize: 40 * scale,
              align: 'center'
            },
            white: {
              color: '#fff',
              align: 'center',
              fontSize: 14 * scale,
              padding: [6, 4]
            },
            blue: {
              color: '#49dff0',
              fontSize: 16 * scale,
              align: 'center'
            },
            hr: {
              borderColor: '#0b5263',
              width: '100%',
              borderWidth: 1,
              height: 0
            }
          };
          option = {
            legend: {
              right: 'right',
              top: '33%',
              padding: [0, 120, 0, 0],
              textStyle: {
                color: '#cde3ff',
                fontSize: 16
              },

              // formatter: function (params) {
              //   if (params.length > 12) {
              //     return params.slice(0, 12) + '\n' + params.slice(12);
              //   } else {
              //     return params;
              //   }
              // }
            },
            tooltip: {
              show: true,
              trigger: 'item',
              confine: true,
                  formatter: function (val) {
                  var dotHtml = ``;
                  const tip =
                    `<div class='custom-tooltip-style'> ` + dotHtml + `<div class='custom-tooltip-text'>${val.name}</div>

                    <div class='custom-tooltip-num'>
                        <span class="ym-dialog-screen--echart-tooltip_tow${val.dataIndex}"></span> 
                        <span class="ym_fff_text">   企业数(家)</span>
                        <span  class="ym_blue_text">${val.value}家</span>
                    </div>
                  </div>`;
                  return tip;
              },
              textStyle: {
                rich: {
                  title: {
                    fontSize: 20,
                    lineHeight: 30,
                    color: '#6D7383'
                  },
                  value: {
                    fontSize: 18,
                    lineHeight: 20,
                    color: '#4DA1FF'
                  }
                }
              }
            },
            series: [
              {
                name: '中间背景',
                type: 'pie',
                zlevel: 1,
                silent: true,
                radius: ['40%', '52%'],
                center: ['40%', '50%'],
                hoverAnimation: false,
                color: 'rgba(255,255,255,0.18)',
                // animation:false,
                data: [1],
                labelLine: {
                  normal: {
                    show: false
                  }
                }
              },
              {
                name: '环状背景',
                type: 'pie',
                zlevel: 10,
                silent: true,
                radius: ['0', '30%'],
                center: ['40%', '50%'],
                hoverAnimation: false,
                data: [1],
                labelLine: {
                  normal: {
                    show: false
                  }
                }
              },
              {
                name: '主要数据',
                zlevel: 11,
                type: 'pie',
                radius: ['42%', '50%'],
                center: ['40%', '50%'],
                hoverAnimation: true,
                minAngle:30,
             color: [
              new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                {
                  offset: 0,
                  color: '#67DFD0'
                },
                {
                  offset: 1,
                  color: '#219EFF'
                }
              ]),
              new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                {
                  offset: 0,
                  color: '#2095E4'
                },
                {
                  offset: 1,
                  color: '#0E5CC5'
                }
              ]),
              new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                {
                  offset: 0,
                  color: '#D79FFE'
                },
                {
                  offset: 1,
                  color: '#7E65E0'
                }
              ]),
              new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                {
                  offset: 0,
                  color: '#F74FCD'
                },
                {
                  offset: 1,
                  color: '#A61586'
                }
              ]),
              new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                {
                  offset: 0,
                  color: '#FC7166'
                },
                {
                  offset: 1,
                  color: '#FC5491'
                }
              ]),
              new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                {
                  offset: 0,
                  color: '#F8CB6B'
                },
                {
                  offset: 1,
                  color: '#FE7B29'
                }
              ]),
              new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                {
                  offset: 0,
                  color: '#1DD888'
                },
                {
                  offset: 1,
                  color: '#01D7E3'
                }
              ]),
              new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                {
                  offset: 0,
                  color: '#91DF62'
                },
                {
                  offset: 1,
                  color: '#8BD9A5'
                }
              ]),
              new Echarts.graphic.LinearGradient(0, 0, 1, 0, [
                {
                  offset: 0,
                  color: '#A3BDED'
                },
                {
                  offset: 1,
                  color: '#6991C7'
                }
              ])
            ],
                label: {
                  normal: {
                    formatter: function (params, ticket, callback) {
                      var total = 0;
                      var percent = 0;
                      echartData.forEach(function (value, index, array) {
                        total += value.value;
                      });
                      percent = ((params.value / total) * 100).toFixed(1);
                      return (
                        '{white|' +
                        params.name +
                        '}\n{hr|}\n{yellow|' +
                        params.value +
                        '家}{blue|(' +
                        percent +
                        '%)}'
                      );
                    },
                    padding: [2, -5, 0, -5],
                    rich: rich
                  }
                },
                labelLine: {
                  normal: {
                    length: 70 * scale,
                    length2: 0,
                    lineStyle: {
                      color: '#0b5263'
                    }
                  }
                },
                // 统计数据
                data: echartData
              },
              {
                name: '',
                zlevel: 10,
                type: 'gauge',
                splitNumber: 30, //刻度数量
                min: 0,
                max: 100,
                radius: '65%', //图表尺寸
                center: ['40%', '50%'],
                startAngle: 90,
                endAngle: -269.9999,
                axisLine: {
                  show: false,
                  lineStyle: {
                    width: 0,
                    shadowBlur: 0,
                    color: [
                      [0, '#0dc2fe'],
                      [1, '#0dc2fe']
                    ]
                  }
                },
                axisTick: {
                  show: true,
                  lineStyle: {
                    color: '#106072',
                    width: 2
                  },
                  length: 20,
                  splitNumber: 5
                },
                splitLine: {
                  show: true,
                  length: 20,
                  lineStyle: {
                    color: '#106072'
                  }
                },
                axisLabel: {
                  show: false
                },
                pointer: {
                  //仪表盘指针
                  show: 0
                },
                detail: {
                  shadowBlur: 2,
                  offsetCenter: [0, '0%'], // x, y,单位px
                  textStyle: {
                    // 其余属性默认使用全局文本样式,详见TEXTSTYLE
                    color: 'rgba(255,255,255,0.18)',
                    fontSize: 50
                  },
                  formatter: function (name) {
                    var total = 0; //数据总和
                    var averagePercent; //综合正确率
                    echartData.forEach(function (value, index, array) {
                      total += value.value;
                    });
                    return '{total|合计企业\n\n' + total + '}{unit|家}';
                  },
                  rich: {
                    total: {
                      color: '#fff',
                      fontSize: 30 * scale,
                      align: 'center'
                    },
                    unit: {
                      color: '#fff',
                      fontSize: 25 * scale
                    }
                  }
                },
                data: [echartData[0].name]
              }
            ]
          };
          ChartDom.setOption(option);
          ChartDom.on('click', (params) => {
            this.baseComsumableClickItem();
          });
          window.addEventListener('resize', function () {
            ChartDom.resize();
          });
          //  监听dom变化,自适应echarts
          let chartObserver = new ResizeObserver(() => {
            ChartDom.resize();
          });
          chartObserver.observe(ChartDom.getDom());
        },

在这里插入图片描述

        quarterChart4(item, id) {
          var ym_list = [];
          item.forEach((val,dataIndex) => {
            ym_list.push({ name: val.name, value: val.rate ,num:val.num,dataIndex});
          });
          var option;
          let _this = this;
          var dom = document.getElementById(id);
          var ChartDom = new_echarts.init(dom);
          var data = ym_list;
          var color = [
            ['#D79FFE', '#7E65E0'],
            ['#E7E4A2', '#4BB322'],
            ['#56CFDC ', '#24A3FD '],
            ['#EEBC62', '#EB7C4D'],
            ['#1DD888', '#16D885'],
            ['#767EFF', '#222AC1']
          ];
          var arrName = getArrayValue(data, 'name');
          var arrValue = getArrayValue(data, 'value');
          var sumValue = eval(arrValue.join('+'));
          var objData = array2obj(data, 'name');
          var optionData = getData(data);
          function getArrayValue(array, key) {
            var key = key || 'value';
            var res = [];
            if (array) {
              array.forEach(function (t) {
                res.push(t[key]);
              });
            }
            return res;
          }

          function array2obj(array, key) {
            var resObj = {};
            for (var i = 0; i < array.length; i++) {
              resObj[array[i][key]] = array[i];
            }
            return resObj;
          }

          function getData(data) {
            var res = {
              series: [],
              legend: []
            };
            for (let i = 0; i < data.length; i++) {
              var itemColor = {
                type: 'linear',
                x: 0,
                y: 0,
                x2: 0,
                y2: 1,
                colorStops: [
                  {
                    offset: 0,
                    color: color[i][0] // 0% 处的颜色
                  },
                  {
                    offset: 2 / 3,
                    color: color[i][1] // 100% 处的颜色
                  },
                  {
                    offset: 1,
                    color: color[i][1] // 100% 处的颜色
                  }
                ],
                global: false // 缺省为 false
              };
              res.series.push({
                name: '',
                z: 1,
                type: 'pie',
                clockWise: false, //顺时加载
                hoverAnimation: false, //鼠标移入变大
                radius: [90 - i * 15 + '%', 85 - i * 15 + '%'],
                center: ['50%', '50%'],
                label: {
                  show: false
                },
                itemStyle: {
                  label: {
                    show: false
                  },
                  labelLine: {
                    show: false
                  },
                  normal: {
                    color: itemColor
                  }
                },
                data: [
                  {
                    value: data[i].value,
                    name: data[i].name
                  },
                  {
                    value: 400 / 3 - data[i].value,
                    name: '',
                    itemStyle: {
                      color: 'rgb(11,27,49)',
                      borderWidth: 1
                    },
                    tooltip: {
                      show: true
                    },
                    hoverAnimation: false
                  }
                ]
              });
              res.series.push({
                name: '',
                type: 'pie',
                silent: true,
                z: 0,
                clockWise: false, //顺时加载
                hoverAnimation: false, //鼠标移入变大
                radius: [90 - i * 15 + '%', 85 - i * 15 + '%'],
                center: ['50%', '50%'],
                label: {
                  show: false
                },
                itemStyle: {
                  label: {
                    show: false
                  },
                  labelLine: {
                    show: false
                  },
                  borderWidth: 5
                },
                data: [
                  {
                    value: 7.5,
                    itemStyle: {
                      color: '#fff',
                      borderWidth: 0
                    },
                    tooltip: {
                      show: false
                    },
                    hoverAnimation: false
                  },
                  {
                    value: 2.5,
                    name: '',
                    itemStyle: {
                      color: 'rgba(0,0,0,0)',
                      borderWidth: 0
                    },
                    tooltip: {
                      show: false
                    },
                    hoverAnimation: false
                  }
                ]
              });
            }
            return res;
          }
          optionData.series.push(
            {
              name: '刻度线',
              type: 'gauge',
              startAngle: 90,
              endAngle: 360,
              min: 0,
              max: 100,
              radius: '90%',
              center: ['50%', '50%'],
              title: { show: false },
              detail: { show: false },
              axisLine: { show: false },
              axisTick: { length: 0 },
              splitLine: {
                length: '100%',
                show: true,
                lineStyle: {
                  color: 'rgba(255, 255, 255, 0.2)',
                  width: 1,
                  type: 'solid'
                }
              },
              axisLabel: { show: false },
              pointer: { show: false },
              data: [{ value: 0 }]
            },
            {
              name: '刻度值',
              type: 'gauge',
              startAngle: 90,
              endAngle: 360,
              min: 0,
              max: 100,
              radius: '90%',
              center: ['50%', '50%'],
              title: { show: false },
              detail: { show: false },
              axisLine: { show: false },
              axisTick: { length: 0 },
              splitLine: { show: false, length: -23 },
              axisLabel: {
                color: '#fff',
                fontSize: 12,
                verticalAlign: 'top',
                align: 'left',
                margin: 0
              },
              pointer: { show: false },
              data: [{ value: 0 }]
            }
          );

          option = {
            legend: [
              {
                show: true,
                top: '5%',
                left: '50%',
                data: arrName,
                width: 100,
                itemGap: 30,
                itemWidth: 0,
                icon: 'none',
                formatter: function (name) {
                  return (
                    '{title|' +
                    name +
                    '}{value| ' +
                    (objData[name].value ) +  '%} '
                  );
                },
                textStyle: {
                  rich: {
                    title: {
                      fontSize: 16,
                      color: '#fff'
                    },
                    value: {
                      fontSize: 16,
                      color: '#009afe'
                    }
                  }
                }
              }
            ],
            tooltip: {
              show: true,
              trigger: 'item',
              confine: true,
              // formatter: function (param) {
              //   return (
              //     param.name +
              //     ' : ' +
              //     param.value +
              //     ' ( ' +
              //     ((objData[param.name].value / sumValue) * 100).toFixed(2) +
              //     '% )'
              //   );
              // },
              
              formatter: function (val) {
                var dotHtml = ``;
                const tip =
                  `<div class='custom-tooltip-style'> ` + dotHtml + `<div class='custom-tooltip-text'>${val.name}</div>

                  <div class='custom-tooltip-num'>
                      <span class="ym-dialog-screen--echart-tooltip_tow${val.dataIndex}"></span> 
                      <span class="ym_fff_text">   企业数(家)</span>
                      <span  class="ym_blue_text">${ym_list[val.dataIndex].num }家</span>
                  </div> 
                  <div class='custom-tooltip-num'>
                      <span class="ym_fff_text"> 占比</span>
                      <span  class="ym_blue_text">${(objData[val.name].value / sumValue * 100).toFixed(1)}%</span>
                  </div> 
                </div>`;
                return tip;
              },
              textStyle: {
                rich: {
                  title: {
                    fontSize: 20,
                    lineHeight: 30,
                    color: '#6D7383'
                  },
                  value: {
                    fontSize: 18,
                    lineHeight: 20,
                    color: '#4DA1FF'
                  }
                }
              }
            },

            series: optionData.series
          };
          ChartDom.setOption(option);
          ChartDom.on('click', (params) => {
            this.baseComsumableClickItem();
          });
          window.addEventListener('resize', function () {
            ChartDom.resize();
          });
          //  监听dom变化,自适应echarts
          let chartObserver = new ResizeObserver(() => {
            ChartDom.resize();
          });
          chartObserver.observe(ChartDom.getDom());
        },
#order_warn .custom-tooltip-style {
  padding: 12px;
  border: 1px solid #017EFB;
  border-radius: 4px 4px 4px 4px;
  background: rgba(21, 49, 91, 0.8);
  box-shadow: inset 0px 0px 11px 0px #00579F;
}
#order_warn .custom-tooltip-text {
  margin-right: 16px;
  margin-left: 8px;
  color: #fff;
  font-family: Microsoft YaHei UI-Regular, Microsoft YaHei UI;
  font-size: 16px;
  font-weight: 400;
}
#order_warn .custom-tooltip-num {
  color: #00EAFF;
  font-family: Microsoft YaHei-Regular, Microsoft YaHei;
  font-size: 16px;
  font-weight: 400;
}
#order_warn .ym_fff_text {
  display: block;
  color: #CDE3FF;
  font-size: 14px;
}

#order_warn .ym_blue_text {
  display: block;
  margin-left: auto;
  padding-left: 20px;
  color: #00EAFF;
  font-size: 14px;
}

#order_warn .ym-dialog-screen--echart-tooltip_tow_null {
  display: inline-block;
  width: 10px;
  height: 10px;
  opacity: 1;
  border-radius: 50%;
}

#order_warn .ym-dialog-screen--echart-tooltip_tow0 {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-right: 5px;
  opacity: 1;
  border-radius: 50%;
  background: linear-gradient(90deg, #67DFD0 0%, #219EFF 100%);
}

#order_warn .ym-dialog-screen--echart-tooltip_tow1 {
  display: inline-block;

  width: 10px;
  height: 10px;
  margin-right: 5px;
  opacity: 1;
  border-radius: 50%;
  background: linear-gradient(90deg, #2095E4 0%, #0E5CC5 100%);
}

#order_warn .ym-dialog-screen--echart-tooltip_tow2 {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-right: 5px;
  opacity: 1;
  border-radius: 50%;
  background: linear-gradient(90deg, #D79FFE 0%, #7E65E0 100%);
}

#order_warn .ym-dialog-screen--echart-tooltip_tow3 {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-right: 5px;
  opacity: 1;
  border-radius: 50%;
  background: linear-gradient(90deg, #F74FCD 0%, #A61586 100%);
}

#order_warn .ym-dialog-screen--echart-tooltip_tow4 {
  display: inline-block;

  width: 10px;
  height: 10px;
  margin-right: 5px;
  opacity: 1;
  border-radius: 50%;
  background: linear-gradient(90deg, #FC7166 0%, #FC5491 100%);
}

#order_warn .ym-dialog-screen--echart-tooltip_tow5 {
  display: inline-block;

  width: 10px;
  height: 10px;
  margin-right: 5px;
  opacity: 1;
  border-radius: 50%;
  background: linear-gradient(90deg, #F8CB6B 0%, #FE7B29 100%);
}

#order_warn .ym-dialog-screen--echart-tooltip_tow6 {
  display: inline-block;

  width: 10px;
  height: 10px;
  margin-right: 5px;
  opacity: 1;
  border-radius: 50%;
  background: linear-gradient(90deg, #1DD888 0%, #01D7E3 100%);
}

#order_warn .ym-dialog-screen--echart-tooltip_tow7 {
  display: inline-block;

  width: 10px;
  height: 10px;
  margin-right: 5px;
  opacity: 1;
  border-radius: 50%;
  background: linear-gradient(90deg, #91DF62 0%, #8BD9A5 100%);
}

#order_warn .ym-dialog-screen--echart-tooltip_tow8 {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-right: 5px;
  opacity: 1;
  border-radius: 50%;
  background: linear-gradient(90deg, #A3BDED 0%, #6991C7 100%);
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值