当前位置: 首页 > news >正文

vue---echarts环形图

1、完整代码直接可以cv 

<template><div id="main1"></div>
</template><script>
import * as echarts from 'echarts';
// import { mapState } from 'vuex';
// import { Alarm_Device } from '../utils/api.js';
export default {name: 'PieChart',data() {return {chart: null,data: [{ value: 1048, name: '人体探测器', itemStyle: { color: '#4f7ff7' } },{ value: 262, name: '生命体征探测器', itemStyle: { color: '#be71f2' } },{ value: 210, name: '防摔倒探测器', itemStyle: { color: '#7586f5' } },{ value: 140, name: '智能床垫', itemStyle: { color: '#6ee497' } },{ value: 90, name: '智能手表', itemStyle: { color: '#4ebfff' } }]};},computed: {// ...mapState(['login']),},mounted() {this.initChart();this.registerUser()},beforeDestroy() {if (this.chart) {this.chart.dispose();}},methods: {getItemStyleByName(name) {// 根据设备名称返回对应的颜色const colorMap = {'人体探测器': '#4f7ff7','生命体征探测器': '#be71f2','防摔倒探测器': '#7586f5','智能床垫': '#6ee497','智能手表': '#4ebfff'};return { color: colorMap[name] || '#ffffff' }; // 如果名称未找到,则默认为白色},initChart() {const chartDom = document.getElementById('main1');this.chart = echarts.init(chartDom);const options = this.getChartOptions();this.chart.setOption(options);},getChartOptions() {const total = this.data.reduce((sum, item) => sum + item.value, 0);const dataWithPercentage = this.data.map(item => ({value: item.value,name: item.name,percentage: `${(item.value / total * 100).toFixed(1)}%`,itemStyle: item.itemStyle}));return {title: {text: '总数量',subtext: '100%',left: 'center',top: '40%',left: '29%',textAlign: 'center',textStyle: {fontSize: 18,fontWeight: 'bold',color: '#ffffff'},subtextStyle: {fontSize: 17,color: '#ffffff'}},legend: {orient: 'vertical',right: '16%',top: 'center',textStyle: {color: '#fff',  // 图例文字颜色fontSize: 12,   // 图例文字大小},formatter: (name) => {const item = dataWithPercentage.find(d => d.name === name);return item ? `${item.name} ${item.percentage}` : name;},},tooltip: {trigger: 'item',},label: {show: true,color: '#fff',  // 设置文字颜色为白色position: 'outside',formatter: ({ data }) => `${data.percentage}` // 只显示百分比},emphasis: {label: {show: true,fontSize: 20,fontWeight: 'bold',color: '#fff'  // 确保在强调状态下文字依然为白色},},labelLine: {show: true,lineStyle: {color: '#fff'  // 设置指引线的颜色为白色}},series: [{name: '',type: 'pie',radius: ['40%', '70%'],center: ['30%', '50%'], // 将中心位置设置为垂直和水平的中点data: dataWithPercentage,// 移除startAngle和endAngle,以显示完整的圆形},],};},},
};
</script><style scoped>
#main1 {width: 560px;height: 180px;
}
</style>

 2、初始化

initChart() {// 获取 DOM 元素,通过其 ID 获取到的元素将作为 ECharts 实例的容器const chartDom = document.getElementById('main1');// 初始化 ECharts 实例,传入上面获取的 DOM 元素this.chart = echarts.init(chartDom);// 获取图表的配置项,这些配置项用于定义图表的类型、数据、样式等const options = this.getChartOptions();// 设置图表的配置项// 这一步将配置项应用到 ECharts 实例中,渲染出图表this.chart.setOption(options);
}

 所有的基本上都是先获取容器盒子,然后初始化echarts,最后配置options

 3、配置解释

