vue使用echarts图表小结


注:部分效果为动图叠加

仪表盘

在这里插入图片描述

const getOption = (data, color) => {
  return {
    series: [
      {
        type: 'gauge',
        name: '最外层蓝圈',
        radius: '74%',
        startAngle: '225',
        endAngle: '-45',
        splitNumber: '10',
        pointer: {
          show: false,
        },
        detail: {
          show: false,
        },
        data: [
          {
            value: 1,
          },
        ],
        axisLine: {
          show: true,
          lineStyle: {
            color: [[1, 'rgba(0,99,190,1)']],
            width: 2,
            shadowBlur: 10,
            shadowOffsetX: 0,
            shadowOffsetY: 0,
            shadowColor: 'rgba(0, 99, 190, 0.8)',
          },
        },
        axisTick: {
          show: false,
        },
        splitLine: {
          show: true,
          length: 2,
          lineStyle: {
            color: '#051932',
            width: 1,
            type: 'solid',
          },
        },
        axisLabel: {
          show: false,
        },
      },
      {
        type: 'gauge',
        radius: '70%',
        startAngle: '225',
        endAngle: '-45',
        min: 0,
        max: 10,
        splitNumber: 10,
        pointer: {
          show: true,
          width: 2,
          itemStyle: {
            // 表盘指针的颜色
            color: '#57EAFF',
          },
        },
        detail: {
          offsetCenter: ['0%', '55%'],
          color: color,
          fontSize: 30,
        },
        data: data,
        title: {
          show: false,
        },
        axisLine: {
          lineStyle: {
            width: 2,
            color: '#051932',
          },
        },
        progress: {
          show: true,
          width: 5,
          itemStyle: {
            color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [
              {
                offset: 0,
                color: '#11f656', // 0% 处的颜色
              },
              {
                offset: 1,
                color: color, // 100% 处的颜色
              },
            ]),
          },
        },
        axisTick: {
          show: false,
        },
        splitLine: {
          show: false,
          length: 2,
          lineStyle: {
            color: '#00377a',
            width: 2,
            type: 'solid',
          },
        },
        axisLabel: {
          show: false,
        },
        animationDuration: 1400,
      },
      {
        name: '表盘刻度',
        type: 'gauge',
        radius: '80%',
        startAngle: 225, //刻度起始
        endAngle: -45, //刻度结束
        min: 0,
        max: 10,
        splitNumber: 10,
        z: 4,
        axisTick: {
          show: false,
        },
        splitLine: {
          length: 2, //刻度节点线长度
          lineStyle: {
            width: 2,
            color: 'auto',
          }, //刻度节点线
        },
        axisLabel: {
          color: '#3F8ECA',
          fontSize: 10,
        }, //刻度节点文字颜色
        pointer: {
          show: false,
        },
        axisLine: {
          lineStyle: {
            color: [
              [0.2, '#2AF65F'],
              [0.4, '#B0D651'],
              [0.6, '#F2CB3E'],
              [0.8, '#F69D23'],
              [1, '#FF0100'],
            ],
            opacity: 0,
          },
        },
        detail: {
          show: false,
        },
        data: [
          {
            value: 10,
            name: '',
          },
        ],
      },
      {
        //底部半透明大圆环内圆
        type: 'pie',
        radius: '36%',
        center: ['50%', '50%'],
        z: 1,
        itemStyle: {
          color: 'rgba(0,6,33,0.7)',
        },
        emphasis: {
          scale: false,
        },
        tooltip: {
          show: false,
        },
        data: [10],
        animationType: 'scale',
      },
      {
        //底部半透明大圆环外圆
        type: 'pie',
        radius: '66%',
        center: ['50%', '50%'],
        z: 0,
        itemStyle: {
          color: new echarts.graphic.RadialGradient(
            0.5,
            0.5,
            0.7,
            [
              {
                offset: 0,
                color: 'rgb(8,128,238)',
              },
              {
                offset: 0.55,
                color: 'rgb(1,10,50)',
              },
              {
                offset: 1,
                color: 'rgb(8,128,238)',
              },
            ],
            false
          ),
        },
        emphasis: {
          scale: false,
        },
        tooltip: {
          show: false,
        },
        data: [10],
        animationType: 'scale',
      },
      {
        name: '小圆最内部圆',
        type: 'pie',
        emphasis: {
          scale: false,
        },
        legendHoverLink: false,
        radius: ['0%', '8%'],
        tooltip: {
          show: false,
        },
        z: 10,
        label: {
          show: false,
        },
        data: [
          {
            value: 100,
            name: '2',
            itemStyle: {
              color: '#0E1327',
            },
          },
        ],
      },
      {
        name: '小圆蓝内圈',
        type: 'pie',
        emphasis: {
          scale: false,
        },
        legendHoverLink: false,
        radius: ['7%', '9%'],
        tooltip: {
          show: false,
        },
        z: 10,
        label: {
          show: false,
        },
        data: [
          {
            value: 100,
            name: '2',
            itemStyle: {
              color: '#6FEDFF',
            },
          },
        ],
      },
      {
        name: '小圆蓝内外圈之间圆环',
        type: 'pie',
        emphasis: {
          scale: false,
        },
        legendHoverLink: false,
        tooltip: {
          show: false,
        },
        radius: ['9%', '14%'],
        z: 10,
        label: {
          show: false,
        },
        data: [
          {
            value: 0,
            name: '1',
            itemStyle: {
              color: 'red',
            },
          },
          {
            value: 100,
            name: '2',
            itemStyle: {
              color: '#0E1327',
            },
          },
        ],
      },
      {
        name: '小圆蓝外圈',
        type: 'pie',
        emphasis: {
          scale: false,
        },
        legendHoverLink: false,
        tooltip: {
          show: false,
        },
        radius: ['14%', '16%'],
        z: 10,
        label: {
          show: false,
        },
        data: [
          {
            value: 100,
            name: '2',
            itemStyle: {
              color: '#6FEDFF',
            },
          },
        ],
      },
    ],
  };
};

