3d柱状图2

预览图:

 

import React, { Component } from 'react';
import * as echart from 'echarts';
import { compare } from '@/utils/tools';
import style from './index.less';

/**
 *  3D柱状图
 *  @param {string[]} xAxis                   X轴数据
 *  @param {string} barColor                  柱状颜色
 *  @param {object[]} barData                 柱状数据
 *  @param {number} barWidth                  柱状宽度
 *  @param {number|number[]} barBorderRadius  柱状圆角
 *  @param {Object} optionObj
 *
 */
class ManyPie extends Component {
  constructor(props) {
    super(props);
    this.chartRef = React.createRef();
  }
  chartRef;
  chart;

  componentDidUpdate() {
    this.init()
  }

  componentDidMount() {
    this.init()
  }

  init() {
    // 基于准备好的dom,初始化echart实例
    if (this.chart != null && this.chart != "" && this.chart != undefined) {
      this.chart.dispose();//解决echarts dom已经加载的报错
    }
    // 基于准备好的dom,初始化echart实例
    this.chart = echart.init(this.chartRef.current, null, { devicePixelRatio: 2.5 });
    this.chart.clear();
    this.setOptions();

    window.addEventListener("resize", () => {
      this.chart.resize();
    });
  }
  barColor = ['#41C6E8', '#F5D66E', '#95D171'];
  barData = [
    { x: "Sun", value: 22 },
    { x: "Mon", value: 18 },
    { x: "Tue", value: 19 },
    { x: "Wed", value: 23 },
    { x: "Thu", value: 29 }
  ]
  xAxis = ['示例街道一', '示例街道二', '示例街道三', '示例街道四', '示例街道五']
  setOptions() {
    const { title = false, subtitle = '', xAxis = this.xAxis, barColor = this.barColor, barWidth = 4, barData = this.barData, barBorderRadius = [10, 10, 0, 0], optionObj = {} } = this.props;

    var mid = ""
    var top = ""
    var bottom = ""
    var bottom1 = ""


    var x = []
    var y = []
    var imgList = []

    barData.forEach((item, index) => {
      x.push(item.x)
      y.push(item.value)
      imgList.push({
        coord: [index, item.value],
        symbolSize: [22, 12],
        symbolOffset: ['23.5%', 0],
        symbol: "image://" + top,
        value: item.value,
        label: {
          show: true,
          offset: [0, -30],
          fontSize: 16,
          color: "#00baff",
          formatter: function (params) {
            return params.value + '%'
          }
        }
      }, {
        coord: [index, 0],
        symbolOffset: ['23.5%', 2.37],
        symbolSize: [22, 6],
        symbol: "image://" + bottom,
        itemStyle: {
          opacity: 0.8
        }
      }, {
        coord: [index, 0],
        symbolOffset: ['22%', 0],
        symbolSize: [22, 12],
        symbol: "image://" + bottom1,
        itemStyle: {
          opacity: 0.8
        }
      })
    })


    var option = {
      title: {
        text: 'Awesome Chart'
      },
      xAxis: {
        show: false,
        offset: 20,
        interval: 20,
        data: x,
        axisLabel: {
          color: '#fff'
        },
        axisLine: {
          show: true
        },
        splitLine: {
          show: false
        },
        axisTick: {
          show: false
        }
      },
      yAxis: {
        show: false,
        axisLine: {
          show: true
        },
        splitLine: {
          show: false
        },
        axisTick: {
          show: false
        }
      },
      series: [{
        z: 1,
        type: 'bar',
        barWidth: 10,
        symbolOffset: [0, -8],
        data: y,
        offset: 10,
        itemStyle: {
          normal: {
            borderColor: new echart.graphic.LinearGradient(0, 0, 0, 1, [
              {
                offset: 0,
                color: 'rgba(0, 79, 197, 0.2)',
              },
              {
                offset: 1,
                color: 'rgba(0, 79, 197, 1)',
              },
            ]),
            color: {
              x: 0,
              y: 1,
              x2: 0,
              y2: 0,
              colorStops: [
                { offset: 0, color: 'rgba(0, 79, 197, 1)' },
                { offset: 1, color: 'rgba(0, 79, 197, 0)' }
              ]
            },
            opacity: 0.8
          }
        },
        markPoint: {
          data: imgList
        }
      }, {
        z: 1,
        type: 'bar',
        barWidth: 10,
        barGap: '-3%',
        symbolOffset: [0, -10],
        data: y,
        offset: 10,
        itemStyle: {
          normal: {
            borderColor: new echart.graphic.LinearGradient(0, 0, 0, 1, [
              {
                offset: 0,
                color: 'rgba(0, 79, 197, 0.2)',
              },
              {
                offset: 1,
                color: 'rgba(0, 79, 197, 1)',
              },
            ]),
            color: {
              x: 0,
              y: 1,
              x2: 0,
              y2: 0,
              colorStops: [
                {offset: 0, color: 'rgba(0, 154, 255, 1)'},
                {offset: 1, color: 'rgba(0, 154, 255, 0)'}
              ]
            },
            opacity: 0.8
          }
        }
      }]
    };

    // 绘制图表

    // mergeJSON(option, optionObj);
    // console.log(option, 333, Object.assign(option, optionObj));
    this.chart.setOption(option);
    window.onresize = () => {
      this.chart.resize();
    }
  }

  render() {
    const { width, height } = this.props;
    return (
      <div ref={this.chartRef} style={{ width: width ? width : `100%`, height: height ? height : '100%' }}></div>
    )
  }
}

export default ManyPie;

 

参考:http://analysis.datains.cn/finance-admin/index.html#/chartLib/all
posted @ 2022-03-03 16:51  ShirleyHe  阅读(468)  评论(0编辑  收藏  举报