echarts常见的一些大屏示意图及配置项【好看】

news2025/1/21 18:42:05

双立体柱状图

示意图:
在这里插入图片描述

配置:

initData() {
            let sideData = [220, 182, 191, 234, 290, 330]
            let sideData1 = [100, 110, 120, 134, 190, 230]
            let nameList = ['结算能力数', '结算金额']
            let yAxisData = ['(金额/亿元)', '(能力数/个)']

            let xData = ['1', '2', '3', '4', '5', '6']

            this.initEchartsDom(sideData, sideData1, xData, nameList, yAxisData)

        },

        /**
         * 
         * @param {*} sideData:蓝色柱状图的数据 
         * @param {*} sideData1 :绿色柱状图的数据
         * @param {*} xData 横坐标数据
         * @param {*} nameList :柱状图的名称对应着图例,[蓝色的,绿色的]
         * @param {*} yAxisData :yAxis配置,如果length>1,则设置两个纵坐标,并且第二个柱状图yAxisIndex为1
         */
        initEchartsDom(sideData, sideData1, xData, nameList, yAxisData) {
            const name1 = nameList[0];
            const name2 = nameList[1];
            let x = xData;

            // 通用的yAxis属性
            let yAxisCommonSetting = {
                nameTextStyle: {
                    color: "rgba(216,240,255,0.6)",
                    fontSize: 10
                },
                type: 'value',
                axisLabel: {
                    formatter: "{value}",
                    textStyle: {
                        color: "rgba(216,240,255,0.6)",
                        fontSize: 10

                    }
                },
            }

           //根据yAxisData配置yAxis
            let yAxis = [{
                name: yAxisData[0],
                ...yAxisCommonSetting,
                splitLine: {
                    show: true,    // 是否显示分隔线。默认数值轴显示,类目轴不显示
                    lineStyle: {
                        type: 'dashed',
                        color: 'rgba(208,222,238,0.20)',
                        width: 1 // 设置分割线的粗细为2
                    }
                }
            }]
            if (yAxisData.length > 1) {
                yAxis.push({
                    name: yAxisData[1],
                    ...yAxisCommonSetting,
                    position: "right",
                    splitLine: {
                        show: false
                    },
                })
            }


            let option = {
                legend: {
                    position: "top",
                    show: true,
                    align: "right",
                    itemWidth: 12,
                    itemHeight: 8,
                    textStyle: {
                        color: '#C0E7FF',
                        fontSize: 10
                    },
                },
                grid: {
                    top: 35,
                    left: 20,
                    right: 20,
                    bottom: 10,
                    containLabel: true
                },
                toolbox: {
                    show: true,
                },
                calculable: true,
                xAxis: [
                    {
                        type: 'category',
                        axisLine: {
                            show: true,
                            lineStyle: {
                                type: 'solid',
                                color: '#2a3853',
                                width: 2
                            }
                        },
                        axisTick: {
                            show: false
                        },
                        data: x,
                        axisLabel: {
                            color: 'rgba(216,240,255,0.6)',
                            fontSize: 10,
                            rotate: 0,
                            margin: 10,
                            clickable: true,
                            formatter: function (value) {
                                if (value.length > 8) {
                                    // 文本超长后换行
                                    return value.substr(0, 8) + '..'
                                } else {
                                    return value
                                }
                            },
                        }
                    }
                ],
                yAxis: yAxis,
                series: [
                    {
                        name: name1,//左侧
                        tooltip: {
                            show: false
                        },
                        type: 'bar',
                        barWidth: 10,
                        itemStyle: {
                            normal: {
                                color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
                                    offset: 0,
                                    color: "rgba(26,102,255,0)" // 0% 处的颜色
                                }, {
                                    offset: 1,
                                    color: "rgba(30,147,188,1)", // 100% 处的颜色
                                }], false)
                            }
                        },
                        data: sideData,
                        barGap: 0,
                    },
                    {
                        name: name1,
                        type: 'bar',
                        barWidth: 10,
                        itemStyle: {
                            normal: {
                                color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
                                    offset: 0,
                                    color: "rgba(51,173,234,0)" // 0% 处的颜色
                                }, {
                                    offset: 1,
                                    color: "rgba(7,195,237,0.8)", // 100% 处的颜色
                                }], false)
                            }
                        },
                        barGap: 0,
                        data: sideData,
                        label: {
                            show: false,
                            position: 'top',
                            textStyle: {
                                color: 'white',
                                fontSize: 10
                            }
                        }
                    }, {
                        data: sideData,
                        type: "pictorialBar",
                        barMaxWidth: "20",
                        symbolPosition: "end",
                        symbol: "diamond",
                        symbolOffset: ['-13', "-6"],
                        symbolSize: [21, 12],
                        zlevel: 2,
                        itemStyle: {
                            color: '#3ed5f7' // 顶部方块的颜色
                        },
                    },
                    // 中间跟背景颜色一样的一个柱子,将两个立体柱子分开
                    {
                        name: name1,
                        type: 'bar',
                        barWidth: 6,
                        tooltip: {
                            show: false
                        },
                        itemStyle: {
                            normal: {
                                color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
                                    offset: 0,
                                    color: "rgba(0,30,61, 0)" // 0% 处的颜色
                                }, {
                                    offset: 1,
                                    color: "rgba(0,30,61, 0)", // 100% 处的颜色
                                    //opacity:0.5
                                }], false)
                            }
                        },
                        barGap: 0,
                        data: sideData,
                        label: {
                            show: false,
                            position: 'top',
                            textStyle: {
                                color: 'white',
                                fontSize: 10
                            }
                        }
                    },

                    // 第二个柱状图
                    {
                        name: name2,
                        yAxisIndex: 1,
                        tooltip: {
                            show: false
                        },
                        type: 'bar',
                        barWidth: 10,
                        itemStyle: {
                            normal: {
                                color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
                                    offset: 0,
                                    color: "rgba(26,102,255,0)" // 0% 处的颜色
                                }, {
                                    offset: 1,
                                    color: "rgba(32,167,24,1)", // 100% 处的颜色
                                }], false)
                            }
                        },
                        data: sideData1,
                        barGap: 0,

                    },
                    {
                        name: name2,
                        type: 'bar',
                        barWidth: 10,
                        yAxisIndex: 1,
                        itemStyle: {
                            normal: {
                                color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
                                    offset: 0,
                                    color: "rgba(51,173,234,0)" // 0% 处的颜色
                                }, {
                                    offset: 1,
                                    color: "rgba(24,203,125,0.8)", // 100% 处的颜色
                                }], false)
                            }
                        },
                        barGap: 0,
                        data: sideData1,
                        label: {
                            show: false,
                            position: 'top',
                            textStyle: {
                                color: 'white',
                                fontSize: 10
                            }
                        }
                    },
                    // 顶部方块
                    {
                        data: sideData1,
                        type: "pictorialBar",
                        barMaxWidth: "20",
                        yAxisIndex: 1,
                        symbolPosition: "end",
                        symbol: "diamond",
                        symbolOffset: ['13', "-6"],
                        symbolSize: [21, 12],
                        zlevel: 2,
                        itemStyle: {
                            color: '#73F539' // 顶部方块的颜色
                        },
                    },
                ]
            };


            this.initEchart(this.$refs.echartsDom, option, 'echartsDom');

        },
        // 初始化图表 
        initEchart(ref, option, name) {
            const myChart = echarts.init(ref);
            myChart.setOption(option, true);
            this[name] = myChart;
        }

