echarts实现3D环状图

2,078 阅读1分钟
<template>
  <div class="chart-container" :id="_uid" :style="{width:'100%',height: height}"></div>
</template>

<script>
  export default {
    name: "BarColor",
    props: {
      height: {
        type: String,
        default: '300px'
      },
      width: {
        type: String,
        default: '400px'
      }
    },
    data() {
      return {
        resizeTimer: null,
        option:{},
        trafficWay:[
            {
                name: '吃喝',
                value: 20,
            },
            {
                name: '服饰',
                value: 10,
            },
            {
                name: '日用品',
                value: 30,
            },
            {
                name: '化妆品',
                value: 40,
            }
        ],
        data:[],
        angle:0,//角度,用来做简单的动画效果的
        timerId:'',
        color:['#FF801C', '#F5FF46', '#00FE65', '#00FEFF', '#ffa800', '#ff5b00', '#ff3000'],
        img:'',
        seriesOption:[]
      }
    },
    mounted() {
      this.drawLine()
    },
    methods: {
       drawLine() {
         console.log(555)
          const echarts = this.$echarts;
          // 基于准备好的dom,初始化echarts实例
          let myChart = echarts.init(document.getElementById(this._uid));
          this.option = this.getPie3D();
    //  绘制图表
    myChart.setOption(this.option);
},

getPie3D() {
      // 00FEFF
      var color = ['#FF801C', '#F5FF46', '#00FE65', '#00FEFF', '#ffa800', '#ff5b00', '#ff3000'];
      for (var i = 0; i < this.trafficWay.length; i++) {
          this.data.push(
              {
                  value: this.trafficWay[i].value,
                  name: this.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,
                      },
                  },
              }
          );
      }
      this.seriesOption=[            {                name: '',                type: 'pie',                clockWise: false,                radius: [105, 140],
                hoverAnimation: false,
                itemStyle: {
                    normal: {
                        label: {
                            show: true,
                            position: 'outside',
                            color: '#ddd',
                            formatter: function (params) {
                                var percent = 0;
                                var total = 0;
                                for (var i = 0; i < this.trafficWay.length; i++) {
                                    total += this.trafficWay[i].value;
                                }
                                percent = ((params.value / total) * 100).toFixed(0);
                                if (params.name !== '') {
                                    return '占百分比:' + percent + '%';
                                    // return '交通方式:' + params.name + '\n' + '\n' + '占                   百分比:' + percent + '%';
                                } else {
                                    return '';
                                }
                            },
                        },
                        labelLine: {
                            length: 30,
                            length2: 100,
                            show: true,
                            color: '#00ffff',
                        },
                    },
                },
                data: this.data,
            },
            // 紫色
            {
                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()) / 5.3,
                            startAngle: ((0 + this.angle) * Math.PI) / 180,
                            endAngle: ((90 + this.angle) * Math.PI) / 180,
                        },
                        style: {
                            stroke: '#00FEFF',
                            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()) / 5.3;
                    let point = this.getCirlPoint(x0, y0, r, 90 + this.angle);
                    return {
                        type: 'circle',
                        shape: {
                            cx: point.x,
                            cy: point.y,
                            r: 4,
                        },
                        style: {
                            stroke: '#00FEFF', //绿
                            fill: '#00FEFF',
                        },
                        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()) / 5.3,
                            startAngle: ((180 + this.angle) * Math.PI) / 180,
                            endAngle: ((270 + this.angle) * Math.PI) / 180,
                        },
                        style: {
                            stroke: '#00FEFF',
                            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()) / 5.3;
                    let point = this.getCirlPoint(x0, y0, r, 180 + this.angle);
                    return {
                        type: 'circle',
                        shape: {
                            cx: point.x,
                            cy: point.y,
                            r: 4,
                        },
                        style: {
                            stroke: '#00FEFF', //绿
                            fill: '#00FEFF',
                        },
                        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()) / 5.8,
                            startAngle: ((270 + -this.angle) * Math.PI) / 180,
                            endAngle: ((40 + -this.angle) * Math.PI) / 180,
                        },
                        style: {
                            stroke: '#00FEFF',
                            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()) / 5.8,
                            startAngle: ((90 + -this.angle) * Math.PI) / 180,
                            endAngle: ((220 + -this.angle) * Math.PI) / 180,
                        },
                        style: {
                            stroke: '#00FEFF',
                            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()) / 5.8;
                    let point = this.getCirlPoint(x0, y0, r, 90 + -this.angle);
                    return {
                        type: 'circle',
                        shape: {
                            cx: point.x,
                            cy: point.y,
                            r: 4,
                        },
                        style: {
                            stroke: '#00FEFF', //粉
                            fill: '#00FEFF',
                        },
                        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()) / 5.8;
                    let point = this.getCirlPoint(x0, y0, r, 270 + -this.angle);
                    return {
                        type: 'circle',
                        shape: {
                            cx: point.x,
                            cy: point.y,
                            r: 4,
                        },
                        style: {
                            stroke: '#00FEFF', //绿
                            fill: '#00FEFF',
                        },
                        silent: true,
                    };
                },
                data: [0],
            },
        ],
    // 准备待返回的配置项,把准备好的 legendData、series 传入。
    this.option = {
        backgroundColor: '#000E1A',
        color: color,
        graphic: {
        elements: [
            {
                type: 'image',
                z: 3,
                style: {
                    image: this.img,
                    width: 178,
                    height: 178,
                },
                left: 'center',
                top: 'center',
                position: [100, 100],
            },
        ],
    },
    tooltip: {
        show: false,
    },
    legend: {
        icon: 'circle',
        orient: 'horizontal',
        // x: 'left',
        data: ['吃喝', '服饰', '日用品', '化妆品'],

        align: 'right',
        textStyle: {
            color: '#fff',
        },
        itemGap: 20,
    },
    toolbox: {
            show: false,
        },
        series: this.seriesOption,
        };
        return this.option;
        },
    }
  }
</script>

<style lang="scss">
  .chart-container {
    div:first-child {
      width: 100% !important;

      canvas {
        width: 100% !important;
      }
    }
  }
</style>