曲线图

三曲线

在这里插入图片描述

const getOption = (data) => {
  return {
    grid: {
      x: 42,
      y: 40,
      x2: 17,
      y2: 25,
    },
    tooltip: {
      trigger: 'axis',
      axisPointer: {
        type: 'cross',
        crossStyle: {
          color: 'rgba(213,212,212,0.5)',
        },
      },
      backgroundColor: 'rgba(0,6,46,0.80)',
      borderColor: 'rgba(37,192,255,0.70)',
      formatter: function (params) {
        let color = ['#01C5FF', '#21E1B9', '#FFF21A'];
        let str =
          '<span style="font-size: 18px;color:#3EB5FF">' +
          params[0].axisValue +
          '</span>' +
          '<br />';
        params.forEach((item, index) => {
          str +=
            '<span style="display:inline-block;margin-right:5px;font-size: 18px;border-radius:50%;width:10px;height:10px;left:5px;background-color:' +
            color[index] +
            '"></span>' +
            '<span style="display:inline-block;margin: 0 0 0 5px;font-size: 18px;color:#3EB5FF;width: 65px">' +
            item.seriesName +
            ' : ' +
            '</span>' +
            '<span style="display:inline-block;margin-left:20px;font-size: 18px;color:#25FFE5">' +
            item.data +
            '</span>' +
            '<br />';
        });
        return str;
      },
    },
    legend: {
      right: '1.5%',
      top: '2%',
      data: [
        {
          name: '高速',
          itemStyle: {
            color: '#01C5FF',
          },
          icon:
            'path://M512 139.81262864a286.42534744 286.42534744 0 1 0 286.42534744 286.42534744 286.42534744 286.42534744 0 0 0-286.42534744-286.42534744z m0 477.3755789a190.95023144 190.95023144 0 1 1 190.95023144-190.95023146 190.95023144 190.95023144 0 0 1-190.95023144 190.95023146z',
        },
        {
          name: '快速路',
          itemStyle: {
            color: '#00CD95',
          },
          icon:
            'path://M512 139.81262864a286.42534744 286.42534744 0 1 0 286.42534744 286.42534744 286.42534744 286.42534744 0 0 0-286.42534744-286.42534744z m0 477.3755789a190.95023144 190.95023144 0 1 1 190.95023144-190.95023146 190.95023144 190.95023144 0 0 1-190.95023144 190.95023146z',
        },
        {
          name: '主干道',
          itemStyle: {
            color: '#FFF21A',
          },
          icon:
            'path://M512 139.81262864a286.42534744 286.42534744 0 1 0 286.42534744 286.42534744 286.42534744 286.42534744 0 0 0-286.42534744-286.42534744z m0 477.3755789a190.95023144 190.95023144 0 1 1 190.95023144-190.95023146 190.95023144 190.95023144 0 0 1-190.95023144 190.95023146z',
        },
      ],
      itemWidth: 15,
      itemHeight: 15,
      itemGap: 30,
      selectedMode: true, //选择
      textStyle: {
        color: '#F1F2FF',
      },
    },
    xAxis: [
      {
        type: 'category',
        data: data.x,
        axisPointer: {
          type: 'shadow',
        },
        axisLine: {
          show: true,
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
            width: 2,
          },
        },
        axisLabel: {
          show: true,
          color: '#F1F2FF',
          fontSize: 15,
          fontWeight: 500,
        },
        boundaryGap: false,
      },
    ],
    yAxis: [
      {
        type: 'value',
        name: '单位:km/h',
        nameTextStyle: {
          color: '#F1F2FF',
          fontSize: '16',
          padding: [0, 0, 0, 22],
        },
        axisLine: {
          show: true,
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
            width: 2,
          },
        },
        axisLabel: {
          show: true,
          color: '#F1F2FF',
          fontSize: 15,
          fontWeight: 500,
        },
        splitLine: {
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
          },
        },
      },
      {
        type: 'value',
        axisLine: {
          show: true,
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
            width: 2,
          },
        },
      },
    ],
    series: [
      {
        name: '高速',
        type: 'line',
        smooth: true, //是否平滑
        showAllSymbol: false,
        symbol: 'circle',
        symbolSize: 2,
        lineStyle: {
          color: '#01C5FF',
        },
        itemStyle: {
          smooth: true,
          color: '#01C5FF',
          shadowColor: 'rgba(1,197,255,0.2)',
          shadowBlur: 7.5,
        },
        z: 12,
        areaStyle: {
          color: new echarts.graphic.LinearGradient(
            0,
            0,
            0,
            1,
            [
              {
                offset: 0,
                color: 'rgba(80,204,255,0.2)',
              },
              {
                offset: 1,
                color: 'rgba(80,204,255,0)',
              },
            ],
            false
          ),
          shadowColor: 'rgba(0,179,244, 0.5)',
          shadowBlur: 20,
        },
        data: data.high,
      },
      {
        name: '快速路',
        type: 'line',
        smooth: true, //是否平滑
        showAllSymbol: false,
        symbol: 'circle',
        symbolSize: 2,
        lineStyle: {
          color: '#00CD95',
        },
        itemStyle: {
          color: '#00CD95',
          shadowColor: 'rgba(33,225,185,0.2)',
          shadowBlur: 7.5,
        },
        z: 11,
        areaStyle: {
          color: new echarts.graphic.LinearGradient(
            0,
            0,
            0,
            1,
            [
              {
                offset: 0,
                color: 'rgba(33,225,185,0.2)',
              },
              {
                offset: 1,
                color: 'rgba(80,204,255,0)',
              },
            ],
            false
          ),
          shadowColor: 'rgba(33,225,185,0.5)',
          shadowBlur: 20,
        },
        data: data.quick,
      },
      {
        name: '主干道',
        type: 'line',
        smooth: true, //是否平滑
        showAllSymbol: false,
        symbol: 'circle',
        symbolSize: 2,
        itemStyle: {
          color: '#FFDE00',
          shadowColor: 'rgba(223, 223, 67, 0.2)',
          shadowBlur: 7.5,
        },
        lineStyle: {
          color: '#FFDE00',
        },
        z: 10,
        areaStyle: {
          color: new echarts.graphic.LinearGradient(
            0,
            0,
            0,
            1,
            [
              {
                offset: 0,
                color: 'rgba(223, 223, 67, 0.2)',
              },
              {
                offset: 1,
                color: 'rgba(80,204,255,0)',
              },
            ],
            false
          ),
          shadowColor: 'rgba(255,242,26,0.5)',
          shadowBlur: 20,
        },
        data: data.main,
      },
    ],
  };
};