立体圆柱形柱状图及折线图

示意图:
在这里插入图片描述
配置:

// 左侧的图
    initOrderingTrend() {
      let xAxisData = ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月']
      let seriesData = [150, 140, 150, 270, 230, 250, 130, 110, 230, 220, 260, 240]
      let seriesData1 = [150, 180, 190, 170, 160, 200, 240, 250, 210, 160, 180, 200]
      let seriesData2 = [40, 45, 47, 48, 62, 70, 82, 78, 70, 68, 62, 69]
      let seriesName = ['每月能力订单数', '年度累计订单数', '同比增长率']//折线图名称,柱状图名称,橘色折线图名称
      let yAxisName = ['(订单数/个)', '(增长率/%)']//两侧纵坐标的名称


      let option = this.getBarOption(xAxisData, seriesData, seriesData1, seriesData2, seriesName, yAxisName);
      this.initEchart(this.$refs.orderingTrend, option, 'orderingTrend');
    },


    //获取圆柱形柱状图option
    getBarOption(xAxisData, seriesData, seriesData1, seriesData2, seriesName, yAxisName) {
      return {
        xAxis: {
          type: 'category',
          data: xAxisData,
          axisLine: {
            show: false
          },
          axisTick: {
            show: false
          },
          triggerEvent: true,
          axisLabel: {
            color: '#B8D3F1',
            fontSize: 10,
            rotate: 0,
            margin: 10,
            clickable: true,
            formatter: function (value) {
              if (value.length > 8) {
                // 文本超长后换行
                return value.substr(0, 8) + '..'
              } else {
                return value
              }
            },
          }
        },

        grid: {
          top: 35,
          left: 20,
          right: 20,
          bottom: 10,
          containLabel: true
        },
        legend: {
          show: true,
          align: "right",
          itemWidth: 12,
          itemHeight: 8,
          textStyle: {
            color: '#C0E7FF',
            fontSize: 10
          },
        },
        yAxis: [
          {
            type: "value",
            name: yAxisName[0],
            min: 0,
            position: "left",

            axisLabel: {
              formatter: "{value}",
              textStyle: {
                color: "#B8D3F1",
                fontSize: 10
              }
            },
            nameTextStyle: {
              color: "#B8D3F1",
              fontSize: 10,
            },
            // max: maxY,
            axisTick: {
              show: false,
            },
            splitLine: {
              show: false,
            },
          },
          {
            type: "value",
            max: 100,
            name: yAxisName[1],
            min: 0,
            nameTextStyle: {
              color: "#B8D3F1",
              fontSize: 10
            },
            axisTick: {
              show: false,
            },
            position: "right",
            axisLabel: {
              formatter: "{value}",
              textStyle: {
                color: "#B8D3F1",
                fontSize: 10

              }
            },
            splitLine: {
              show: true,    // 是否显示分隔线。默认数值轴显示,类目轴不显示
              lineStyle: {
                type: 'solid',
                color: 'rgba(87,206,234,0.1)',
                width: 1 // 设置分割线的粗细为2
              }
            }
          },
        ],


        tooltip: {
          trigger: 'axis',
          renderMode: "html",
          appendToBody: true,
          className: 'custom-tooltip',

          axisPointer: {
            // Use axis to trigger tooltip
            type: 'shadow' // 'shadow' as default; can also be 'line' or 'shadow'
          },
          formatter: function (params) {
            var relVal = '';
            for (var i = 0, l = params.length; i < l; i++) {
              if (!params[i].seriesName.includes('series')) relVal += params[i].marker + params[i].seriesName + "  " + params[i].value + '<br/>'
            }
            return relVal
          }

        },

        series: [
          // 折线图1
          {
            name: seriesName[0],
            type: "line",
            symbolSize: 5,
            symbol: "circle",
            itemStyle: {
              color: "#00F6FF",
            },
            data: seriesData1
          },
          // 圆形柱状图
          {
            name: seriesName[1],
            data: seriesData,
            type: 'bar',
            barWidth: 20,
            // 柱形颜色渐变
            color: {
              type: 'linear',
              x: 0,
              y: 0,
              x2: 0,
              y2: 1,
              colorStops: [
                {
                  offset: 0,
                  color: '#0E60B2'
                },

                {
                  offset: 1,
                  color: '#1FAEDE'
                }
              ],
              global: false
            },
            itemStyle: {
              normal: {
                barBorderRadius: 10,
                label: {
                  show: false,
                  position: 'top',
                  textStyle: {
                    color: '#FFFFFF',
                    fontSize: 12
                  },
                  formatter: function (params) {
                    return params.value
                  }
                }
              }
            }
          },
          {
            color: '#17E1FF',
            type: 'pictorialBar',
            symbol: 'circle',
            symbolSize: ['20', '10'],
            symbolPosition: 'end',
            symbolOffset: [0, 0],
            data: seriesData,
            z: 3,
          }, {
            color: '#1E80E4',
            type: 'pictorialBar',
            symbol: 'circle',
            symbolSize: ['20', '10'],
            symbolPosition: 'start', // 图形边缘与柱子结束的地方内切。
            symbolOffset: [0, 0], // 椭圆水平偏移,垂直偏移. 因为不一定正好盖住柱形,所以可能要移动一点点
            data: seriesData, // 数据要跟主体柱形一致
            z: 3, // 数值越大,层级越高,可以盖住下面的图形
          },


          // 折线图2

          {
            name: seriesName[2],
            type: "line",
            symbolSize: 5,
            yAxisIndex: 1,
            symbol: "circle",
            itemStyle: {
              color: "#EC9C45",
            },
            data: seriesData2
          },
        ]
      };
    },

