P5.js开发之——2D图形绘制(3)

2024-03-24 06:10
文章标签 开发 js 绘制 图形 2d p5

本文主要是介绍P5.js开发之——2D图形绘制(3),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一 概述

本文介绍通过P5.js绘制常见的2D形状

编号图形函数
1弧形arc()
2椭圆形ellipse()
3circle()
4直线line()
5point()
6四角形quad()
7方形rect()
8方形square()
9三角形triangle()

二 项目创建

2.1 通过VSCode插件创建P5.js项目

index.html
sketch.js

2.2 新建libs文件夹,并将p5.js 复制到libs目录下,并添加引用(index.html)

<!DOCTYPE html>
<html lang="en">
<head><meta charset="utf-8"><title>p5demo</title><script src="./libs/p5.js"></script>
</head>
<body><script src="sketch.js"></script>
</body>
</html>

三 2D图形绘制—代码复制到draw函数

3.1 弧形—arc()

代码及预览

参数及说明
arc(x, y, w, h, start, stop, [mode], [detail])
参数说明
x数字:弧形的椭圆形的 x 坐标
y数字:弧形的椭圆形的 y 坐标
w数字:弧形的椭圆形的宽度
h数字:弧形的椭圆形的高度
start数字:弧形开始的角度,用弧度定义
stop数字:弧形结束的角度,用弧度定义
mode常数:可选参数用以定义弧形的画法,可用 CHORD、PIE 或 OPEN
detail数字:WebGL模式的可选参数

3.2 椭圆形—ellipse()

代码及预览

参数及说明
ellipse(x, y, w, [h])
ellipse(x, y, w, h, [detail])
参数说明
x数字:椭圆形的 x 坐标
y数字:椭圆形的 y 坐标
w数字:椭圆形的宽度
h数字:椭圆形的高度
detail整数:椭圆形的径向扇区数

3.3 圆—circle()

代码及预览

参数及说明
circle(x, y, d)
参数说明
x数字:圆的 x 坐标
y数字:圆的 y 坐标
d数字:圆的直径

3.4 直线—line()

代码及预览

参数及说明
line(x1, y1, x2, y2)
line(x1, y1, z1, x2, y2, z2)
参数说明
x1数字:第一个点的 x 坐标
y1数字:第一个点的 y 坐标
x2数字:第二个点的 x 坐标
y2数字:第二个点的 y坐标
z1数字:第一个点的z 坐标
z2数字:第二个点的 z 坐标

3.5 点—point()

代码及预览

参数及说明
point(x, y, [z])
参数说明
x数字:x 坐标
y数字:y 坐标
z数字:z 坐标(用于 WEBGL 模式)

3.6 四角形—quad()

代码及预览

参数及说明
quad(x1, y1, x2, y2, x3, y3, x4, y4, [detailX], [detailY])
quad(x1, y1, z1, x2, y2, z2, x3, y3, z3, x4, y4, z4, [detailX], [detailY])
参数说明
x1数字:第一个点的 x 坐标
y1数字:第一个点的 y 坐标
x2数字:第二个点的 x 坐标
y2数字:第二个点的 y坐标
x3数字:第三个点的 x 坐标
y3数字:第三个点的 y 坐标
x4数字:第四个点的 x 坐标
y4数字:第四个点的 y 坐标
z1数字:第一个点的 z 坐标
z2数字:第二个点的 z 坐标
z3数字:第三个点的 z 坐标
z4数字:第四个点的 z 坐标

3.7 方形—rect()

代码及预览

参数及说明
rect(x, y, w, [h], [tl], [tr], [br], [bl])
rect(x, y, w, h, [detailX], [detailY])
参数说明
x数字:方形的 x 坐标
y数字:方形的 y 坐标
w数字:方形的宽度
h数字:方形的高度
tl数字:可选性左上角拐角半径值
tr数字:可选性右上角拐角半径值
br数字:可选性右下角拐角半径值
bl数字:可选性左下角拐角半径值
detailX整数:x 方向段数
detailY整数:y 方向段数

3.8 方形—square()

代码及预览

参数及说明
square(x, y, s, [tl], [tr], [br], [bl])
参数说明
x数字:方形的 x 坐标
y数字:方形的 y 坐标
s数字:方形的 尺寸
tl数字:可选性左上角拐角半径值
tr数字:可选性右上角拐角半径值
br数字:可选性右下角拐角半径值
bl数字:可选性左下角拐角半径值

3.9 三角形—triangle()

代码及预览

参数及说明
triangle(x1, y1, x2, y2, x3, y3)
参数说明
x1数字:第一个点的 x 坐标
y1数字:第一个点的 y 坐标
x2数字:第二个点的 x 坐标
y2数字:第二个点的 y 坐标
x3数字:第三个点的 x 坐标
y3数字:第三个点的 y 坐标

四 参考

  • P5.js—参考文献

这篇关于P5.js开发之——2D图形绘制(3)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/840671

相关文章

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Java 与 LibreOffice 集成开发指南(环境搭建及代码示例)

《Java与LibreOffice集成开发指南(环境搭建及代码示例)》本文介绍Java与LibreOffice的集成方法,涵盖环境配置、API调用、文档转换、UNO桥接及REST接口等技术,提供... 目录1. 引言2. 环境搭建2.1 安装 LibreOffice2.2 配置 Java 开发环境2.3 配

Python38个游戏开发库整理汇总

《Python38个游戏开发库整理汇总》文章介绍了多种Python游戏开发库,涵盖2D/3D游戏开发、多人游戏框架及视觉小说引擎,适合不同需求的开发者入门,强调跨平台支持与易用性,并鼓励读者交流反馈以... 目录PyGameCocos2dPySoyPyOgrepygletPanda3DBlenderFife

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自