双曲线

在这里插入图片描述

const getOption = (data) => {
  return {
    grid: {
      x: 60,
      y: 40,
      x2: 17,
      y2: 25,
    },
    tooltip: {
      trigger: 'axis',
      axisPointer: {
        type: 'cross',
        crossStyle: {
          color: 'rgba(213,212,212,0.5)',
        },
      },
      backgroundColor: 'rgba(0,6,46,0.80)',
      borderColor: 'rgba(37,192,255,0.70)',
      textStyle: {
        color: '#3EB5FF',
        fontSize: '18',
      },
    },
    legend: {
      right: '1.5%',
      top: '2%',
      data: [
        {
          name: '预测指数',
          icon:
            'path://M512 139.81262864a286.42534744 286.42534744 0 1 0 286.42534744 286.42534744 286.42534744 286.42534744 0 0 0-286.42534744-286.42534744z m0 477.3755789a190.95023144 190.95023144 0 1 1 190.95023144-190.95023146 190.95023144 190.95023144 0 0 1-190.95023144 190.95023146z',
        },
        {
          name: '交通指数',
          icon:
            'path://M512 139.81262864a286.42534744 286.42534744 0 1 0 286.42534744 286.42534744 286.42534744 286.42534744 0 0 0-286.42534744-286.42534744z m0 477.3755789a190.95023144 190.95023144 0 1 1 190.95023144-190.95023146 190.95023144 190.95023144 0 0 1-190.95023144 190.95023146z',
        },
      ],
      itemWidth: 15,
      itemHeight: 15,
      itemGap: 30,
      selectedMode: true, //选择
      textStyle: {
        color: '#F1F2FF',
      },
    },
    xAxis: [
      {
        type: 'category',
        data: data.x,
        axisPointer: {
          type: 'shadow',
        },
        axisLine: {
          show: true,
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
            width: 2,
          },
        },
        axisLabel: {
          show: true,
          color: '#F1F2FF',
          fontSize: 15,
          fontWeight: 500,
        },
        boundaryGap: false,
      },
    ],
    yAxis: [
      {
        type: 'value',
        name: data.unit,
        nameTextStyle: {
          color: '#F1F2FF',
          fontSize: '16',
        },
        axisLine: {
          show: true,
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
            width: 2,
          },
        },
        axisLabel: {
          show: true,
          color: '#F1F2FF',
          fontSize: 15,
          fontWeight: 500,
        },
        splitLine: {
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
          },
        },
      },
      {
        type: 'value',
        axisLine: {
          show: true,
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
            width: 2,
          },
        },
      },
    ],
    series: [
      {
        name: '交通指数',
        type: 'line',
        smooth: true, //是否平滑
        showAllSymbol: false,
        symbol: 'circle',
        symbolSize: 2,
        lineStyle: {
          color: '#50CCFF',
        },
        itemStyle: {
          color: '#50CCFF',
        },
        areaStyle: {
          color: new echarts.graphic.LinearGradient(
            0,
            0,
            0,
            1,
            [
              {
                offset: 0,
                color: 'rgba(80,204,255,0.3)',
              },
              {
                offset: 1,
                color: 'rgba(80,204,255,0)',
              },
            ],
            false
          ),
          shadowColor: 'rgba(0,179,244, 0.9)',
          shadowBlur: 20,
        },
        data: data.history,
      },
      {
        name: '预测指数',
        type: 'line',
        smooth: true, //是否平滑
        showAllSymbol: false,
        symbol: 'circle',
        symbolSize: 2,
        lineStyle: {
          type: 'dashed',
          color: '#F8AF0B',
        },
        itemStyle: {
          color: '#F8AF0B',
        },
        data: data.predict,
      },
      {
        name: '',
        type: 'effectScatter',
        symbolSize: [8, 8],
        rippleEffect: {
          period: 15,
          scale: 10,
          brushType: 'stroke',
        },
        tooltip: {
          show: false,
        },
        itemStyle: {
          color: new echarts.graphic.RadialGradient(0.4, 0.3, 1, [
            {
              offset: 0,
              color: '#FFF21A',
            },
            {
              offset: 1,
              color: '#FFF21A',
            },
          ]),
        },
        z: 12,
        data: data.point,
      },
    ],
  };
};