渐变柱状图

示意图:
在这里插入图片描述
配置:

 const echartDom = document.getElementById("dataQuality")
      const myChart = echarts.init(echartDom)
      let option = {
        grid: {
          left: "0%",
          top: "0%",
          right: "2%",
          bottom: "0%",
          containLabel: true,
        },
        xAxis: {
          type: "value",
          show: true,
          position: "bottom",
          axisTick: {
            show: false,
          },
          axisLine: {
            show: true,
            lineStyle: {
              color: "#64718a",
            },
          },
          axisLabel: {
            color: "#C0E7FF",
          },
          splitLine: {
            show: true,
            lineStyle: {
              type: "dashed",
              color: "#3a4761"
            }
          },
        },
        yAxis: [
          {
            type: "category",
            axisTick: {
              show: false,
              alignWithLabel: false,
              length: 5,
            },
            splitLine: {
              //网格线
              show: false,
            },
            axisLabel: {
              color: "#C0E7FF",
            },
            inverse: "false",
            axisLine: {
              show: true,
              lineStyle: {
                color: "#64718a",
              },
            },
            data: ["一致性", "调整性", "波动性", "及时性"],
          },
        ],
        series: [
          {
            name: "",
            type: "bar",
            itemStyle: {
              normal: {
                barBorderRadius: 30,
                // color: new echarts.graphic.LinearGradient(
                //   0, 0, 0, 1, [{
                //     offset: 0,
                //     color: "rgba(0, 219, 150, 0.33)",
                //   },
                //   {
                //     offset: 0.95,
                //     color: "rgba(0, 219, 150, 1)",
                //   },
                //   {
                //     offset: 1,
                //     color: "#fff",
                //   }
                // ]
                // ),

                color: {
                  colorStops: [
                    {
                      offset: 0,
                      color: "rgba(0, 219, 150, 0.33)",
                    },
                    {
                      offset: 0.95,
                      color: "rgba(0, 219, 150, 1)",
                    },
                    {
                      offset: 1,
                      color: "#fff",//最后尖尖的白色
                    }
                  ]
                }

              },
              barBorderRadius: 70,
              borderWidth: 0,
              borderColor: "#333",
            },
            barGap: "0%",
            barCategoryGap: "50%",
            data: [55, 64, 32, 62],
          },
        ],
      };

      option && myChart.setOption(option)

      //随着屏幕大小调节图表
      window.addEventListener("resize", () => {
        myChart.resize();
      });

