Ant Design Charts 仪表盘配置属性结合案例详细说明_ant design charts仪表盘-程序员宅基地

技术标签: 工作记录  echarts  reactjs  javascript  

本次案例为仪表板,最终成品样式如下,案例种用到仪表盘分大部分属性,每个属性都注释说明作用。成品效果如下

 使用方法如下

import { Gauge, G2 } from "@ant-design/plots";

const { registerShape, Util } = G2; 

// 自定义指针 Shape 部分 在下面 indicator.shape 中使用,如不需要可删除下面的  indicator.shape 和 registerShape 函数。

  registerShape("point", "custom-gauge-indicator", {
    draw(cfg, container) {
      // 使用 customInfo 传递参数
      const { indicator, defaultColor } = cfg.customInfo;
      const { pointer, pin } = indicator;

      const group = container.addGroup();
      // 获取极坐标系下画布中心点
      const center = this.parsePoint({ x: 0, y: 0 });
      console.log(center);
      // 设置 pin 指针的圆盘的样式
      if (pin) {
        // 直接使用配置里面的pin样式
        group.addShape("circle", {
          name: "pin-outer",
          attrs: {
            x: center.x,
            y: center.y,
            ...pin.style,
          },
        });
      }
      // 绘制指针
      if (pointer) {
        const { startAngle, endAngle } = Util.getAngle(cfg, this.coordinate);
        const radius = this.coordinate.getRadius();
        const midAngle = (startAngle + endAngle) / 2;
        const { x: x1, y: y1 } = Util.polarToCartesian(
          center.x,
          center.y,
          radius / 15,
          midAngle + 1 / Math.PI
        );
        const { x: x2, y: y2 } = Util.polarToCartesian(
          center.x,
          center.y,
          radius / 15,
          midAngle - 1 / Math.PI
        );
        const { x, y } = Util.polarToCartesian(
          center.x,
          center.y,
          radius * 0.5,
          midAngle
        );
        const { x: x0, y: y0 } = Util.polarToCartesian(
          center.x,
          center.y,
          radius * 0.1,
          midAngle + Math.PI
        );
        const sa = Math.PI / 3 + midAngle;
        const r1 = 3.5;
        const p1 = {
          x: center.x + Math.cos(sa) * r1,
          y: center.y + Math.sin(sa) * r1,
        };
        const p2 = {
          x: center.x - Math.cos(sa) * r1,
          y: center.y - Math.sin(sa) * r1,
        };
        const r2 = r1 / 4;
        const p11 = {
          x: x + Math.cos(sa) * r2,
          y: y + Math.sin(sa) * r2,
        };
        const p21 = {
          x: x - Math.cos(sa) * r2,
          y: y - Math.sin(sa) * r2,
        };

        const path = [
          ["M", p21.x, p21.y],
          // 参数信息: cx, cy, .., .., .., endPointX, endPointY
          ["A", r2, r2, 0, 0, 1, p11.x, p11.y],
          ["L", p1.x, p1.y],
          ["A", r1, r1, 0, 0, 1, p2.x, p2.y],
          ["Z"],
        ];
        // pointer
        group.addShape("path", {
          name: "pointer",
          attrs: {
            path,
            fill: "#9155FD",
            ...pointer.style,
          },
        });
      }
      return group;
    },
  });