柱状图

柱状图一

在这里插入图片描述

const getOption = (data) => {
  return {
    grid: {
      x: 40,
      y: 62,
      x2: 28,
      y2: 40,
    },
    tooltip: {
      axisPointer: {
        type: 'cross',
        crossStyle: {
          color: 'rgba(213,212,212,0.5)',
        },
      },
      backgroundColor: 'rgba(0,6,46,0.80)',
      borderColor: 'rgba(37,192,255,0.70)',
      textStyle: {
        color: '#3EB5FF',
        fontSize: '18',
      },
    },
    legend: {
      right: '15%',
      top: '11%',
      data: [
        {
          name: '交通指数',
          itemStyle: {
            color: '#00FFFF',
          },
          icon:
            'path://M512 139.81262864a286.42534744 286.42534744 0 1 0 286.42534744 286.42534744 286.42534744 286.42534744 0 0 0-286.42534744-286.42534744z m0 477.3755789a190.95023144 190.95023144 0 1 1 190.95023144-190.95023146 190.95023144 190.95023144 0 0 1-190.95023144 190.95023146z',
        },
        {
          name: '预测指数',
          itemStyle: {
            color: '#FFD300',
          },
          icon:
            'path://M512 139.81262864a286.42534744 286.42534744 0 1 0 286.42534744 286.42534744 286.42534744 286.42534744 0 0 0-286.42534744-286.42534744z m0 477.3755789a190.95023144 190.95023144 0 1 1 190.95023144-190.95023146 190.95023144 190.95023144 0 0 1-190.95023144 190.95023146z',
        },
      ],
      itemWidth: 15,
      itemHeight: 15,
      itemGap: 30,
      selectedMode: false, //选择
      textStyle: {
        color: '#F1F2FF',
      },
    },
    xAxis: [
      {
        type: 'category',
        data: data.x,
        axisPointer: {
          type: 'shadow',
        },
        axisLine: {
          show: true,
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
            width: 2,
          },
        },
        axisLabel: {
          show: true,
          color: '#F1F2FF',
          fontSize: 15,
          fontWeight: 500,
        },
      },
    ],
    yAxis: [
      {
        type: 'value',
        axisLine: {
          show: true,
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
            width: 2,
          },
        },
        axisLabel: {
          show: true,
          color: '#F1F2FF',
          fontSize: 15,
          fontWeight: 500,
        },
        splitLine: {
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
          },
        },
      },
      {
        type: 'value',
        axisLine: {
          show: true,
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
            width: 2,
          },
        },
      },
    ],
    series: [
      {
        name: '交通指数',
        type: 'bar',
        barWidth: '7px',
        itemStyle: {
          color: {
            type: 'linear',
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [
              {
                offset: 0,
                color: '#00FFFF', // 0% 处的颜色
              },
              {
                offset: 0.38,
                color: '#00D0FF', // 0% 处的颜色
              },
              {
                offset: 1,
                color: 'rgba(58,166,239,0)', // 100% 处的颜色
              },
            ],
            global: false, // 缺省为 false
          },
        },
        data: data.history,
      },
      {
        name: '预测指数',
        type: 'bar',
        barWidth: '7px',
        itemStyle: {
          color: {
            type: 'linear',
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [
              {
                offset: 0,
                color: '#FFD300', // 0% 处的颜色
              },
              {
                offset: 0.25,
                color: 'rgba(255, 189, 0, 0.7)', // 0% 处的颜色
              },
              {
                offset: 1,
                color: 'rgba(255,207,0,0)', // 100% 处的颜色
              },
            ],
            global: false, // 缺省为 false
          },
        },
        data: data.predict,
      },
      {
        name: 'blue',
        type: 'pictorialBar',
        symbol:
          'image://',
        symbolSize: [25, 25],
        symbolOffset: [-4, -12],
        z: 12,
        tooltip: {
          show: false,
        },
        data: data.blue,
      },
      {
        name: 'yellow',
        type: 'pictorialBar',
        symbol:
          'image://',
        symbolSize: [25, 25],
        symbolOffset: [4, -12],
        z: 12,
        tooltip: {
          show: false,
        },
        data: data.yellow,
      },
    ],
  };
};