类似电池的柱状图进度条

示意图:
在这里插入图片描述
配置:

 // 敏感数据分布(驻)和数据访问量统计公用
    initCommon(idName, xData, yData, maxY) {
      const echartDom = document.getElementById(idName)
      const myChart = echarts.init(echartDom)
      let option = {
        tooltip: {
          trigger: "axis",
          axisPointer: {
            type: "shadow",
          },
          formatter: function (item) {
            return (
              item[0].axisValueLabel +
              "<br />" +
              item[0].seriesName +
              ": " +
              item[0].data
            );
          },
        },
        grid: {
          top: 30,
          right: 0,
          left: 30,
          bottom: 20,
        },
        xAxis: [
          {
            data: xData,
            axisLine: {
              lineStyle: {
                color: "#687c99",
              },
            },
            axisTick: {
              show: false,
            },
            axisLabel: {
              color: "#C0E7FF",
              fontSize: 12,
              interval: 0,
            },
          }
        ],
        yAxis: [
          {
            name: "数量",
            nameTextStyle: {
              color: "#C0E7FF"
            },
            max: maxY,
            axisTick: {
              show: false,
            },
            splitLine: {
              show: true,
              lineStyle: {
                type: "dashed",
                color: "#182450"
              }
            },
            axisLabel: {
              textStyle: {
                color: "#C0E7FF",
              },

            },
          },
        ],
        series: [
          {
            name: "",
            type: "bar",
            barWidth: 25,
            itemStyle: {
              color: "rgba(16, 32, 68,0.6)",
              borderWidth: 0,
              borderColor: "#10bffc",
              padding: 0,
            },
            label: {
              show: false,
            },
            z: 10,
            data: new Array(yData.length).fill(maxY),
          },
          {
            name: "数量",
            type: "pictorialBar",
            symbol: "rect",
            itemStyle: {
              color: "rgba(0, 133, 247, 1)",
            },
            symbolRepeat: true,
            symbolSize: [19, 4],
            symbolMargin: 2,
            symbolPosition: "start",
            z: 20,
            data: yData,

            label: {
              normal: {
                show: true,
                position: "top",
                distance: '15',
                verticalAlign: "top",
                color: "rgba(192, 231, 255, 1)"
              },
            },
          }
        ],
      }


      option && myChart.setOption(option)

      //随着屏幕大小调节图表
      window.addEventListener("resize", () => {
        myChart.resize();
      });

    },

渐变折线图

