Echarts光圈有光晕,文字在指示线的上方

**

效果图:

**
在这里插入图片描述

代码:

注意:光圈发光有光晕,文字在指示线的上方

  let _that = this
  var chartDom = document.getElementById('course')
  var myChart = echarts.init(chartDom)
  var option
  var img =
      ""
  let arrD = []
  for (const key in _that.numX) {
    if (Object.hasOwnProperty.call(_that.numX, key)) {
      const element = _that.numX[key]
      arrD.push({
        name: key,
        value: element,
      })
    }
  }
  let xname = []
  this.echartsList.forEach(r=>{
    xname.push(r.name)
  })
  var trafficWay = this.echartsList || arrD
  var data = []
  var color = [
    "#00ffff",
    "#00cfff",
    "#006ced",
    "#ffe000",
    "#ffa800",
    "#ff5b00",
    "#ff3000",
  ]
  for (var i = 0; i < trafficWay.length; i++) {
    data.push(
        {
          value: trafficWay[i].value,
          name: trafficWay[i].name,
          itemStyle: {
            normal: {
              borderWidth: 5,
              shadowBlur: 20,
              borderColor: color[i],
              shadowColor: color[i],
            },
          },
        },
        {
          value: 2,
          name: "",
          itemStyle: {
            normal: {
              label: {
                show: false,
              },
              labelLine: {
                show: false,
              },
              color: "rgba(0, 0, 0, 0)",
              borderColor: "rgba(0, 0, 0, 0)",
              borderWidth: 0,
            },
          },
        }
    )
  }
  // console.log(data)
  var seriesOption = [
    {
      type: "pie",
      // clockWise: false,
      radius: [105, 109],
      // hoverAnimation: false,
      label:{
        color: "#ddd",
        alignTo: 'edge',
        edgeDistance: 10,
        minMargin: 5,
        lineHeight: 25,
        formatter: function (params) {
          if (params.name !== "") {
            return (
                params.name +
                ":" + params.value + '\n'
            )
          } else {
            return ""
          }
        },
        padding:[0,10]
      },
      labelLine: {
        length: 25,
        length2: 0,
        maxSurfaceAngle: 80
      },
      itemStyle: {
        borderColor: '#fff',
        borderWidth: 1
      },
      labelLayout: (params) => {
        const isLeft = params.labelRect.x < myChart.getWidth() / 2;
        const points = params.labelLinePoints;
        // Update the end point.
        points[2][0] = isLeft
            ? params.labelRect.x
            : params.labelRect.x + params.labelRect.width;
        return {
          labelLinePoints: points
        };
      },
      data: data,
    },
  ]
  option = {
    backgroundColor: "rgba(255,255,255,0)",
    color: color,
    title: [
      {
        text: this.title,
        top: "50%",
        textAlign: "center",
        left: "49%",
        textStyle: {
          color: "#fff",
          fontSize: 22,
          fontWeight: "400",
        },
      },
      {
        text: this.allCount,
        top: "40%",
        textAlign: "center",
        left: "49%",
        textStyle: {
          color: "#1FD6F0",
          fontSize: 22,
          fontWeight: "400",
        },
      }
    ],
    graphic: {
      elements: [
        {
          type: "image",
          z: 3,
          style: {
            image: img,
            width: 178,
            height: 178,
          },
          left: "center",
          top: "center",
          position: [100, 100],
        },
      ],
    },
    tooltip: {
      show: false,
    },
    legend: {
      show: false,
      icon: "circle",
      orient: "horizontal",
      // x: 'left',
      data: xname,
      right: 10,
      bottom: 0,
      align: "right",
      textStyle: {
        color: "#fff",
      },
      itemGap: 10,
    },
    toolbox: {
      show: false,
    },
    series: seriesOption,
  }

  option && myChart.setOption(option)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值