柱状图二

在这里插入图片描述

const getOption = (data) => {
  return {
    grid: {
      x: 60,
      y: 40,
      x2: 25,
      y2: 25,
    },
    tooltip: {
      trigger: 'axis',
      axisPointer: {
        type: 'cross',
        crossStyle: {
          color: 'rgba(213,212,212,0.5)',
        },
      },
      backgroundColor: 'rgba(0,6,46,0.80)',
      borderColor: 'rgba(37,192,255,0.70)',
      formatter: function (params) {
        let color = ['#01C5FF', '#FFF21A'];
        let str =
          '<span style="font-size: 18px;color:#3EB5FF">' +
          params[0].axisValue +
          '</span>' +
          '<br />';
        params.forEach((item, index) => {
          str +=
            '<span style="display:inline-block;margin-right:5px;font-size: 18px;border-radius:50%;width:10px;height:10px;left:5px;background-color:' +
            color[index] +
            '"></span>' +
            '<span style="display:inline-block;margin: 0 0 0 5px;font-size: 18px;color:#3EB5FF;width: 80px">' +
            item.seriesName +
            ' : ' +
            '</span>' +
            '<span style="display:inline-block;margin-left:20px;font-size: 18px;color:#25FFE5">' +
            item.data +
            '</span>' +
            '<br />';
        });
        return str;
      },
    },
    legend: {
      right: '1.5%',
      top: '2%',
      data: [
        {
          name: '事件数量',
          itemStyle: {
            color: '#FFF21A',
          },
          icon:
            'path://M512 139.81262864a286.42534744 286.42534744 0 1 0 286.42534744 286.42534744 286.42534744 286.42534744 0 0 0-286.42534744-286.42534744z m0 477.3755789a190.95023144 190.95023144 0 1 1 190.95023144-190.95023146 190.95023144 190.95023144 0 0 1-190.95023144 190.95023146z',
        },
        {
          name: '上月同期',
          itemStyle: {
            color: '#01C5FF',
          },
          icon:
            'path://M512 139.81262864a286.42534744 286.42534744 0 1 0 286.42534744 286.42534744 286.42534744 286.42534744 0 0 0-286.42534744-286.42534744z m0 477.3755789a190.95023144 190.95023144 0 1 1 190.95023144-190.95023146 190.95023144 190.95023144 0 0 1-190.95023144 190.95023146z',
        },
      ],
      itemWidth: 15,
      itemHeight: 15,
      itemGap: 30,
      selectedMode: false, //选择
      textStyle: {
        color: '#F1F2FF',
      },
    },
    xAxis: [
      {
        type: 'category',
        data: data.x,
        axisPointer: {
          type: 'shadow',
        },
        axisLine: {
          show: true,
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
            width: 2,
          },
        },
        axisLabel: {
          show: true,
          color: '#F1F2FF',
          fontSize: 15,
          fontWeight: 500,
        },
      },
    ],
    yAxis: [
      {
        type: 'value',
        name: '单位:个',
        nameTextStyle: {
          color: '#F1F2FF',
          fontSize: '16',
        },
        axisLine: {
          show: true,
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
            width: 2,
          },
        },
        axisLabel: {
          show: true,
          color: '#F1F2FF',
          fontSize: 15,
          fontWeight: 500,
        },
        splitLine: {
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
          },
        },
      },
      {
        type: 'value',
        axisLine: {
          show: true,
          lineStyle: {
            color: 'rgba(89,126,178,0.7)',
            width: 2,
          },
        },
      },
    ],
    series: [
      {
        name: '上月同期',
        type: 'bar',
        barWidth: '7',
        itemStyle: {
          color: {
            type: 'linear',
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [
              {
                offset: 0,
                color: '#00EFFF', // 0% 处的颜色
              },
              {
                offset: 0.69,
                color: 'rgba(0, 225, 255, 0.61)', // 0% 处的颜色
              },
              {
                offset: 1,
                color: 'rgba(58,166,239,0)', // 100% 处的颜色
              },
            ],
            global: false, // 缺省为 false
          },
        },
        data: data.lastMonth,
      },
      {
        name: '事件数量',
        type: 'line',
        itemStyle: {
          color: '#FFF21A',
          shadowColor: 'rgba(223, 223, 67, 0.3)',
          shadowBlur: 7.5,
        },
        lineStyle: {
          color: '#FFF21A',
        },
        data: data.today,
      },
      {
        name: '',
        type: 'effectScatter',
        symbolSize: [7, 7],
        rippleEffect: {
          period: 4,
          scale: 4,
          brushType: 'fill',
        },
        tooltip: {
          show: false,
        },
        itemStyle: {
          color: new echarts.graphic.RadialGradient(0.4, 0.3, 1, [
            {
              offset: 0,
              color: '#FFF21A',
            },
            {
              offset: 1,
              color: '#1A1835',
            },
          ]),
        },
        data: data.today,
      },
    ],
  };
};