效果图:
在这里插入图片描述
配置:

 const echartDom = document.getElementById("projectOperation")
      const myChart = echarts.init(echartDom)

      let color = ["#0090FF", "#36CE9E", "#FFC005", "#FF515A", "#8B5CFF", "#00CA69"];
      let echartData = [
        {
          name: "23-06",
          value2: 43,
        },
        {
          name: "23-07",
          value2: 20,
        },
        {
          name: "23-08",
          value2: 60,
        },
        {
          name: "23-09",
          value2: 40,
        },
        {
          name: "23-10",
          value2: 17,
        },
        {
          name: "23-11",
          value2: 72,
        },
        {
          name: "23-12",
          value2: 45,
        }
      ];

      let xAxisData = echartData.map((v) => v.name);
      let yAxisData2 = echartData.map((v) => v.value2);
      const hexToRgba = (hex, opacity) => {
        let rgbaColor = "";
        let reg = /^#[\da-f]{6}$/i;
        if (reg.test(hex)) {
          rgbaColor = `rgba(${parseInt("0x" + hex.slice(1, 3))},${parseInt(
            "0x" + hex.slice(3, 5)
          )},${parseInt("0x" + hex.slice(5, 7))},${opacity})`;
        }
        return rgbaColor;
      };

      let option = {
        color: color,
        tooltip: { trigger: "axis" },
        grid: {
          top: 30,
          left: '7%',
          bottom: 20
        },
        xAxis: [
          {
            type: "category",
            boundaryGap: false,
            axisLabel: {
              formatter: "{value}",
              textStyle: {
                color: "rgba(192, 231, 255, 1)",
              },
            },
            splitLine: {
              show: false,
            },
            axisLine: {
              lineStyle: {
                color: "#34405a",
              },
            },
            data: xAxisData,
            axisTick: {
              show: false,
            },
          },
        ],
        yAxis: [
          {

            type: "value",
            name: "访问量(万次)",
            max: 80,
            min: 0,
            splitNumber: 5,
            nameTextStyle: {
              color: "#C0E7FF",
              show: true,
              fontSize: '12',
              align: 'left'
            },
            axisLabel: {
              textStyle: {
                color: "rgba(192, 231, 255, 1)",
              },
            },
            splitLine: {
              lineStyle: {
                type: "dashed",
                color: "#3a4761",
              },
            },
            axisLine: {
              lineStyle: {
                color: "#34405a",
              },
            },
            axisTick: {
              show: false,
            },
          },
        ],
        series: [
          {
            name: "",
            type: "line",
            smooth: true,
            // showSymbol: false,
            symbolSize: 8,
            zlevel: 3,
            lineStyle: {
              normal: {
                color: color[1],
                // shadowBlur: 3,
                // shadowColor: hexToRgba(color[1], 0.5),
                // shadowOffsetY: 8,
              },
            },
            itemStyle: {
              color: "rgba(0, 219, 150, 1)",
              borderColor: "rgba(192, 231, 255, 1)",
              borderWidth: 0,
              // shadowColor: "rgba(0, 0, 0, .3)",
              // shadowBlur: 0,
              // shadowOffsetY: 0,
              // shadowOffsetX: 0,
            },
            areaStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(
                  0,
                  0,
                  0,
                  1,
                  [
                    {
                      offset: 0,
                      color: hexToRgba(color[1], 0.3),
                    },
                    {
                      offset: 1,
                      color: hexToRgba(color[1], 0.1),
                    },
                  ],
                  false
                ),
                shadowColor: hexToRgba(color[1], 0.1),
                shadowBlur: 0,
              },
            },
            data: yAxisData2,
          },
        ],
      };


      option && myChart.setOption(option)

      //随着屏幕大小调节图表
      window.addEventListener("resize", () => {
        myChart.resize();
      });

似三角锥(三角形)图形

效果图:
在这里插入图片描述
配置:

initDataEcharyts() {
      const echartDom = document.getElementById("dataEcharts")
      const myChart = echarts.init(echartDom)
      let option = {
        grid: {
          top: 30,
          bottom: 20
        },
        xAxis: [
          {
            data: [
              "21-09",
              "21-10",
              "21-11",
              "21-12",
              "22-01",
              "22-01",
              "22-03"
            ],
            axisLabel: {
              color: "#C0E7FF",
              fontSize: 10
            },
            axisTick: {
              show: false
            },
            axisLine: {
              show: false
            }
          }
        ],
        yAxis: [
          {
            name: "数量",
            nameTextStyle: {
              color: "#C0E7FF"
            },
            splitLine: {
              show: true,
              lineStyle: {
                type: "dashed",
                color: "#182450"
              }
            },
            axisLabel: {
              color: "#C0E7FF"
            }
          }
        ],
        // 使用内部缩放(滚轮缩放、鼠标拖着左右滑动)
        dataZoom: [
          {
            type: "inside",
            minValueSpan: 6, // 最小展示数
            start: 0, // 开始展示位置(默认)
            end: 5 // 结束展示位置 (默认)
          }
        ],
        series: [
          {
            name: "hill",
            // 象柱形图
            type: "pictorialBar",
            // 同一系列的柱间距离
            barCategoryGap: "20%",
            // 自定义svg 图标 (三角锥形的关键)
            // symbol: "path://M0,10 L10,10 C5.5,10 5.5,5 5,0 C4.5,5 4.5,10 0,10 z",
            symbol: "path://M0,10 L10,10 C5.5,10 5.5,5 5,2 C4.5,5 4.5,10 0,10 z",
            label: {
              normal: {
                show: true,
                position: "top",
                formatter: "{c}",
                textStyle: {
                  color: "#C0E7FF", //color of value
                },
              },
            },
            // 默认样式
            itemStyle: {
              label: {
                show: false
              },
              borderColor: "#206fde",
              borderWidth: 0,
              color: {
                colorStops: [
                  {
                    offset: 0,
                    color: "rgba(0, 133, 247, 1)"
                  },
                  {
                    offset: 1,
                    color: "rgba(0, 133, 247, 0.14)"
                  }
                ]
              }
            },

            // 鼠标滑过样式
            emphasis: {
              label: {
                show: true,
                position: "top",
                color: "#12DCFF"
              },
              itemStyle: {
                borderColor: "#17cdfa",
                borderWidth: 2,
                color: {
                  colorStops: [
                    {
                      offset: 0,
                      color: "rgba(0, 133, 247, 1)"
                    },
                    {
                      offset: 1,
                      color: "rgba(0, 133, 247, 1)"
                    }
                  ]
                }
              }
            },
            data: [80, 80, 60, 70, 80, 80, 60],
            z: 10
          }
        ]
      }

      option && myChart.setOption(option)

      //随着屏幕大小调节图表
      window.addEventListener("resize", () => {
        myChart.resize();
      });


    },