getChartOptions() {// 计算数据总量,用于计算百分比const total = this.data.reduce((sum, item) => sum + item.value, 0);// 为每个数据项计算百分比,并保留原有的 itemStyleconst dataWithPercentage = this.data.map(item => ({value: item.value,name: item.name,percentage: `${(item.value / total * 100).toFixed(1)}%`, // 计算并格式化百分比itemStyle: item.itemStyle // 保留原有的样式}));return {// 图表标题配置title: {text: '总数量', // 主标题文本subtext: '100%', // 副标题文本left: 'center', // 主标题水平居中top: '40%', // 主标题垂直位置left: '29%', // 主标题水平位置textAlign: 'center', // 主标题文本对齐方式textStyle: {fontSize: 18, // 主标题字体大小fontWeight: 'bold', // 主标题字体粗细color: '#ffffff' // 主标题字体颜色},subtextStyle: {fontSize: 17, // 副标题字体大小color: '#ffffff' // 副标题字体颜色}},// 图例配置legend: {orient: 'vertical', // 图例垂直排列right: '16%', // 图例水平位置top: 'center', // 图例垂直居中textStyle: {color: '#fff',  // 图例文字颜色fontSize: 12,   // 图例文字大小},// 格式化图例文字,显示名称和百分比formatter: (name) => {const item = dataWithPercentage.find(d => d.name === name);return item ? `${item.name} ${item.percentage}` : name;},},// 提示框配置tooltip: {trigger: 'item', // 鼠标悬停在项上触发提示框},// 标签配置label: {show: true, // 显示标签color: '#fff',  // 标签文字颜色position: 'outside', // 标签位置在图形外部formatter: ({ data }) => `${data.percentage}` // 标签只显示百分比},// 高亮显示配置emphasis: {label: {show: true, // 高亮时显示标签fontSize: 20, // 高亮时标签字体大小fontWeight: 'bold', // 高亮时标签字体粗细color: '#fff'  // 高亮时标签字体颜色},},// 标签线配置labelLine: {show: true, // 显示标签线lineStyle: {color: '#fff'  // 标签线颜色}},// 系列数据配置series: [{name: '', // 系列名称type: 'pie', // 图表类型为饼图radius: ['40%', '70%'], // 饼图的半径范围,内环到外环center: ['30%', '50%'], // 饼图中心位置,水平和垂直的百分比位置data: dataWithPercentage, // 使用带有百分比的数据// 移除 startAngle 和 endAngle 使饼图显示完整的圆形},],};
}

相关文章:

vue---echarts环形图

1、完整代码直接可以cv <template><div id"main1"></div> </template><script> import * as echarts from echarts; // import { mapState } from vuex; // import { Alarm_Device } from ../utils/api.js; export default {name: P…...

克服编程挫折:从Bug的迷宫中寻找出口与面对算法保持冷静的策略

在编程学习的道路上&#xff0c;挫折感无疑是每个学习者都必须面对的挑战之一。它们仿佛是一座座高墙&#xff0c;阻挡我们前进的步伐。然而&#xff0c;正如许多有经验的编程高手所证明的那样&#xff0c;挫折并不是终点&#xff0c;而是成长和进步的催化剂。本文将分享一些有…...

Flink之SQL client使用案例

Flink的执行模式有以下三种: 前提是我们已经开启了yarnsession的进程&#xff0c;在下图中可以看到启动的id也就是后续任务需要通过此id进行认证&#xff0c;以及任务分配的master主机。 这里启动时候会报错一个ERROR&#xff1a;org.apache.flink.shaded.curator.org.apache…...

实际开发中的模块化开发 - 应用到直播间

实际开发中的模块化开发 - 模块管理&#xff08;以直播间为例&#xff09;-CSDN博客 引言 在前面的两篇博客中&#xff0c;我们已经介绍了直播模块的简单结构&#xff0c;创建了模块管理器和模块抽象基类&#xff0c;并且通过模块化实现了两个小业务功能模块。接下来&#xf…...

EmguCV学习笔记 VB.Net 第5章 图像变换

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 EmguCV是一个基于OpenCV的开源免费的跨平台计算机视觉库,它向C#和VB.NET开发者提供了OpenCV库的大部分功能。 教程VB.net版本请访…...

【初阶数据结构】顺序表与链表的比较(附题)

目录 一、顺序表和链表的区别&#xff08;其他链表存在缺陷&#xff0c;比较意义不大&#xff0c;这里用带头双向循环链表与顺序表进行比较&#xff09; 1.1插入、扩容与随机访问 二、缓存利用率的比较 2.1前置知识 详解及补充知识&#xff08;本文仅为比较顺序表及链表&am…...

git-20240822