饼图

饼图一

在这里插入图片描述

const getOption = (list) => {
  return {
    title: [
      /*{
      text: list.total,
      top: '34%',
      textAlign: 'center',
      left: '47%',
      textStyle: {
        color: '#00FFB0',
        fontSize: 20,
        fontWeight: '500',
      },
    },*/
      {
        text: '人次',
        top: '51%',
        textAlign: 'center',
        left: '47%',
        textStyle: {
          color: '#FFFFFF',
          fontSize: 16,
          fontWeight: '500',
        },
      },
    ],
    series: [
      // 数据
      {
        //亮圆环
        type: 'pie',
        radius: ['65%', '71%'],
        center: ['50%', '50%'],
        data: [
          {
            value: 1,
            itemStyle: {
              color: 'rgba(0, 0, 0, 0)',
            },
            label: {
              show: false,
            },
          },
          {
            value: list.outProvince,
            itemStyle: {
              color: '#0BFBFD',
            },
            label: {
              show: false,
            },
          },
          {
            value: 1,
            itemStyle: {
              color: 'rgba(0, 0, 0, 0)',
            },
            label: {
              show: false,
            },
          },
          {
            hoverOffset: 1,
            value: list.inProvince,
            itemStyle: {
              color: '#FFB70F',
            },
            label: {
              show: false,
            },
            labelLine: {
              smooth: true,
              lineStyle: {
                width: 0,
              },
            },
            hoverAnimation: false,
          },
          {
            hoverOffset: 1,
            value: list.local,
            itemStyle: {
              color: '#0C97FE',
            },
            label: {
              show: false,
            },
            labelLine: {
              smooth: true,
              lineStyle: {
                width: 0,
              },
            },
            hoverAnimation: false,
          },
        ],
      },
      {
        // 内阴影
        type: 'pie',
        radius: ['50%', '65%'],
        center: ['50%', '50%'],
        data: [
          {
            value: 1,
            itemStyle: {
              color: 'rgba(0, 0, 0, 0)',
            },
            label: {
              show: false,
            },
          },
          {
            value: list.outProvince,
            itemStyle: {
              color: 'rgba(11,251,253,0.3)',
            },
            label: {
              show: false,
            },
          },
          {
            value: 1,
            itemStyle: {
              color: 'rgba(0, 0, 0, 0)',
            },
            label: {
              show: false,
            },
          },
          {
            hoverOffset: 1,
            value: list.inProvince,
            itemStyle: {
              color: 'rgba(255,183,15,0.3)',
            },
            label: {
              show: false,
            },
            labelLine: {
              smooth: true,
              length: 1,
              length2: 20,
            },
            hoverAnimation: false,
          },
          {
            hoverOffset: 1,
            value: list.local,
            itemStyle: {
              color: 'rgba(12,151,254,0.2)',
            },
            label: {
              show: false,
            },
            labelLine: {
              smooth: true,
              length: 1,
              length2: 20,
            },
            hoverAnimation: false,
          },
        ],
      },
      {
        name: '最外部进度条',
        type: 'gauge',
        radius: '80%',
        splitNumber: 10,
        axisLine: {
          lineStyle: {
            color: [
              [
                0.85,
                new echarts.graphic.LinearGradient(0, 0.5, 1, 0, [
                  {
                    offset: 0,
                    color: 'rgba(145,207,255,0)',
                  },
                  {
                    offset: 0.5,
                    color: 'rgba(145,207,255,0.2)',
                  },
                  {
                    offset: 1,
                    color: '#046F89',
                  },
                ]),
              ],
              [1, '#07204B'],
            ],
            width: 4,
          },
        },
        axisLabel: {
          show: false,
        },
        axisTick: {
          show: false,
        },
        splitLine: {
          show: false,
        },
        itemStyle: {
          show: false,
        },
        detail: {
          show: false,
        },
        title: {
          //标题
          show: false,
        },
        data: [
          {
            name: 'title',
            value: 4,
          },
        ],
        pointer: {
          show: false,
        },
        animationDuration: 4000,
      },
    ],
  };
};

