首页 前端知识 echarts饼图 扇形添加间隔 内嵌图形 富文本引导文字

echarts饼图 扇形添加间隔 内嵌图形 富文本引导文字

2024-02-26 20:02:32 前端知识 前端哥 301 228 我要收藏

大部分功能是echarts社区大佬写的,地址https://www.makeapie.cn/echarts_content/xmQZRm2IHw.html

下面是自己的一些学习理解,效果:

 

1.添加间隔

for (var i = 0; i < trafficWay.length; i++) {
        data.push(
          {
            value: trafficWay[i].value,
            name: trafficWay[i].name,
            itemStyle: {
              normal: {
                
                borderWidth: 2,
                borderColor: bgColor[i],
                color: color[i],
              },
            },
          },
          {
            value: 1,//数值控制间隔大小
            name: "",
            itemStyle: {
              normal: {
                color: "rgba(0, 0, 0, 0)",//均为透明颜色
                borderColor: "rgba(0, 0, 0, 0)",
                borderWidth: 0,
              },
            },
          }
        );
      }

间隔的大多数方案是统过与背景图一样的边框颜色来达成,但如果要求扇形有其他边框颜色或者背景色不是纯色,效果就无法实现。大佬是通过给每一个要呈现的扇形添加一个透明的扇形来达成,适用场景更广!

2.内嵌图形

var img =""//base64编码值
graphic: {
          elements: [
            {
              type: "image",
              z: 3,
              style: {
                image: img,
                width: 108,
                height: 108,
              },
              left: "center",
              top: "center",
              position: [100, 100],
            },
          ],
        },

可以使用菜鸟编码工具https://c.runoob.com/front-end/59/

3.富文本引导文字

formatter: function (params) {
                  if (params.name) {
                    return `{a|${params.value}}\n {b|${params.name}}`
                  }
                },
                rich:{
                    a:{color:'#d9e289',
                    fontSize:22
                },
                    b:{color:'white',
                    fontSize:14}
                }

根据官方文档做的引导线文字样式,formatter可以自定义文字内容,rich自定义文字样式

官方文档地址:https://echarts.apache.org/zh/option.html#series-pie.label.formatter

全部代码

<template>
  <div class="contain">
    <div style="width: 100%; height: 100%" ref="echarts"></div>
  </div>
</template>
    
    <script>
import * as echarts from "echarts";
export default {
  data() {
    return {};
  },
  props: ["aName", "aValue"],
  mounted() {
    this.test();
  },
  methods: {
    test() {
      var myChart = echarts.init(this.$refs.echarts);
      var option;
      var img =
        "";

      var trafficWay = [
        {
          name: "火车",
          value: 20,
        },
        {
          name: "飞机",
          value: 10,
        },
        {
          name: "客车",
          value: 30,
        },
      ];

      var data = [];
      var color = ["#06bb7b", "#2aaec0", "#b9a671"];
      let bgColor = ["#01e991", "#2ecfe2", "#e6cb84"];
      for (var i = 0; i < trafficWay.length; i++) {
        data.push(
          {
            value: trafficWay[i].value,
            name: trafficWay[i].name,
            itemStyle: {
              normal: {
                
                borderWidth: 2,
                borderColor: bgColor[i],
                color: color[i],
              },
            },
          },
          {
            value: 1,//数值控制间隔大小
            name: "",
            itemStyle: {
              normal: {
                color: "rgba(0, 0, 0, 0)",//均为透明颜色
                borderColor: "rgba(0, 0, 0, 0)",
                borderWidth: 0,
              },
            },
          }
        );
      }
      var seriesOption = [
        {
          name: "",
          type: "pie",
          clockWise: false,
          radius: [65, 75],
          hoverAnimation: false,
          itemStyle: {
            normal: {
              label: {
                show: true,
                position: "outside",
                color: "#ddd",
                textStyle: {
                    color: 'white', // 文字颜色
                    fontSize: 14 // 文字大小
                },
                formatter: function (params) {
                  if (params.name) {
                    return `{a|${params.value}}\n {b|${params.name}}`
                  }
                },
                rich:{
                    a:{color:'#d9e289',
                    fontSize:22
                },
                    b:{color:'white',
                    fontSize:14}
                }
              },
                labelLine: {
                  show: true,
                  length:40,
                  length2:20,
                },
            },
          },
          data: data,
        },
      ];
      option = {
        color: color,

        graphic: {
          elements: [
            {
              type: "image",
              z: 3,
              style: {
                image: img,
                width: 108,
                height: 108,
              },
              left: "center",
              top: "center",
              position: [100, 100],
            },
          ],
        },
        tooltip: {
          show: false,
        },

        toolbox: {
          show: false,
        },
        series: seriesOption,
      };

      option && myChart.setOption(option);
    },
  },
};
</script>
    
    <style>
</style>
    

转载请注明出处或者链接地址:https://www.qianduange.cn//article/2760.html
标签
评论
会员中心 联系我 留言建议 回顶部
复制成功!