【React Native】做了一个简约的雷达图组件

本文目录

  • 【React Native】做了一个简约的雷达图组件
    • 获取组件
    • 实现思路
    • 用法示例
      • 简易用法
      • 自定义美化
    • 结语

【React Native】做了一个简约的雷达图组件

最近在使用 react-native 中需要绘制雷达图,没有找到合适的小组件(大的图表库未直接提供,需要自行绘制;小的封装好的雷达图组件外观一般或者有无法更改的瑕疵)。最后我选择了自造了一个适用于 react-native 的雷达图组件。

获取组件

  • 已发布的 npm 包1(@evanpatchouli/react-native-radar)
    • npm i -S @evanpatchouli/react-native-radar
  • Github仓库项目源码2

实现思路

利用 react-native-svg,计算好组成雷达图的每个图像元素的尺寸和坐标,依次绘制背景、边框、轴线、刻度、有效面积、值线和标签,并将他们按顺序层层叠加。

用法示例

简易用法

import EvpRadar from "@evanpatchouli/react-native-radar";const MyRadar = () => (<EvpRadardata={[100, 20, 30, 10, 40]}labels={["Aaa", "Bbb", "Ccc", "Ddd", "Eee"]}labelSpace={30}border={{type: "circle", // polygon, circle, none}}strokeColor="none"Axis={{type: "dashed", // solid, dashed, none}}/>
);export default function App() {return (<MyRadar />);
}

效果图:
最简易demo

自定义美化

多传入和覆盖一些参数,进行更细节的样式设置。详细的参数说明已写在代码注释中,文中不再花篇幅做介绍。

const MyRadar = (<EvpRadar// containerViewProps={{ // 设置容器属性//   style: {//     borderColor: "rgba(0, 0, 200, 0.5)",//     borderWidth: 1,//     borderRadius: 10,//     overflow: "hidden",//     margin: 10,//     padding: 10,//   },// }}data={[100, 20, 30, 10, 40]}labels={["Aaa", "Bbb", "Ccc", "Ddd", "Eee"]} // 文本标签// labels={[ //使用自定义的标签元素//   <Text key="Aaa">Aaa</Text>,//   <Text key="Bbb">Bbb</Text>,//   <Text key="Ccc">Ccc</Text>,//   <Text key="Ddd">Ddd</Text>,//   <Text key="Eee">Eee</Text>,// ]}radius={100} // 图片半径,默认: 100backgroundColor="rgba(0, 0, 200, 0.05)" //背景色,默认: nonestrokeColor="rgba(0, 0, 200, 0.5)" // 值线的颜色,默认: blackstrokeWidth={1.5} // 值线的宽度,默认: 1strokeType="solid" // 值线的类型:dashed 或 solid,默认: solid// strokeOpacity={1} // 值线的不透明度,默认: 1dashArray={[5, 3]} // 虚线形值线的形式,画多长留多少空白,默认: [10, 5]fillColor="rgba(0, 255, 255, 0.4)" // 值线围起来的区域的填充颜色,默认: nonelabelProps={{ fill: "rgba(0, 0, 200, 0.3)" }} // 文本标签属性coefficient={1} // 系数,值线的长度 = 系数 * 值,默认: 1labelSpace={40} // 文本标签与雷达边界的间距,默认: 0border={{ // 雷达边界配置项type: "polygon", // 边界形状,circle 或 polygon(多边形)或 none, 默认: nonecolor: "rgba(0, 0, 200, 0.5)", // 边界颜色,默认: blackwidth: 10, // 边界宽度,默认: 1}}Axis={{// 雷达轴线配置项type: "dashed", // 轴线线条类型,solid 或 dashed 或 none,默认: nonewidth: 1, // 轴线宽度,默认: 1color: "rgba(0, 0, 200,  0.2)", // 轴线颜色,默认: greydashArray: [5, 4], // 虚线形轴线的形式,默认: [10, 5]}}ScaleLine={{// 刻度线配置项type: "solid", // 刻度线线条类型,solid 或 dashed 或 none,默认: noneshape: "polygon", // 刻度线形状,polygon 或 circle. 如果未指定,将跟随边框 border 的类型. 如果雷达边框形状也未指定,默认为 polygonnumber: 4, // 等分刻度线数量,默认: 0width: 1, // 刻度线宽度,默认: 1color: "rgba(0, 0, 200, 0.2)", // 刻度线颜色,默认: greydashArray: [5, 4], // 虚线形刻度线: [20, 5]// opacity: 1 // 刻度线的不透明度,默认: 1}}/>
);

效果图:
高度自定义雷达图

结语

笔者觉得这个雷达图还是挺好用的,当然不足之处一定是存在的,如果有小伙伴门有任何方面的建议,可以留言、私信或在仓库提issue,欢迎共建!


  1. npm 包地址: https://www.npmjs.com/package/@evanpatchouli/react-native-radar ↩︎

  2. Github 仓库项目源码: https://github.com/Evanpatchouli/react-native-radar ↩︎

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/45325.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

pico+unity3d运行测试方法

一. 发布并运行程序 这个就很简单&#xff0c;电脑和pico数据库连接、pico打开开发者模式、运行的时候选择设备pico 二. pico串流助手 1.需要先下载pico的软件 PICO Developer Center、并安装串流助手、这种方式的话&#xff0c;安装了向日葵的小伙伴可能有冲突、百度一下解…

c#中的特性

在C#中&#xff0c;特性&#xff08;Attributes&#xff09;是一种向程序元素&#xff08;如类、方法、属性等&#xff09;添加元数据的方式。特性可以用来提供关于程序元素的附加信息&#xff0c;这些信息可以在编译时和运行时被访问。 特性主要有以下几个用途&#xff1a; 提…

手机数据恢复篇:如何从 Android 设备内恢复数据

如何从 Android 内部存储恢复数据&#xff1f; 要从 Android 内部存储恢复已删除的文件&#xff0c;您需要一个 Android 内部存储恢复应用或程序。请继续阅读以获取可靠的 Android 数据恢复软件&#xff0c;并让它帮助您从 Android 手机的内部存储恢复数据。 是否有可能恢复 An…

4-2 权重衰减

前一节我们描述了过拟合的问题&#xff0c;本节我们将介绍一些正则化模型的技术。 我们总是可以通过去收集更多的训练数据来缓解过拟合。 但这可能成本很高&#xff0c;耗时颇多&#xff0c;或者完全超出我们的控制&#xff0c;因而在短期内不可能做到。 假设我们已经拥有尽可能…

图片转文字的软件,分享3种不同的类型的软件!

在信息爆炸的时代&#xff0c;图片作为一种直观、生动的信息载体&#xff0c;已经成为我们日常生活中不可或缺的一部分。然而&#xff0c;有时候我们可能需要将图片中的文字提取出来&#xff0c;以便于编辑、整理或进一步使用。那么&#xff0c;有哪些实用的图片转文字软件可以…

一个引发openssl崩溃问题案例

1 背景 最近用libevent写了一个https代理功能&#xff0c;在调研的时候&#xff0c;遇到了一个项目用到了本地多个openssl库引发的ssl握手崩溃问题。 2 开发环境 项目库版本号依赖项libeventlibevent-2.1.8-stableopenssl 1.1openssl1.0u / 1.1.1w / 3.3.1...... 3 问题现象…

Python酷库之旅-第三方库Pandas(024)

目录 一、用法精讲 61、pandas.to_numeric函数 61-1、语法 61-2、参数 61-3、功能 61-4、返回值 61-5、说明 61-6、用法 61-6-1、数据准备 61-6-2、代码示例 61-6-3、结果输出 62、pandas.to_datetime函数 62-1、语法 62-2、参数 62-3、功能 62-4、返回值 62-…

关于SQLException: Illegal mix of collations (`utf8mb4_general_ci,IMPLICIT`)...错误

希望文章能给到你启发和灵感&#xff5e; 如果觉得文章对你有帮助的话&#xff0c;点赞 关注 收藏 支持一下博主吧&#xff5e; 阅读指南 开篇说明一、基础环境说明1.1 硬件环境1.2 软件环境 二、报错信息三、最后 开篇说明 记录一个查询错误 场景&#xff1a;数据库之间某表复…

旷野之间 16 – AI 代理、AI 代理基础设施、平台和比较

在本文中&#xff0c;我们将研究 AI 代理、AI 代理基础设施、市场上最流行的 AI 代理平台、它们的比较以及 AI 代理的未来 我们将按以下顺序讨论这些主题 1. 关于人工智能代理 2. 人工智能代理在行业中的应用 3. AI代理基础设施 4. 最受欢迎的 AI 代理平台及比较 5.您将如…

【笔记】nginx命令

查看 启动 通过./nginx启动nginx之后 可以在虚拟机中进入/usr/local/nginx/html 去查看cat index.html 也就是此页面的源代码 进入vim /etc/profile 配置完之后保存退出 source /etc/profile 手动重载资源 随后就可以在任意位置重载资源了 nginx -s reload 部署静态资源就把静…

两项国际设计奖,支持双设备—悠律Ringbuds pro开放式蓝牙耳机体验

在音频设备领域&#xff0c;开放式耳机对比入耳式耳机的优势就是既能听到耳机内的声音又能感知环境音&#xff0c;很适合在户外以及办公时使用&#xff0c;今天分享一款新品牌悠律UMELODY——悠律凝声环Ringbuds pro&#xff0c;它采用气传导耳挂式设计&#xff0c;佩戴舒适、安…

【人工智能】 知识表示与推理(八数码 + 传教士与野人渡河)

目录 一、八数码难题 1. 需求分析 2. 数据结构、功能模块设计与说明 2.1 算法思路 2.2 数据结构 3. 核心代码与测试结果说明 3.1 核心代码 3.2 测试结果说明 4. 存在的问题与体会 4.1 存在的问题 4.2 体会 二、传教士与野人渡河 1. 需求分析 2. 数据结构、功能模…

基于EMQX+Flask+InfluxDB+Grafana打造多协议物联网云平台:MQTT/HTTP设备接入与数据可视化流程(附代码示例)

摘要: 本文深入浅出地介绍了物联网、云平台、MQTT、HTTP、数据可视化等核心概念&#xff0c;并结合 EMQX、Flask、InfluxDB、Grafana 等主流工具&#xff0c;手把手教你搭建一个支持多协议的物联网云平台。文章结构清晰&#xff0c;图文并茂&#xff0c;代码翔实易懂&#xff0…

2024-07-14 Unity插件 Odin Inspector1 —— 插件介绍

文章目录 1 介绍2 模块3 学习目的 1 介绍 ​ Odin Inspector 是 Unity 的一个插件&#xff0c;拥有强大、自定义和用户友好的编辑器&#xff0c;而无需编写任何自定义编辑器代码&#xff0c;使得编程过程中的数据可视化更容易实现。 ​ 具体功能包括&#xff1a; 更舒适美观…

软件设计师(中级)备考视频教程

一、视频介绍 本视频主要包括软件设计师系统学习教程&#xff0c;通过学习本视频&#xff0c;可以帮助考生高效且深入地掌握软件设计师资格考试核心知识&#xff0c;全方位覆盖考试要点&#xff0c;从而轻松备战考试。视频不仅涵盖了考试所需的全面知识体系&#xff0c;还通过直…

Linux--USB驱动开发(二)插入USB后的内核执行程序

一、USB总线驱动程序的作用 a&#xff09;识别USB设备 1.1 分配地址 1.2 并告诉USB设备(set address) 1.3 发出命令获取描述符 b&#xff09;查找并安装对应的设备驱动程序 c&#xff09;提供USB读写函数 二、USB设备工作流程 由于内核自带了USB驱动,所以我们先插入一个U…

Google Colab 云端硬盘路径读取

加载云端硬盘 需要在左上角点击这个文件图标&#xff1b; from google.colab import drive drive.mount("/content/drive") # 挂载云端硬盘import os path"/content/drive/MyDrive/TextClassificationCustom" os.chdir(path) # 以路径path作为当前工作目…

在 SwiftUI 中的作用域动画

文章目录 前言简单示例动画视图修饰符使用多个可动画属性使用 ViewBuilder总结 前言 从一开始&#xff0c;动画就是 SwiftUI 最强大的功能之一。你可以在 SwiftUI 中快速构建流畅的动画。唯一的缺点是每当我们需要运行多步动画或将动画范围限定到视图层次结构的特定部分时&…

docker emqx 配置密码和禁用匿名连接

mqtt版本emqx/emqx:4.4.3 1.首先把镜像内目录/opt/emqx/etc拷贝到本地 2.做映射 3.allow_anonymous&#xff0c; false改成true 4. 5.MQTTX连不上的话看看下图的有没有打开

windows下环境变量开启方式

第一种方法&#xff1a; 使用快捷键打开“运行”对话框&#xff1a;按下 Win R 组合键&#xff0c;这将打开“运行”窗口。 输入系统属性命令&#xff1a;在“运行”窗口中输入 sysdm.cpl 然后按回车键。这将打开“系统属性”对话框。【sysdm.cpl是"System Data Manager…