饼图二

在这里插入图片描述

const getOption = (list) => {
  var data = list.woman;
  return {
    title: [
      {
        text: '人次',
        top: '50%',
        textAlign: 'center',
        left: '47%',
        textStyle: {
          color: '#FFFFFF',
          fontSize: 16,
          fontWeight: '500',
        },
      },
    ],
    series: [
      {
        type: 'pie',
        center: ['50%', '50%'],
        radius: ['68%', '80%'],
        emphasis: {
          scale: false,
        },
        startAngle: -180,
        clockwise: false,
        labelLine: {
          show: false,
        },
        data: [
          {
            name: '',
            value: data > 100 ? 100 : data,
            itemStyle: {
              color: '#05e28d',
            },
          },
        ],
      },
      {
        type: 'pie',
        center: ['50%', '50%'],
        radius: ['60%', '95%'],
        startAngle: -180,
        clockwise: false,
        labelLine: {
          show: false,
        },
        itemStyle: {
          color: 'rgba(0,0,0,0)',
        },
        emphasis: {
          scale: false,
          label: {
            borderColor: 'rgb(0, 2, 69)',
          },
        },
        data: [
          {
            name: '',
            value: data / 2,
          },
          {
            //画中间的图标
            name: '',
            value: 0,
            itemStyle: {
              color: '#fff',
            },
            label: {
              position: 'inside',
              formatter: function () {
                return '{a|女}';
              },
              rich: {
                a: {
                  color: '#fff',
                  fontSize: 16,
                  width: 25,
                  height: 25,
                  borderRadius: 21,
                  borderWidth: 4,
                  borderColor: 'rgb(0, 2, 69)',
                  fontWeight: 600,
                  backgroundColor: '#00CA34',
                },
              },
            },
          },
          {
            //画剩余的刻度圆环
            name: '',
            value: 100 - data / 2,
            itemStyle: {
              color: 'rgba(0,0,0,0)',
            },
            label: {
              show: false,
            },
          },
        ],
      },
      //男 半圆的线
      {
        type: 'pie',
        center: ['50%', '50%'],
        radius: ['65%', '85%'],
        emphasis: {
          scale: false,
        },
        startAngle: -180,
        clockwise: false,
        labelLine: {
          show: false,
        },
        data: [
          {
            name: '',
            value: data,
            itemStyle: {
              color: 'rgba(0,0,0,0)',
            },
          },
          {
            name: '',
            value: (100 - data) * 0.5,
            itemStyle: {
              color: '#00EAFF',
            },
          },
          {
            //画中间的图标
            name: '',
            value: 0,
            itemStyle: {
              color: 'rgba(0,0,0,0)',
            },
          },
          {
            //画剩余的刻度圆环
            name: '',
            value: 100 - data - (100 - data) * 0.5,
            itemStyle: {
              color: '#00EAFF',
            },
            label: {
              show: false,
            },
          },
        ],
      },
      //男 中心圆
      {
        type: 'pie',
        center: ['50%', '50%'],
        radius: ['78%', '85%'],
        emphasis: {
          scale: false,
        },
        startAngle: -180,
        clockwise: false,
        labelLine: {
          show: false,
        },
        z: 12,
        data: [
          {
            name: '',
            value: data,
            itemStyle: {
              color: 'rgba(0,0,0,0)',
            },
          },
          {
            name: '',
            value: (100 - data) * 0.5,
            itemStyle: {
              color: 'rgba(0,0,0,0)',
            },
          },
          {
            //画中间的图标
            name: '',
            value: 0,
            itemStyle: {
              color: '#fff',
            },
            label: {
              position: 'inside',
              fontWeight: 'normal',
              formatter: function () {
                return '{a|男}';
              },
              rich: {
                a: {
                  color: '#fff',
                  fontSize: 14,
                  width: 25,
                  height: 25,
                  borderRadius: 21,
                  fontWeight: 100,
                  borderWidth: 4,
                  borderColor: 'rgb(0 2 69)',
                  fontFamily: 'Microsoft YaHei',
                  // lineHeight:100,
                  backgroundColor: '#009EFF',
                },
              },
            },
          },
          {
            //画剩余的刻度圆环
            name: '',
            value: 100 - data - (100 - data) * 0.5,
            itemStyle: {
              color: 'rgba(0,0,0,0)',
            },
            label: {
              show: false,
            },
          },
        ],
      },
      //最外层
       {
         type: 'pie',
         clockwise: false,
         radius: ['89%', '92%'],
         emphasis: {
           scale: false,
         },
         silent: true,
         center: ['50%', '50%'],

         labelLine: { show: false },

         data: [
           {
             value: 1,
             itemStyle: {
               color: 'rgba(19,159,190,0.7)',
               shadowColor: 'rgba(19,159,190,0.7)',
               borderWidth: 2,
               borderColor: 'rgba(19,159,190,0.7)',
               shadowBlur: 5,
               borderRadius: 10,
             },
           },
           {
             value: 44,
             itemStyle: {
               color: 'rgba(19,159,190,0.3)',
             },
           },
           {
             value: 1,
             itemStyle: {
               color: 'rgba(19,159,190,0.7)',
               shadowColor: 'rgba(19,159,190,0.7)',
               borderWidth: 2,
               borderColor: 'rgba(19,159,190,0.7)',
               shadowBlur: 5,
               borderRadius: 10,
             },
           },
           {
             value: 44,
             itemStyle: {
               color: 'rgba(19,159,190,0.3)',
             },
           },
           {
             value: 1,
             itemStyle: {
               color: 'rgba(19,159,190,0.7)',
               shadowColor: 'rgba(19,159,190,0.7)',
               borderWidth: 2,
               borderColor: 'rgba(19,159,190,0.7)',
               shadowBlur: 5,
               borderRadius: 10,
             },
           },
           {
             value: 44,
             itemStyle: {
               color: 'rgba(19,159,190,0.3)',
             },
           },
           {
             value: 1,
             itemStyle: {
               color: 'rgba(19,159,190,0.7)',
               shadowColor: 'rgba(19,159,190,0.7)',
               borderWidth: 2,
               borderColor: 'rgba(19,159,190,0.7)',
               shadowBlur: 5,
               borderRadius: 10,
             },
           },
           {
             value: 44,
             itemStyle: {
               color: 'rgba(19,159,190,0.3)',
             },
           },
         ],
       },
    ],
  };
};