带动画的饼图

外面的环会旋转。
示意图:
在这里插入图片描述
配置:

 initCompleteStatistics() {
      const echartDom = document.getElementById("completeStatistics")
      const myChart = echarts.init(echartDom)

      let colorList = ["#00DB96", "#E59734", "#E59734"]
      let angle = 0;
      //获取圆上面某点的坐标(x0,y0表示坐标,r半径,angle角度)
      function getCirlPoint(x0, y0, r, angle) {
        let x1 = x0 + r * Math.cos((angle * Math.PI) / 180);
        let y1 = y0 + r * Math.sin((angle * Math.PI) / 180);
        return {
          x: x1,
          y: y1,
        };
      }

      let option = {
        tooltip: {
          trigger: 'item'
        },
        series: [
          {
            name: '',
            type: 'pie',
            label: {
              position: "outside",
              normal: {
                distance: '30',
                formatter: (a) => {
                  const { value, name, percent } = a
                  return `${name} \n \n${value}   ${percent}%`
                },
                backgroundColor: "rgba(255, 147, 38, 0)",
                borderColor: "transparent",
                borderRadius: 4,
                textStyle: {
                  color: "#C0E7FF",
                  fontSize: 12,
                },
              },
            },

            labelLine: {
              normal: {
                length: 40,
                length2: 60,
                show: true,
                color: "#4e5b75",
              }
            },
            radius: ['70%', '40%'],
            axisLabel: {
              color: "#C0E7FF",
            },
            itemStyle: {
              color: (params) => {
                return colorList[params.dataIndex % colorList.length];
              },
            },
            data: [
              { value: 218, name: '未备注' },
              { value: 4375, name: '已备注' }
            ],
            emphasis: {
              itemStyle: {
                shadowBlur: 10,
                shadowOffsetX: 0,
                shadowColor: 'rgba(0, 0, 0, 0.5)'
              }
            }
          },


          // 外面转圈的环
          {
            name: "ring5",
            type: "custom",
            coordinateSystem: "none",
            renderItem: function (params, api) {
              return {
                type: "arc",
                shape: {
                  cx: api.getWidth() / 2,
                  cy: api.getHeight() / 2,
                  r: (Math.min(api.getWidth(), api.getHeight()) / 2) * 0.9,
                  startAngle: ((0 + angle) * Math.PI) / 180,
                  endAngle: ((90 + angle) * Math.PI) / 180,
                },
                style: {
                  stroke: "#e59734",
                  fill: "transparent",
                  lineWidth: 1.5,
                },
                silent: true,
              };
            },
            data: [0],
          },
          {
            name: "ring5",
            type: "custom",
            coordinateSystem: "none",
            renderItem: function (params, api) {
              return {
                type: "arc",
                shape: {
                  cx: api.getWidth() / 2,
                  cy: api.getHeight() / 2,
                  r: (Math.min(api.getWidth(), api.getHeight()) / 2) * 0.9,
                  startAngle: ((180 + angle) * Math.PI) / 180,
                  endAngle: ((270 + angle) * Math.PI) / 180,
                },
                style: {
                  stroke: "#e59734",
                  fill: "transparent",
                  lineWidth: 1.5,
                },
                silent: true,
              };
            },
            data: [0],
          },
          {
            name: "ring5",
            type: "custom",
            coordinateSystem: "none",
            renderItem: function (params, api) {
              return {
                type: "arc",
                shape: {
                  cx: api.getWidth() / 2,
                  cy: api.getHeight() / 2,
                  r: (Math.min(api.getWidth(), api.getHeight()) / 2) * 0.79,
                  startAngle: ((270 + -angle) * Math.PI) / 180,
                  endAngle: ((40 + -angle) * Math.PI) / 180,
                },
                style: {
                  stroke: "#00db96",
                  fill: "transparent",
                  lineWidth: 1.5,
                },
                silent: true,
              };
            },
            data: [0],
          },
          {
            name: "ring5",
            type: "custom",
            coordinateSystem: "none",
            renderItem: function (params, api) {
              return {
                type: "arc",
                shape: {
                  cx: api.getWidth() / 2,
                  cy: api.getHeight() / 2,
                  r: (Math.min(api.getWidth(), api.getHeight()) / 2) * 0.79,
                  startAngle: ((90 + -angle) * Math.PI) / 180,
                  endAngle: ((220 + -angle) * Math.PI) / 180,
                },
                style: {
                  stroke: "#00db96",
                  fill: "transparent",
                  lineWidth: 1.5,
                },
                silent: true,
              };
            },
            data: [0],
          },
          {
            name: "ring5",
            type: "custom",
            coordinateSystem: "none",
            renderItem: function (params, api) {
              let x0 = api.getWidth() / 2;
              let y0 = api.getHeight() / 2;
              let r = (Math.min(api.getWidth(), api.getHeight()) / 2) * 0.79;
              let point = getCirlPoint(x0, y0, r, 90 + -angle);
              return {
                type: "circle",
                shape: {
                  cx: point.x,
                  cy: point.y,
                  r: 4,
                },
                style: {
                  stroke: "#00db96", //粉
                  fill: "#00db96",
                },
                silent: true,
              };
            },
            data: [0],
          },
          {
            name: "ring5", //绿点
            type: "custom",
            coordinateSystem: "none",
            renderItem: function (params, api) {
              let x0 = api.getWidth() / 2;
              let y0 = api.getHeight() / 2;
              let r = (Math.min(api.getWidth(), api.getHeight()) / 2) * 0.79;
              let point = getCirlPoint(x0, y0, r, 270 + -angle);
              return {
                type: "circle",
                shape: {
                  cx: point.x,
                  cy: point.y,
                  r: 4,
                },
                style: {
                  stroke: "#00db96", //绿
                  fill: "#00db96",
                },
                silent: true,
              };
            },
            data: [0],
          },
        ]
      };



      option && myChart.setOption(option)

      //随着屏幕大小调节图表
      window.addEventListener("resize", () => {
        myChart.resize();

      });

      let that = this
      function draw() {
        let now = new Date().getTime()
        if (now - that.lastTime > 40) {
          angle = angle + 3;
          that.lastTime = now
        }
                myChart.setOption(option, true);
        // window.requestAnimationFrame(draw);
        that.annimationId = requestAnimationFrame(draw)
      }
      setTimeout(() => {
        draw()
      }, 1000);
    },

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1347677.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

