echarts-扇形图-渐变色

效果图:

 

 

  <div style="width: 100%; height: 100%" id="energyRightBottom"></div>

这个地方我采用的是props传值,也可以直接写到方法里面

props: {
    dataOne: {
      type: Number,
      default() {
        return 50;
      },
    },
    dataTwo: {
      type: Number,
      default() {
        return 50;
      },
    },
    dataName: {
      type: String,
      default() {
        return "总数量";
      },
    },
  },

方法:

    // 自适应字体大小变化
    WidthAdaptive(res) {
      var windth = window.innerWidth;
      let fontSize = windth / 1920;
      return fontSize * res;
    },
    drawLine() {
      // 基于准备好的dom,初始化echarts实例
      let myChart = this.$echarts.init(
        document.getElementById("energyRightBottom")
      );
      let dolitData = generateData(100, 25, 20, "rgba(255, 221, 1, 1)");
      let bgColor = "transparent";
      let title = this.dataName;
      let color = ["rgb(255,210,0)", "rgb(20,171,173)"];
      let echartData = [
        {
          name: "在线门禁设备",
          value: this.dataTwo,
          itemStyle: {
            normal: {
              color: {
                // x: 1,
                // y: 0,
                // x2: 1,
                // y2: 1,
                type: "linear",
                global: false,
                colorStops: [
                  {
                    offset: 1,
                    color: "rgba(20,171,173,1)",
                  },
                  {
                    offset: 0,
                    color: "rgba(20,171,173,0)",
                  },
                ],
              },
            },
          },
          label: {
            normal: {
              formatter: (params) => {
                console.log(params.data.itemStyle.color.colorStops[0].color);
                return "{value|" + baifenbi(formatNumber(params.value)) + "}";
              },
              padding: -30,
              height: 30,
              rich: {
                icon: {
                  fontSize: this.WidthAdaptive(14),
                },

                value: {
                  fontSize: this.WidthAdaptive(14),
                  fontWeight: "bold",
                  color: "rgba(20,171,173,1)",
                },
              },
            },
          },
        },
        {
          name: "离线门禁设备",
          value: this.dataOne,
          itemStyle: {
            normal: {
              color: {
                // x: 1,
                // y: 0,
                // x2: 1,
                // y2: 1,
                type: "linear",
                global: false,
                colorStops: [
                  {
                    offset: 1,
                    color: "rgba(255,210,0,0)",
                  },
                  {
                    offset: 0,
                    color: "rgba(255,210,0,1)",
                  },
                ],
              },
            },
          },
          label: {
            normal: {
              formatter: (params) => {
                console.log(params.data.itemStyle.color.colorStops[0].color);
                return "{value|" + baifenbi(formatNumber(params.value)) + "}";
              },
              padding: -30,
              height: 30,
              rich: {
                icon: {
                  fontSize: this.WidthAdaptive(14),
                },

                value: {
                  fontSize: this.WidthAdaptive(14),
                  fontWeight: "bold",
                  color: "rgba(255,210,0,1)",
                },
              },
            },
          },
        },
      ];
      let formatNumber = function (num) {
        return num;
      };
      let total = echartData.reduce((a, b) => {
        return a + b.value * 1;
      }, 0);
      let baifenbi = function (num) {
        console.log(num / total);
        let data = num / total;
        data = (data * 100).toFixed(0);
        return data + "%";
      };
      let baseDataPie = [],
        baseDataWrap = [];

      for (let i = 0; i < echartData.length; i++) {
        baseDataPie.push({
          value: echartData[i].value * 20,
          name: echartData[i].name,
          itemStyle: {
            normal: {
              borderWidth: this.WidthAdaptive(20),
            },
          },
        });
        baseDataWrap.push(
          {
            value: echartData[i].value * 20,
            name: echartData[i].name,
            itemStyle: {
              normal: {
                color: color[i],
                borderWidth: this.WidthAdaptive(5),
              },
            },
          },
          {
            value: 20,
            name: "",
            itemStyle: {
              normal: {
                color: "transparent",
                borderWidth: this.WidthAdaptive(5),
                borderColor: "transparent",
              },
            },
          }
        );
      }

      let dataPie = [{}, {}, {}, {}, {}, {}];

      let baseDataPie1 = [],
        baseDataWrap1 = [];
      for (let i = 0; i < dataPie.length; i++) {
        baseDataPie1.push({
          value: 1,
          name: 1,
          itemStyle: {
            normal: {
              borderWidth: this.WidthAdaptive(20),
            },
          },
        });
        baseDataWrap1.push(
          {
            value: 10,
            name: 1,
            itemStyle: {
              normal: {
                color: "#0c0f15",
                borderWidth: this.WidthAdaptive(1),
                borderColor: "#0c0f15",
              },
            },
          },
          {
            value: 20,
            name: "",
            itemStyle: {
              normal: {
                color: "transparent",
                borderWidth: this.WidthAdaptive(5),
                borderColor: "transparent",
              },
            },
          }
        );
      }
      let option = {
        backgroundColor: bgColor,
        color: color,
        // tooltip: {
        //     trigger: 'item'
        // },
        title: [
          {
            text: "\n{val|" + formatNumber(total) + "}\n{name|" + title + "}",
            top: "center",
            left: "center",
            textStyle: {
              rich: {
                name: {
                  fontSize: this.WidthAdaptive(8),
                  fontWeight: "400",
                  color: "#fff",
                  padding: [6, 0],
                },
                val: {
                  fontSize: this.WidthAdaptive(20),
                  fontWeight: 400,
                  color: "#FFDD01",
                  fontFamily: "zcoolqingkehuangyouti",
                },
              },
            },
          },
        ],
        graphic: {
          elements: [
            {
              type: "image",
              z: 4,
              style: {
                image:
                  "",
                width: this.WidthAdaptive(120),
                height: this.WidthAdaptive(120),
              },
              left: "center",
              top: "center",
              silent: true,
            },
          ],
        },
        series: [
          {
            type: "pie",
            radius: ["45%", "60%"],
            center: ["50%", "50%"],
            data: echartData,
            hoverAnimation: false,
            itemStyle: {
              normal: {
                borderColor: bgColor,
                borderWidth: this.WidthAdaptive(2),
              },
            },
            labelLine: {
              length: this.WidthAdaptive(25),
              length2: this.WidthAdaptive(25),
            },
          },
          {
            name: "不动外圆",
            type: "pie",
            zlevel: 4,
            silent: true,
            radius: ["67%", "66%"],
            label: {
              normal: {
                show: false,
              },
            },
            labelLine: {
              normal: {
                show: false,
              },
            },
            data: dolitData,
          },
        ],
      };
      window.onresize = function () {
        myChart.resize();
      };
      function generateData(totalNum, bigvalue, smallvalue, color) {
        let dataArr = [];
        for (var i = 0; i < totalNum; i++) {
          if (i % 2 === 0) {
            dataArr.push({
              name: (i + 1).toString(),
              value: bigvalue,
              itemStyle: {
                normal: {
                  color: color,
                  borderWidth: 0,
                },
              },
            });
          } else {
            dataArr.push({
              name: (i + 1).toString(),
              value: smallvalue,
              itemStyle: {
                normal: {
                  color: "rgba(0,0,0,0)",
                  borderWidth: 0,
                },
              },
            });
          }
        }
        return dataArr;
      }
      myChart.setOption(option);
    },

 

posted @ 2021-10-09 10:51  大云之下  阅读(2969)  评论(0编辑  收藏  举报
大云之下