饼图三

在这里插入图片描述

const getOption = (data) => {
  return {
    title: [
      {
        text: '人次',
        top: '51%',
        textAlign: 'center',
        left: '47%',
        textStyle: {
          color: '#FFFFFF',
          fontSize: 16,
          fontWeight: '500',
        },
      },
    ],
    series: [
      {
        name: '半径模式',
        type: 'pie',
        radius: ['45%', '80%'],
        center: ['50%', '50%'],
        roseType: 'radius',
        label: {
          show: false,
        },
        labelLine: {
          length: 1,
          length2: 20,
          smooth: true,
        },
        data: [
          {
            value: data.low,
            name: 'social',
            itemStyle: {
              color: '#03FFFF',
              borderWidth: 3,
            },
          },
          {
            value: data.middle,
            name: 'shopping',
            itemStyle: {
              color: '#00FFA4',
              borderWidth: 3,
            },
          },
          {
            value: data.high,
            name: 'reading',
            itemStyle: {
              color: '#0097FF',
              borderWidth: 3,
            },
          },
        ],
      },
    ],
  };
};

其他

树状

在这里插入图片描述

const getOption = (data) => {
  return {
    grid: {
      left: '5%',
      right: '5%',
      bottom: '0',
      top: '20%',
      containLabel: true,
    },
    xAxis: {
      data: data.xdata,
      triggerEvent: true,
      axisTick: {
        show: false,
      },
      axisLine: {
        show: false,
      },
      axisLabel: {
        show: true,
        rotate: -30,
        color: '#F1F2FF',
      },
    },
    yAxis: {
      name: '',
      nameTextStyle: {
        show: false,
      },
      splitLine: {
        show: false,
      },
      axisTick: {
        show: false,
      },
      axisLine: {
        show: false,
      },
      axisLabel: {
        show: false,
      },
    },
    series: [
      {
        name: 'hill',
        barMinHeight: 10,
        type: 'pictorialBar',
        barCategoryGap: '-80%',
        symbol: 'path://M0,10 L10,10 C5.5,10 5.5,5 5,0 C4.5,5 4.5,10 0,10 z',
        itemStyle: {
          //color: 'rgba(98,114,255,0.8)',
          color: function (params) {
            let colorList = [
              'rgba(98,114,255,0.6)',
              'rgba(98,114,255,0.8)',
              'rgba(98,114,255,0.6)',
              'rgba(98,114,255,0.8)',
              'rgba(98,114,255,0.6)',
            ];
            return colorList[params.dataIndex];
          },
        },
        label: {
          formatter: '{@score}%',
          show: true,
          position: 'top',
          color: '#00FFB0',
          fontSize: 20,
        },
        data: data.data,
      },
    ],
  };
};

水球

在这里插入图片描述
此处注意echart5.0以上版本需额外引入 import ‘echarts-liquidfill’;

const getOption = () => {
  return {
    series: [
      {
        type: 'liquidFill',
        name: '',
        radius: '85%',
        center: ['50%', '45%'],
        data: [0.55, 0.5, 0.5],
        color: ['rgba(0,118,255,0.5)', 'rgba(0,102,255,0.5)', 'rgba(0,185,255,0.6)'],
        outline: {
          show: false,
        },
        backgroundStyle: {
          color: 'transparent',
          borderColor: 'transparent',
          borderWidth: 1,
          shadowColor: 'transparent',
          shadowBlur: 0,
        },
        label: {
          show: false,
        },
      },
    ],
  };
};
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值