三角函数两角和差公式推导

一.几何推理 1.两角和公式 做一斜边为1的直角△ABC,任意旋转非 k Π , k N kΠ,kN kΠ,kN,补充如图,令 ∠ A B C ∠ α &#xff0c; ∠ C B F ∠ β ∠ABC∠α&#xff0c;∠CBF∠β ∠ABC∠α&#xff0c;∠CBF∠β ∴ ∠ D B F ∠ D B A ∠ α ∠ β 90 , ∠ D A …

vue3-13

token可以是后端api的访问依据&#xff0c;一般绝大多数时候&#xff0c;前端要访问后端的api,后端都要求前端请求需要携带一个有效的token,这个token用于用户的身份校验&#xff0c;通过了校验&#xff0c;后端才会向前端返回数据&#xff0c;进行相应的操作&#xff0c;如果没…

自动驾驶学习笔记(二十四)——车辆控制开发

#Apollo开发者# 学习课程的传送门如下&#xff0c;当您也准备学习自动驾驶时&#xff0c;可以和我一同前往&#xff1a; 《自动驾驶新人之旅》免费课程—> 传送门 《Apollo开放平台9.0专项技术公开课》免费报名—>传送门 文章目录 前言 控制算法 控制标定 控制协议…

【漏洞复现】企望制造ERP系统 RCE漏洞

漏洞描述 企望制造ERP系统是畅捷通公司开发的一款领先的生产管理系统&#xff0c;它以集成化管理为核心设计理念&#xff0c;通过模块化机制&#xff0c;帮助企业实现生产、采购、库存等方面的高效管理。该系统存在RCE远程命令执行漏洞&#xff0c;恶意攻击者可利用此漏洞进行…

【解决复杂链式任务打造全能助手】大模型思维链 CoT 应用:langchain 大模型 结合 做 AutoGPT

大模型思维链 CoT 应用&#xff1a;langchain 大模型 结合 做 AutoGPT&#xff0c;解决复杂链式任务打造全能助手 思维链 CoTlangchainlangchain 大模型结合打造 AutoGPT 思维链 CoT 最初的语言模型都是基于经验的&#xff0c;只能根据词汇之间的相关性输出答案&#xff0c;根…

Android 接入第三方数数科技平台

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、数数科技平台是什么&#xff1f;二、使用步骤1.集成SDK2. 初始化3. 发送事件和设置账号id4. 验证发送事件是否成功 小结 前言 一个成熟的App必然不可缺少对…

FingerprintService启动-Android13

FingerprintService启动-Android13 1、指纹服务启动1.1 rc启动Binder对接指纹厂商TA库1.2 FingerprintService启动1.2.1 SystemServer启动FingerprintService1.2.2 注册Binder服务fingerprint 2、获取底层信息2.1 AIDL 对接TA中获取2.2 指纹类型判断 android13-release 1、指纹…

有限差分场的数值计算:代数、求导、积分

