funnelChart.vue 9.32 KB
<template>
  <div style="position:relative;">
    <basic ref="basic" :chartId="chartId" :chartData="chartData"></basic>
  </div>
</template>
<script>
import mixin from './mixin';
import { chartweather, weatherpng } from '../Charts/weather'
export default {
  mixins: [mixin],
  data() {
    return {

    }
  },
  methods: {
    /**
     * 预处理option参数
     * */
    preChartData(cdata) {
      /*if(!cdata||!cdata.data||!cdata.data[0]||cdata.data[0].value==0){
        cdata.series = [];
        cdata.noProcess = false;
      }*/
      return cdata;
    },
    /**
     * 处理option参数
     * */
    dealChartData(data) {
      var uploadedDataURL = "/asset/get/s/data-1576742942370-X6JMK0GY.png";
      var colors = ['#1cd389', '#668eff', '#ffc751', '#ff6e73', '#8683e6', '#9692ff'];
      var url = 'image://';
      if (!data || JSON.stringify(data) === "{}"||data.data.length==0) {
        return false;
      }
      let chartdata = data.data.sort((a, b) => b.value - a.value);
      let graphic = [];
      let halfW = this.$refs.basic.$el.offsetWidth/2;
      let partH = 400/chartdata.length;
      let nameList = JSON.parse(JSON.stringify(chartdata)).sort((a, b) => b.value - a.value);
      for (var i = 0; i < nameList.length; i++) {
        graphic.push({
          type: 'group',
          bounding: 'raw',
          left:0,
          top: partH*i,
          children: [{
              type: 'rect',
              left: 0,
              top: 0,
              shape: {
                width: halfW,
                height: partH
              },
              style: {
                fill: i%2?'#fff':'#F5F7F9'
              }
            },
            {
              type: 'text',
              left: 20,
              top: partH/3,
              style: {
                fill: '#000',
                font: 'normal 15px sans-serif',
                text: nameList[i].name
              }
            },
            {
              type: 'text',
              left: 20,
              top: partH/1.9,
              style: {
                fill: '#3F8AFA',
                font: 'normal 15px sans-serif',
                text: this.toThousands(nameList[i].value)+this.$t("format.perNum")
              }
            }
          ]
        })
      }
      chartdata.forEach((item,idx)=>{
        item.value1 = item.value;
        item.value = 1000-250*idx;
        return item ;
      })
      var option = {
        backgroundColor: "transparent",
        graphic,
        color: data.color || ["#6FA9FF", "#FF9C7F", "#66D5C6", "#FFD48A", "#FFA2C0"],
        grid: {
          left: 0,
          right: 0,
          top: 0,
          bottom: 0
        },
        tooltip: {
          formatter: params => {
            return `${params.name} ${params.data.value1 || ""}${
              params.data.value1 ? this.$t("format.perNum") : ""
            }`;
          }
        },
        series: [{
            top: 0,
            type: 'funnel',
            height: 400,
            gap: 0,
            //minSize: 80,
            left: '25%',
            width: '50%',
            label: {
              show: true,
              position: 'inside',
              fontSize: '15',
              formatter: function(d) {
                var ins = d.name + '{aa|}\n' //+ d.data.value;
                return ins
              },
              rich: {
                aa: {
                  padding: [8, 0, 6, 0],
                }
              }
            },
            data: chartdata
          },
          {
            top: 0,
            type: 'funnel',
            gap: 0,
            height: 400,
            //minSize: 80,
            left: '25%',
            width: '50%',
            color: '#000000',
            z: 2,
            label: {
              normal: {
                color: '#000000',
                position: 'rightTop',
                //backgroundColor: '#f6f7fc',
                //borderColor: '#f6f7fc',
                //borderWidth: 1,
                //borderRadius: 4,
                //padding: [11, 25, 11, 25],
                formatter: function(d) {
                  let index = d.dataIndex;
                  let len = chartdata.length;
                  let perc = index == 0 ? '' : (d.data.value1 * 100 / chartdata[index-1].value1).toFixed(2) + '%';
                  let pinfo = "";
                  if (perc) {
                    pinfo = '{gap|}{aa|} ' + chartdata[index-1].name + '->' + chartdata[index].name + ':';
                  }
                  var ins = pinfo + '{bb|' + (perc) + '}';
                  return ins
                },
                rich: {
                  gap:{
                    width: 50,
                  },
                  aa: {
                    width: 50,
                    height: 320 / chartdata.length,
                    backgroundColor: {
                      image: ''
                    }
                  },
                  bb: {
                    color: '#333',
                    fontSize: '14',
                  }
                }
              }
            },
            labelLine: {
              show: false
            },
            data: chartdata
          }
        ]
      };
      if(data.data.length==0)option.series=[];
      if (data.otherConf) {
        option.series.lineStyle = data.otherConf.lineStyle || '';
        option.series.top = data.otherConf.top || ''
      }

      return option;
    }
  },
  created() {

  }
}

</script>
<style scoped>
</style>