目录 初始化仓库 Git init Git init project --bare 查看提交的记录 git log --prettyoneline 查看当前git远程库地址 git remote -v 查看详细提交记录 git log 撤出暂存区的文件 git reset HEAD file(.代表全部文件&#xff09; 提交数据到远程仓库 git config --global push.…...

【时时三省】c语言例题----华为机试题< 数字颠倒>

目录 1,题目 描述 输入描述: 输出描述: 示例1 2,代码...

【前缀和算法】--- 一维和二维前缀和模板

Welcome to 9ilks Code World (๑•́ ₃ •̀๑) 个人主页: 9ilk (๑•́ ₃ •̀๑) 文章专栏&#xff1a; 算法Journey 本文开始,博主开始讲解有关前缀和的算法&#xff0c;本篇博客我们先来了解一下有关前缀和的两个模板。 &#x1f3e0; 一维前缀和模板 &…...

有些信息注定会丢失

智能在分析问题、做出决策时&#xff0c;总是希望获取尽可能多的信息&#xff0c;以此更加准确地决策。然而&#xff0c;很遗憾的是&#xff0c;有一些信息注定会丢失&#xff0c;不可能获取完全的信息&#xff0c;而且即使能够获取&#xff0c;智能也不能完全利用。 这一点与…...

c#中Task.Run 和使用 Task 构造函数创建任务的区别

Task.Run 和使用 Task 构造函数创建任务是两种不同的方法&#xff0c;它们在某些方面有显著的区别&#xff1a; 启动方式: Task.Run 是一个静态方法&#xff0c;它立即启动一个任务并在后台执行指定的工作。它通常用于快速启动一个简单的后台任务。使用 Task 构造函数创建任务&…...

使用nginx做代理转发

需求1&#xff1a;通过监听服务器的80端口&#xff0c;将请求转发到另一台服务器的8070端口 打开nginx/nginx.conf文件 server {listen 80;server_name localhost;location /analys {proxy_pass http://10.xx.xx.xx:8070/;} }需求2&#xff1a;通过监听服务器的80端口&am…...

Java前端与后端交互:JSON与XML数据交换 - 掌握现代Web开发的核心技能

引言 随着互联网技术的不断进步&#xff0c;Web应用变得越来越复杂&#xff0c;从前端到后端的每一个环节都需要精心设计以保证良好的用户体验。在这个过程中&#xff0c;数据的传递扮演着至关重要的角色。无论是简单的表单提交还是复杂的API调用&#xff0c;都需要一种可靠的…...

网络攻击原理及过程

网络攻击原理表 攻击者 内容 攻击访问 攻击效果 攻击意图 黑客 挑战 间谍 用户命令 破坏信息 好奇 恐怖主义者 脚本或程序 本地访问 信息泄密 获取情报 公司职员 自治主体 远程访问 窃取服务 经济利益 职业犯罪分子 电磁泄露 拒绝服务 恐怖事…...

day30(8/16)——ansible

目录 一、回顾 1、mysql和python 1. mysql5.7 2. 可以使用pymysql非交互的管理mysql 2、mycat中间件 1. 独属于mysql主从的负载均衡策略 2.配置写主读从 3. 步骤 3.1 安装jdk 3.2 mycat 3.3 配置 3.4 启动和调试 二、运维自动化&#xff08;ansible&#xff09; 1、任务背…...

fastadmin 安装

环境要求&#xff0c;大家可以参考官方文档的&#xff0c;我这里使用的是phpstudy&#xff0c;很多已经集成了。 注意一点&#xff0c;PHP 版本&#xff1a;PHP 7.4 。 第二步&#xff1a;下载 下载地址&#xff1a;https://www.fastadmin.net/download.html 进入下载地址后…...

Unity动画模块 之 3D模型导入基础设置 Rig页签

​本文仅作笔记学习和分享&#xff0c;不用做任何商业用途本文包括但不限于unity官方手册&#xff0c;unity唐老狮等教程知识&#xff0c;如有不足还请斧正​​ 1.Rig页签 Rig 选项卡 - Unity 手册&#xff0c;rig是设置骨骼与替身系统的&#xff0c;工作流程如下 Avatar是什么…...

⭐️Python在Windows命令行(Command Prompt)运行Python脚本或交互式地执行Python代码详解

Python在Windows命令行&#xff08;Command Prompt&#xff09;运行Python脚本或交互式地执行Python代码详解 Python在Windows命令行&#xff08;Command Prompt&#xff09;运行Python脚本或交互式地执行Python代码详解一、安装Python二、运行Python脚本1. 打开命令行2. 导航到…...

Python | Leetcode Python题解之第355题设计推特

题目&#xff1a; 题解&#xff1a; class Twitter:class Node:def __init__(self):self.followee set()self.tweet list()def __init__(self):self.time 0self.recentMax 10self.tweetTime dict()self.user dict()def postTweet(self, userId: int, tweetId: int) ->…...

D. Beard Graph

https://codeforces.com/problemset/problem/165/D 主要是边转点 后面都是简单的线段树维护 我们维护ok标记,val值&#xff0c;黑&#xff08;1),白&#xff08;0&#xff09; id.okl.ok&r.ok id.vall.valr.val 注意特判如果两个点一样是0,如果dfn[u]1>dfn[v]就不…...

【kafka】Golang实现分布式Masscan任务调度系统

要求&#xff1a; 输出两个程序&#xff0c;一个命令行程序&#xff08;命令行参数用flag&#xff09;和一个服务端程序。 命令行程序支持通过命令行参数配置下发IP或IP段、端口、扫描带宽&#xff0c;然后将消息推送到kafka里面。 服务端程序&#xff1a; 从kafka消费者接收…...

java_网络服务相关_gateway_nacos_feign区别联系

1. spring-cloud-starter-gateway 作用&#xff1a;作为微服务架构的网关&#xff0c;统一入口&#xff0c;处理所有外部请求。 核心能力&#xff1a; 路由转发&#xff08;基于路径、服务名等&#xff09;过滤器&#xff08;鉴权、限流、日志、Header 处理&#xff09;支持负…...

java 实现excel文件转pdf | 无水印 | 无限制

文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...

【位运算】消失的两个数字(hard)

消失的两个数字&#xff08;hard&#xff09; 题⽬描述&#xff1a;解法&#xff08;位运算&#xff09;&#xff1a;Java 算法代码&#xff1a;更简便代码 题⽬链接&#xff1a;⾯试题 17.19. 消失的两个数字 题⽬描述&#xff1a; 给定⼀个数组&#xff0c;包含从 1 到 N 所有…...

UE5 学习系列(三)创建和移动物体

这篇博客是该系列的第三篇&#xff0c;是在之前两篇博客的基础上展开&#xff0c;主要介绍如何在操作界面中创建和拖动物体&#xff0c;这篇博客跟随的视频链接如下&#xff1a; B 站视频&#xff1a;s03-创建和移动物体 如果你不打算开之前的博客并且对UE5 比较熟的话按照以…...

全球首个30米分辨率湿地数据集(2000—2022)

数据简介 今天我们分享的数据是全球30米分辨率湿地数据集&#xff0c;包含8种湿地亚类&#xff0c;该数据以0.5X0.5的瓦片存储&#xff0c;我们整理了所有属于中国的瓦片名称与其对应省份&#xff0c;方便大家研究使用。 该数据集作为全球首个30米分辨率、覆盖2000–2022年时间…...

【HTML-16】深入理解HTML中的块元素与行内元素

HTML元素根据其显示特性可以分为两大类&#xff1a;块元素(Block-level Elements)和行内元素(Inline Elements)。理解这两者的区别对于构建良好的网页布局至关重要。本文将全面解析这两种元素的特性、区别以及实际应用场景。 1. 块元素(Block-level Elements) 1.1 基本特性 …...

SAP学习笔记 - 开发26 - 前端Fiori开发 OData V2 和 V4 的差异 (Deepseek整理)

上一章用到了V2 的概念&#xff0c;其实 Fiori当中还有 V4&#xff0c;咱们这一章来总结一下 V2 和 V4。 SAP学习笔记 - 开发25 - 前端Fiori开发 Remote OData Service(使用远端Odata服务)&#xff0c;代理中间件&#xff08;ui5-middleware-simpleproxy&#xff09;-CSDN博客…...

短视频矩阵系统文案创作功能开发实践,定制化开发

在短视频行业迅猛发展的当下&#xff0c;企业和个人创作者为了扩大影响力、提升传播效果&#xff0c;纷纷采用短视频矩阵运营策略&#xff0c;同时管理多个平台、多个账号的内容发布。然而&#xff0c;频繁的文案创作需求让运营者疲于应对&#xff0c;如何高效产出高质量文案成…...

Python基于历史模拟方法实现投资组合风险管理的VaR与ES模型项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档&#xff09;&#xff0c;如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 在金融市场日益复杂和波动加剧的背景下&#xff0c;风险管理成为金融机构和个人投资者关注的核心议题之一。VaR&…...