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

p5.js 3D盒子的基础用法

点赞 + 关注 + 收藏 = 学会了

如果你刚接触 p5.js,想尝试 3D 绘图,那么box()函数绝对是你的入门首选。它能快速绘制出 3D 长方体(或正方体),配合简单的交互就能做出酷炫的 3D 效果。本文会从基础到进阶,带你吃透这个实用 API。

box

box()是 p5.js 中专门用于绘制 3D 立方体的函数。它具有以下几个特点:

  • 自带 6 个面,每个面都和相邻面成 90° 角(直角);
  • 必须在WebGL 模式下使用(3D 绘图的基础模式);
  • 参数灵活,可通过调整参数控制大小和细节。

基础用法

要使用box(),首先得创建支持 3D 的画布。记住:必须用WEBGL模式,否则盒子不会显示!

function setup() {// 创建300x300的WebGL画布(支持3D)createCanvas(300, 300, WEBGL);
}function draw() {background(220); // 灰色背景orbitControl();  // 允许鼠标拖动旋转视角(必加!否则3D效果看不出来)box(); // 绘制默认盒子
}

运行后,你会看到一个灰色背景上的白色盒子。拖动鼠标可以 360° 旋转查看。

box()有 5 个可选参数,分别控制盒子的尺寸和表面细节。记住,参数是按顺序生效的。

box([width], [height], [depth], [detailX], [detailY])

width(宽度)

  • 作用:控制盒子沿 X 轴的长度;
  • 默认值:50;
  • 示例:box(100) → 宽度为 100,其他尺寸默认(高度 = 宽度,深度 = 高度)。

height(高度)

  • 作用:控制盒子沿 Y 轴的长度;
  • 默认值:等于 width(所以只传 1 个参数时是正方体);
  • 示例:box(100, 200) → 宽 100,高 200,深度默认等于高度(200)。

depth(深度)

  • 作用:控制盒子沿 Z 轴的长度(3D 的 “厚度”);
  • 默认值:等于 height;
  • 示例:box(100, 200, 50) → 宽 100,高 200,深 50(扁平状)。

detailX(X 轴细分)

  • 作用:控制盒子表面沿 X 轴的三角形细分数量(细分越多,表面越平滑,但性能消耗略高);
  • 默认值:1(最基础的细分,棱角明显);
  • 示例:box(100, 100, 100, 5) → X 轴用 5 个细分,表面更细腻。

detailY(Y 轴细分)

  • 作用:控制盒子表面沿 Y 轴的三角形细分数量;
  • 默认值:1;
  • 示例:box(100, 100, 100, 5, 8) → X 轴 5 细分,Y 轴 8 细分,表面更平滑。

上色和动画

一个彩色的长方体,会缓慢旋转,颜色随时间从红→绿→蓝循环变化,拖动鼠标可从任意角度观察。

function setup() {createCanvas(400, 400, WEBGL);
}function draw() {background(0); // 黑色背景orbitControl();// 随时间旋转(X和Y轴同时转)rotateX(frameCount * 0.01); // frameCount是当前帧数,让旋转随时间变化rotateY(frameCount * 0.01);// 彩色盒子(HSL颜色模式:色相随时间变化)fill(frameCount % 360, 100, 50); // 色相0-360循环,饱和度100,亮度50// 尺寸:宽150,高100,深80,细分3(表面更平滑)box(150, 100, 80, 3);
}

跳动的彩色盒子阵列

box()做一个酷炫的特效:多个盒子组成阵列,随鼠标位置和时间跳动,颜色也动态变化。

let spacing = 120; // 盒子间距
let boxSize = 60; // 基础大小function setup() {createCanvas(800, 600, WEBGL);noFill(); // 无填充,只显示边框strokeWeight(2); // 边框粗细
}function draw() {background(0);orbitControl();// 旋转整个场景,增强3D感rotateX(-0.3);rotateY(frameCount * 0.005);// 绘制3x3阵列的盒子for (let x = -spacing; x <= spacing; x += spacing) {for (let y = -spacing; y <= spacing; y += spacing) {for (let z = -spacing; z <= spacing; z += spacing) {push(); // 保存当前状态translate(x, y, z); // 移动到目标位置// 随时间和鼠标位置变化大小(跳动效果)let size = boxSize * 0.5 + sin(frameCount * 0.05 + x*0.1 + mouseX*0.01) * 20;// 颜色随位置变化stroke(x + 200, y + 200, z + 200);box(size); // 绘制盒子pop(); // 恢复状态}}}
}

以上就是本文的全部内容啦,想了解更多 P5.js 用法欢迎关注 《P5.js中文教程》。

也可以➕我 green bubble 吹吹水咯

点赞 + 关注 + 收藏 = 学会了

http://www.lryc.cn/news/621614.html

相关文章:

  • 用 Enigma Virtual Box 将 Qt 程序打包成单 exe
  • Helm 常用命令 + Bitnami 中间件部署速查表
  • 北京JAVA基础面试30天打卡10
  • JVM核心原理与实战优化指南
  • Java 调用 Python 脚本:实现 HelloWorld
  • Android 欧盟网络安全EN18031 要求对应的基本表格填写
  • 电脑上练打字用什么软件最好:10款打字软件评测
  • 【Linux】编辑器vim的使用
  • IDE:vscode的vue3模板
  • STM32 - Embedded IDE - GCC - 解决LWRB库在GCC编译器会编译失败,在ARMCC编译器时却正常编译
  • collections:容器数据类型
  • 《R for Data Science (2e)》免费中文翻译 (第4章) --- Workflow: code style
  • uniapp 开发微信小程序,获取经纬度并且转化详细地址(单独封装版本)
  • 启动electron桌面项目控制台输出中文时乱码解决
  • 解锁AI大模型:Prompt工程全面解析
  • 玻璃pcb是什么材质?哪家工厂可以生产?
  • C++:stl-> list的模拟实现
  • NAT 和 PNAT
  • Oracle按照特定列值排序和C#统计特定列值的所有行
  • 当云手机出现卡顿怎么办?
  • 云手机选哪个比较好用?
  • 手机端的音视频界面或者图片文档界面共享给大屏
  • 实用技巧:Oracle中精准查看表占用空间大小
  • Rust 中 i32 与 *i32 的深度解析
  • Java-JVM的内存模型
  • 网上商城|基于SprinBoot+vue的分布式架构网上商城系统(源码+数据库+文档)
  • 【学习笔记】进程、线程、协程及进程间通信
  • 电脑开机几秒后就停止然后再循环是怎么回事
  • 深入理解 Python 闭包:从原理到实践
  • 永磁同步电机控制 第二篇、电机的分类