// 配置部分
const config = {
    // 设置图表的宽度和高度,如果不设置默认与容器大小一致画布,等同于设置了autoFit:true 效果
    with: 90,
    hight: 90,
    // 设置图表在画布的位置 可设置单个数字,也可以设置 [数字,数字,数字,数字] 控制4个方向。不加这个属性默认等于 auto
    // padding: "auto",

    // 当前仪表盘指针位置 值范围为 0 - 1
    percent: 0.33,
    // 仪表盘圆弧外环的半径 值得范围为 0 - 1
    radius: 0.9,

    // innerRadius 仪表盘圆弧内环的半径 值范围为 0 -1。
    //  外环和内环选一个配置即可,剩下可以配置圆弧宽度。
    // innerRadius: 0.8,

    // 调整仪表盘的开始位置 此处配置为半圆
    startAngle: Math.PI,
    //调整仪表盘的结束位置
    endAngle: 2 * Math.PI,
    // 图标渲染方式  canvas / svg 不设置默认为canvas 注意点:设置为svg后会影响到下面 gaugeStyle.lineCap 倒角的方向
    // renderer: "svg",
    // range 仪表盘的圆弧样式控制
    range: {
      // 控制仪表盘分色,此处分为3种颜色,各占3分之一
      ticks: [1 / 3, 3 / 4, 1],
      // 每个分区对应颜色
      color: ["#9155FD", "#C3ACF9", "#f4f5fa"],
      // 仪表板圆弧宽度默认单位为px
      width: 9,
    },
    // axis 仪表盘的刻度轴的配置
    axis: {
      // tickLine 为null 表示不显示刻度线
      tickLine: null,
      // label 为null 表示不显示刻度文字
      label: null,
    },

    //indicator 指针样式配置 null为不展示指针
    indicator: {
      // 自定义指针
      shape: "custom-gauge-indicator",
      // 配置指针样式,不包括圆盘
      pointer: {
        style: {
          stroke: "#9155FD",
          lineCap: "round",
          lineWidth: 4,
        },
      },
      // 配置指针连接的圆盘样式
      pin: {
        style: {
          // 指针边框颜色
          stroke: "#9155FD",
          // 指针圆盘半径
          r: 4.5,
          // 指针圆盘中间填充颜色
          fill: "#9155FD",
        },
      },
    },
    // 仪表盘的样式
    gaugeStyle: {
      // 圆弧内每段占比结束都进行倒角,包含仪表盘起始位置和结束位置都进行倒角
      lineCap: "round",
      // 圆弧外描边虚线
      lineDash: [2, 3],
      // 圆弧外描边虚线宽度
      lineWidth: 0.6,
      // 圆弧外描边颜色
      stroke: "#c0aaf6",
    },
  };


// 最终使用
   <Gauge {...config} />



更多详细属性描述,请前往 仪表盘 | G2Plot (antv.vision)

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/mingwei_zhu/article/details/127445714

智能推荐

关于simplis仿真和驱动方法-程序员宅基地

文章浏览阅读9k次,点赞4次,收藏34次。转自:http://bbs.21dianyuan.com/thread-233723-1-1.html1.1.4 驱动线路(死区控制、隔离变压器)A.互补驱动(带死区控制)实现方式,UC3843的PWM输出用逻辑非门芯片取反,然后利用RCD做死区,经驱动IC HIP2101(仿真软件自带驱动芯片模型),得到两路带死区的互补驱动信号PWM1和PWM2,如下图所示:该电路可用来做同步Buck,同..._simplis

软件构建(转)_软件构建是什么意思-程序员宅基地

文章浏览阅读5.2k次。1、什么是构建你一定知道“构建(construction)”一次在软件开发领域以外的含义。“构建”就是“建筑工人(construction workers)”在建设一栋房屋,一所学校,乃至一座摩天大楼时所做的工作。在你年轻时,可能也曾用“硬纸板(construction paper)”构建过什么东西吧。按照一般的用法,“构建”是指建设的过程。构建过程可能包含有计划、设计、检查工作的一些方面,但..._软件构建是什么意思

reboot后centos服务器无法ssh连接_服务器重启reboot 无法连接-程序员宅基地

