これを読んだ後、円グラフに画像を挿入するのはとても簡単であることがわかりました。

1. このケースは Vue3+ts に基づいており、効果が表示されます。

2. 単一の属性の値:

series.radius: [ ' パーセント ' , ' パーセント ' ]

最初の値はデバイスの内側の円のサイズを設定し、2 番目の値は外側の円のサイズを設定します。

2 つの値を組み合わせると円の太さを設定できます

シリーズ.センター: [ ' パーセント ' 、 ' パーセント ' ]

最初の値は水平位置を調整し、2 番目の値は垂直位置を調整します

グラフィック 円グラフの中央に画像を挿入します

  要素: [

        {

          タイプ: '画像',

          スタイル: {

            画像: 「base64 形式の画像」、

           //画像サイズを設定

            幅: 50、

            身長: 50、

          }、

          // 位置を調整する

          左: '39.5%'、

          トップ: '46.5%'、

        }、

      ]、

画像を Base64 に変換するオンライン ツール:

画像から BASE64 エンコード | 新人ツール

3. 完全なコードは次のとおりです。

<template>
	<div class="container" ref="echartsRef" @resize="onResize"></div>
</template>
<script setup lang="ts" name="highTemperature-pie">
import { ref, onMounted } from 'vue';
import * as echarts from 'echarts';

const echartsRef = ref();
let myChart: any = null; // echarts实例对象

onMounted(() => {
	initCharts();
});

// 变化尺寸
const onResize = (resize: any) => {
	console.log('resize: ', resize);
	myChart && myChart.resize();
};
window.addEventListener('resize', onResize);

const initCharts = () => {
	const eChartsData = [
		{
			name: '正常',
			value: 87,
		},
		{
			name: '异常',
			value: 13,
		},
	];
	// 中间图片必须是base64格式
	const giftImageUrl =
		'';
	let option = {
		color: ['#FFF500', '#00FFFF'],
		// 中间图片
		graphic: {
			elements: [
				{
					type: 'image',
					style: {
						image: giftImageUrl,
						width: 50,
						height: 50,
					},
					left: '39.5%',
					top: '46.5%',
				},
			],
		},
		tooltip: {
			show: false,
		},
		legend: {
			icon: 'rect',
			itemWidth: 12, // 图例标记的图形宽度。[ default: 25 ]
			itemHeight: 12, // 图例标记的图形高度。[ default: 14 ]
			// itemGap: 5, // 图例每项之间的间隔。[ default: 10 ]横向布局时为水平间隔,纵向布局时为纵向间隔。
			textStyle: {
				fontSize: 14,
				color: '#D3D3D3',
			},
			formatter(name: any) {
				let res = eChartsData.filter((v) => v.name === name);
				return res[0].name + ' : ' + res[0].value + '%';
			},
		},
		series: [
			{
				type: 'pie',
				name: '内层细圆环1',
				radius: ['38%', '38%'], // 调整圆的大小
				center: ['50%', '60%'], // 调整圆的位置
				hoverAnimation: false,
				clockWise: false,
				itemStyle: {
					normal: {
						borderColor: '#284c5a',
						borderWidth: 3,
					},
				},
				label: {
					show: false,
				},
				data: [100],
			},
			{
				type: 'pie',
				name: '最外层细圆环',
				hoverAnimation: false,
				clockWise: false,
				radius: ['75%', '75%'],
				center: ['50%', '60%'],
				itemStyle: {
					normal: {
						borderColor: 'rgba(50, 74, 91, 1)',
						borderWidth: 3,
					},
				},
				label: {
					show: false,
				},
				data: [100],
			},
			{
				name: '饼图内容区',
				type: 'pie',
				clockWise: false,
				radius: ['50%', '65%'],
				center: ['50%', '60%'],
				data: eChartsData,
				label: {
					show: false,
				},
				itemStyle: {
					borderWidth: 5,
					borderColor: '#0e1e27',
				},
			},
		],
	};

	myChart = echarts.init(echartsRef.value as HTMLDivElement);
	myChart.setOption(option, true);
};
</script>
<style lang="scss" scoped>
.container {
	width: 100%;
	height: 100%;
}
</style>

おすすめ

転載: blog.csdn.net/weixin_48082900/article/details/134026848