大部分功能是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>