文章浏览阅读9.4k次,点赞2次,收藏10次。问题描述安装好了centOS服务器,一直用Secure CRT工具通过ssh服务来远程连接linux,很方便的进行各种操作。今天偶然尝试了一下在非root的一般用户下执行重启服务器的命令,发现一般用户是没有权限执行重启的,果断使用sudo命令再次执行,终于重启成功,却发现Secure CRT再也连不上服务器了,郁闷不已,去网上查找各种资料总算有了一点粗浅的认识,记录下来,也让其他的linux beginner们能够少走些弯路吧。普通用户下执行重启命令:shutdown -r now 或者 _服务器重启reboot 无法连接

启动Tomcat时报错:java.util.zip.ZipException: invalid LOC header (bad signature)_"[\"ajp-nio-8012\"]"-程序员宅基地

文章浏览阅读916次。详细错误:java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[/coin-deal]] at java...._"[\"ajp-nio-8012\"]"

神奇的layer,layer 的使用方法详解(转载官网,你想要的提示框都有)_doc/modules/layer.html-程序员宅基地

文章浏览阅读5.7k次,点赞2次,收藏11次。转载:http://www.layui.com/doc/modules/layer.html弹层组件文档 - layui.layerlayer 至今仍作为 layui 的代表作,她的受众广泛并非偶然,而是这数年来的坚持、不弃的执念,将那些不屑的眼光转化为应得的尊重,不断完善和维护、不断建设和提升社区服务,在 Web 开发者的圈子里口口相传,乃至于成为今天的 layui 最强劲的源动力。目前,lay..._doc/modules/layer.html

8086CPU汇编语言程序格式_8086汇编 精简教程-程序员宅基地

文章浏览阅读871次,点赞19次,收藏18次。汇编语言程序格式_8086汇编 精简教程

随便推点

LDPC译码:和积译码算法(SPA)、最小和算法(MSA)、分层译码算法(LBP)、动态信息更新策略IDS(含RBP、NW-RBP、SVNF-RBP)的MATLAB实现_最小和译码算法-程序员宅基地

文章浏览阅读1.8w次,点赞32次,收藏232次。LDPC各类译码方法的MATLAB实现主要内容新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注脚注释也是必不可少的KaTeX数学公式新的甘特图功能,丰富你的文章UML 图表FLowchart流程图导出与导入导出导入主要内容LDP..._最小和译码算法

新手C语言开发详细教程_安装c语言-程序员宅基地

文章浏览阅读1.1k次。C语言开发编译工具gcc的详细安装教程(图文)_安装c语言

【前端】前端及其技术栈_前端技术栈-程序员宅基地

文章浏览阅读1.5w次,点赞32次,收藏272次。文章目录0)前端1、什么是前端?2、为什么需要前端?前端的发展简史:3、前端开发的类型Web前端开发:客户端(APP)开发:4、前端与后端的交互Ajax:Socket:*前端技术栈1)核心语言1.1 HTML什么是HTML?HTML如何描述网页?HTML文档与网页的关系?1.2 CSS什么是CSS?为什么使用CSS?1.3 JavaScript(JS)什么是JavaScript?JavaScript的作用?2)基础技术2.1 AJAX什么是AJAX?AJAX的工作原理?2.2 JSON什么是JSON?为什么_前端技术栈

JWT单点登录功能_jeeccg 登录功能-程序员宅基地

文章浏览阅读1k次。如题,要使用Spring Boot + JWT + VUE + Node.js实现单点登录功能_jeeccg 登录功能

05-RabbitMQ 面试题-程序员宅基地

文章浏览阅读894次,点赞21次,收藏11次。rabbit mq 面试题

全开源即时通讯(IM)系统 高仿微信_wildfirechat-程序员宅基地

文章浏览阅读3.5w次,点赞19次,收藏67次。android-chat项目地址:wildfirechat/android-chat简介:全开源即时通讯(IM)系统 高仿微信更多:作者提 Bug官网标签:野火 IM 是一套跨平台、全开源的即时通讯解决方案,主要包含以下内容。仓库 说明 备注 android-chat 野火 IM Android SDK 源码和 App 源码..._wildfirechat