如何用Vue3和p5.js绘制交互式3D饼图
suiw9 2024-11-09 14:49 27 浏览 0 评论
本文由ScriptEcho平台提供技术支持
项目地址:传送门
基于p5.js实现色彩轮和饼状图的动态可视化
应用场景
本代码利用p5.js库,创建了一个交互式的色彩轮和饼状图可视化界面。它适用于需要展示颜色信息或数据分布情况的场景,如设计、数据分析和教育领域。
基本功能
该代码主要实现了以下功能:
- **色彩轮:**动态生成一个圆形色彩轮,展示色相、饱和度和亮度变化。
- **饼状图:**基于提供的数字数据,生成一个交互式的饼状图,展示数据比例分布。
功能实现步骤及关键代码分析
1. 加载p5.js库
首先,使用loadJavascript函数异步加载p5.js库,确保其在程序执行前已加载完成。
const loadJavascript = (jsUrl) => {
return new Promise((resolve, reject) => {
const script = document.createElement('script')
script.type = 'text/javascript'
script.onload = () => resolve('')
script.onerror = (err) => reject(err)
script.src = jsUrl
document.body.appendChild(script)
})
}
2. 定义p5.js草图
在onMounted钩子中,定义一个p5.js草图,该草图将渲染到#container元素中。
const sketch = (s) => {
// ...
}
3. 设置画布和颜色模式
在setup函数中,设置画布大小、颜色模式和角度模式。
s.setup = () => {
s.createCanvas(400, 400)
s.colorMode(s.HSB)
s.angleMode(s.DEGREES)
}
4. 绘制色彩轮
使用colorWheel函数,根据指定的半径和角度绘制一个色彩轮。
s.colorWheel = (x, y, rad) => {
// ...
for (let a = 0; a < 360; a += 10) {
s.stroke(a, 150, 200) //hue based on a
s.line(x, y, x + rad * s.cos(a), y + rad * s.sin(a))
}
}
5. 绘制饼状图
使用pieChartPop函数,根据提供的数字数据绘制一个饼状图。
s.pieChartPop = (x, y) => {
// ...
let startValue = 0
let range = 0
// ...
s.drawSlice(fColor, x, y, 200, startValue, startValue + range)
startValue += range
// ...
}
6. 绘制饼状图切片
使用drawSlice函数,根据指定的颜色、位置、直径和百分比范围绘制一个饼状图切片。
s.drawSlice = (fColor, x, y, d, percent1, percent2) => {
s.fill(fColor)
s.arc(x, y, d, d, -90 + percent1 * 360, -90 + percent2 * 360)
}
7. 初始化p5.js实例
使用new p5函数,初始化一个p5.js实例,并将草图附加到#container元素中。
new p5(sketch, 'container')
总结与展望
开发这段代码的过程中,我学习到了如何使用p5.js库创建交互式的可视化效果。该代码可以根据不同的数据和参数进行定制,以满足各种可视化需求。
未来,该卡片功能可以进一步拓展和优化,例如:
- **数据绑定:**将饼状图的数据绑定到外部数据源,实现实时更新。
- **交互性增强:**允许用户与饼状图交互,如选择切片或查看详细信息。
- **移动设备优化:**优化代码以适应移动设备,实现跨平台兼容性。
- 更多组件:
获取更多Echos
本文由ScriptEcho平台提供技术支持
项目地址:传送门
微信搜索ScriptEcho了解更多
相关推荐
- 分布式系统核心概念及实现(分布式核心原理解析)
-
一、分布式系统核心概念1.分布式系统的定义分布式系统是由多个独立的计算机(节点)通过网络连接,协同完成任务的系统。这些节点可以是物理机、虚拟机或容器。...
- nosql之mongodb(nosql数据库是国产的吗)
-
什么是MongoDB?MongoDB是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。...
- 如何治理非结构化数据?(非结构化化数据)
-
据调查,当前企业80%的数据为非结构化数据或半结构化数据,而结构化数据是他们管理的重点,非结构化数据却被忽视。然而,非结构化数据也有着它的价值。那么,如何治理非结构化数据?IDC调研显示,目前企业中8...
- Cloudera收购大数据加密初创企业Gazzang
-
Hadoop供应商Cloudera刚刚收购了专门研究下一代数据存储环境加密技术技术的初创企业Gazzang,但交易细节并未透露。这是Cloudera的第一笔重大收购。Gazzang成立于20...
- 全网最全95道MongoDB面试题1万字详细解析
-
1、mongodb是什么?MongoDB是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。在高负载的情况下,添加更多的节点,可以保证服务器性能。MongoDB旨在给WEB应...
- mongodb——视图(mongodb object)
-
MongoDB视图是一个可查询的对象,其内容由其他集合或视图上的聚合管道定义。MongoDB不会将视图内容持久化到磁盘。当客户端查询视图时,MongoDB可以要求客户端拥有查询视图的权限。MongoD...
- mongodb的优缺点及应用场景(mongodb 优点 应用场景)
-
一、MongoDB是什么1、维基百科MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。...
- 5款Syslog集中系统日志常用工具对比推荐
-
一、为何要集中管理Syslog?Syslog由Linux/Unix系统及其他网络设备生成,广泛分布于整个网络。因其包含关键信息,可用于识别网络中的恶意活动,所以必须对其进行持续监控。将Sys...
- 跨平台、多数据库支持的开源数据库管理工具——DBeaver
-
简介今天给大家推荐一个开源的数据库管理工具——DBeaver。它支持多种数据库系统,包括Mysql、Oracle、PostgreSQL、SLQLite、SQLServer等。DBeaver的界面友好...
- 强烈推荐!数据库管理工具:Navicat Premium 16.3.2 (64位)
-
NavicatPremium,一款集数据迁移、数据库管理、SQL/查询编辑、智能设计、高效协作于一体的全能数据库开发工具。无论你是MySQL、MariaDB、MongoDB、SQLServer、O...
- 3 年 Java 程序员还玩不转 MongoDB,网友:失望
-
一、什么场景使用MongoDB?...
- 拯救MongoDB管理员的GUI工具大赏:从菜鸟到极客的生存指南
-
作为一名在NoSQL丛林中披荆斩棘的数据猎人,没有比GUI工具更称手的瑞士军刀了。本文将带你围观五款主流MongoDB管理神器的特性与暗坑,附赠精准到扎心的吐槽指南一、MongoDBCompass:...
- mongodb/redis/neo4j 如何自己打造一个 web 数据库可视化客户端?
-
前言最近在做neo4j相关的同步处理,因为产线的可视化工具短暂不可用,发现写起来各种脚本非常麻烦。...
- solidworks使用心得,纯干货!建议大家收藏
-
SolidWorks常见问题...
- 统一规约-关乎数字化的真正实现(规范统一性)
-
尽管数字化转型的浪潮如此深入人心,但是,对于OPCUA和TSN的了解却又甚少,这难免让人质疑其可实现性,因为,如果缺乏统一的语义互操作规范,以及更为具有广泛适用的网络与通信,则数字化实际上几乎难以具...
你 发表评论:
欢迎- 一周热门
-
-
Linux:Ubuntu22.04上安装python3.11,简单易上手
-
宝马阿布达比分公司推出独特M4升级套件,整套升级约在20万
-
MATLAB中图片保存的五种方法(一)(matlab中保存图片命令)
-
别再傻傻搞不清楚Workstation Player和Workstation Pro的区别了
-
Linux上使用tinyproxy快速搭建HTTP/HTTPS代理器
-
如何提取、修改、强刷A卡bios a卡刷bios工具
-
Element Plus 的 Dialog 组件实现点击遮罩层不关闭对话框
-
日本组合“岚”将于2020年12月31日停止团体活动
-
SpringCloud OpenFeign 使用 okhttp 发送 HTTP 请求与 HTTP/2 探索
-
tinymce 号称富文本编辑器世界第一,大家同意么?
-
- 最近发表
- 标签列表
-
- dialog.js (57)
- importnew (44)
- windows93网页版 (44)
- yii2框架的优缺点 (45)
- tinyeditor (45)
- qt5.5 (60)
- windowsserver2016镜像下载 (52)
- okhttputils (51)
- android-gif-drawable (53)
- 时间轴插件 (56)
- docker systemd (65)
- slider.js (47)
- android webview缓存 (46)
- pagination.js (59)
- loadjs (62)
- openssl1.0.2 (48)
- velocity模板引擎 (48)
- pcre library (47)
- zabbix微信报警脚本 (63)
- jnetpcap (49)
- pdfrenderer (43)
- fastutil (48)
- uinavigationcontroller (53)
- bitbucket.org (44)
- python websocket-client (47)