文章目录 前言一、代数运算1.手动计算流程2.ubermag库函数验证 二、求导运算1.手动计算流程2.ubermag库函数验证3.标量场的梯度&#xff0c;矢量场的散度和旋度 三、积分运算1.手动计算流程2.ubermag库函数验证 总结 靡不有初&#xff0c;鲜克有终。——《诗经大雅荡》 前言 …

fastApi 项目部署

方式一&#xff0c;Uvicorn部署 Run a Server Manually - Uvicorn - FastAPI 1&#xff0c;linux服务器安装 python>3.8 2&#xff0c;安装 uvicorn : pip install "uvicorn[standard]" 3&#xff0c;上传项目到服务器 main.py from typing imp…

机场信息集成系统系列介绍(6):机场协同决策支持系统ACDM*续集

目录 1、A-CDM实施效果评估背景 2、评估核心指标项 &#xff08;1&#xff09;机位效率 &#xff08;2&#xff09;登机效率 &#xff08;3&#xff09;推出效率 &#xff08;4&#xff09;滑行效率 &#xff08;5&#xff09;协同效率 3、其他指标项 &#xff08;1&a…

使用 Hyper-V 创建虚拟机

使用 Hyper-V 创建虚拟机 官网教程修改存储目录Hyper-V管理器创建虚拟机启动虚拟机Win10安装教程Press any key to boot from CD or DVD...... 如何使用Windows自带的虚拟机工具来创建虚拟机&#xff0c; 快速创建虚拟机进行学习探讨&#xff0c;如果有环境问题可以立即创建一个…

Vue-Setup

一、setup概述 小小提示&#xff1a;vue3中可以写多个根标签。 Person.vue中内容 <template><div class"person"><h2>姓名&#xff1a;{{name}}</h2><h2>年龄&#xff1a;{{age}}</h2><!--定义了一个事件&#xff0c;点击这…

【Image】超硬核数学推导——WGAN的先“破”后“立”

GAN的实现 上一篇文章中我们说到了GAN的数学解释 min ⁡ G max ⁡ D V ( D , G ) E x ∼ p data ( x ) [ log ⁡ D ( x ) ] E z ∼ p z ( z ) [ log ⁡ ( 1 − D ( G ( z ) ) ) ] − log ⁡ 4 2 J S D ( p data ∥ p g ) ≥ − log ⁡ 4 , where [ p d a t a p g ] \mi…

node相关的args属性与<param>子标签的区别

launch文件内&#xff1a;node标签内的<param>标签示例&#xff1a; 可以看到launch文件内的<param>标签在命令行内会转化为--ros-args -p 这样格式的命令&#xff0c;说明<param>标签指定的是ros2内的参数。不能用于传递非ros2的传入参数 如果要传入非ros2…

【测试基础】构造测试数据之 MySQL 篇

构造测试数据之 MySQL 篇 作为一名测试工程师&#xff0c;我们经常会构造测试数据进行一些功能验证。为了暴露更多的问题&#xff0c;在测试数据的构造上&#xff0c;我们应该尽可能的构造不同类型字段的数据&#xff0c;且一张表的字段最好不低于 10 10 10 个。 对于 MySQL …

在高并发场景下,缓存“雪崩”了怎么办

1. 缓存雪崩的常见原因 缓存“雪崩”是指&#xff0c;因为部分缓存节点不可用&#xff0c;而导致整个缓存系统&#xff08;甚至是整个服务系统&#xff09;不可用。缓存“雪崩”主要分为以下两种情况&#xff1a; 因缓存不支持 rehash 而导致的缓存“雪崩”缓存支持 rehash 时…

基于Vite创建简单Vue3工程

首先安装node.js环境&#xff0c;没有node.js环境&#xff0c;便没有npm命令。 1、Vue3创建执行命令 D:\TABLE\test>npm create vuelatestVue.js - The Progressive JavaScript Framework√ 请输入项目名称&#xff1a; ... vue_test √ 是否使用 TypeScript 语法&#xff…

很想写一个框架,比如,spring

很想写一个框架&#xff0c;比如&#xff0c;spring。 原理很清楚&#xff0c;源码也很熟悉。 可惜力不从心&#xff0c;是不是可以找几个小弟一起做。

Stata18软件安装包下载及安装教程

Stata 18下载链接&#xff1a;https://docs.qq.com/doc/DUm5pRlFJaWV5aWtY 1.选中下载好的安装包&#xff0c;右键选择解压到“Stata18”文件夹 2.选中“SetupStata18.exe”&#xff0c;右键以管理员身份运行 3.点击“Next” 4.选择“I accept.....”,选择“Next” 5.点击“Nex…

分布式系统架构设计之分布式数据存储的扩展方式、主从复制以及分布式一致性

三、水平扩展和垂直扩展 在分布式系统中&#xff0c;数据存储的扩展是为了适应业务的增长和提高系统的性能。分为水平扩展和垂直扩展两种方式&#xff0c;这两种方式在架构设计和应用场景上有着不同的优势和局限性。 水平扩展 水平扩展是通过增加节点或服务器的数量来扩大整…