p5.js 3D模型(model)入门指南

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

什么是 model ()?为什么需要它?

在 p5.js 中,model()是专门用来绘制 3D 模型的 "画笔"。它的作用很简单:把一个提前准备好的 3D 几何对象(p5.Geometry)画到画布上。

但有个关键前提:必须在 WebGL 模式下使用。因为 3D 绘图需要 WebGL 的 3D 渲染能力,普通 2D 画布(默认模式)不支持!

核心概念:p5.Geometry 对象

model()的参数必须是p5.Geometry类型 ------ 你可以把它理解为 "3D 模型的数字描述"(包含顶点、面、颜色等信息)。

怎么得到p5.Geometry?有两种方式:

  1. 自己创建 :用buildGeometry()beginGeometry()+endGeometry()手动定义形状;
  2. 加载外部文件 :用loadModel()导入.obj 格式的 3D 模型文件(比如从 Blender 导出的模型)。

基础用法

步骤 1:创建 WebGL 画布

createCanvas(width, height, WEBGL)开启 3D 模式:

js 复制代码
function setup() {
  createCanvas(400, 400, WEBGL); // 最后一个参数WEBGL是关键!
}

步骤 2:准备 p5.Geometry 对象

可以自己画一个简单形状,比如圆锥:

js 复制代码
let myModel; // 存储3D模型

function setup() {
  createCanvas(400, 400, WEBGL);
  // 用buildGeometry创建模型:传入一个画形状的函数
  myModel = buildGeometry(drawCone); 
}

// 定义要画的形状(这里画一个圆锥)
function drawCone() {
  cone(50, 100); // 圆锥:底面半径50,高100
}

步骤 3:用 model () 绘制

draw()里调用model(你的模型)就能显示了:

js 复制代码
function draw() {
  background(200); // 灰色背景
  model(myModel); // 画出准备好的模型
}

完整代码

js 复制代码
let myModel; // 存储3D模型

function setup() {
  createCanvas(400, 400, WEBGL);
  // 用buildGeometry创建模型:传入一个画形状的函数
  myModel = buildGeometry(drawCone); 
}

// 定义要画的形状(这里画一个圆锥)
function drawCone() {
  cone(50, 100); // 圆锥:底面半径50,高100
}

function draw() {
  background(200); // 灰色背景
  model(myModel); // 画出准备好的模型
}

允许鼠标操作

orbitControl()是 3D 绘图的常用工具,让你能 360° 查看模型。

js 复制代码
function draw() {
  background(200); // 灰色背景
  orbitControl(); // 允许鼠标拖拽旋转视角(3D必备交互)
  model(myModel); // 画出准备好的模型
}

采用前面的代码,然后在 draw() 里加入一句 orbitControl() 即可。


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

可以➕我 green bubble 吹吹水咯

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

相关推荐
飞翔的佩奇19 分钟前
【完整源码+数据集+部署教程】【天线&水】舰船战舰检测与分类图像分割系统源码&数据集全套:改进yolo11-repvit
前端·python·yolo·计算机视觉·数据集·yolo11·舰船战舰检测与分类图像分割系统
哆啦A梦15881 小时前
点击Top切换数据
前端·javascript·vue.js
程序猿追2 小时前
Vue组件化开发
前端·html
艾德金的溪2 小时前
redis-7.4.6部署安装
前端·数据库·redis·缓存
小光学长2 小时前
基于Vue的2025年哈尔滨亚冬会志愿者管理系统5zqg6m36(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
@PHARAOH2 小时前
WHAT - 受控组件和非受控组件
前端·javascript·react.js
生莫甲鲁浪戴2 小时前
Android Studio新手开发第二十六天
android·前端·android studio
JH30733 小时前
B/S架构、HTTP协议与Web服务器详解
前端·http·架构
yi碗汤园3 小时前
【超详细】C#自定义工具类-StringHelper
开发语言·前端·unity·c#·游戏引擎
Kevin Wang7274 小时前
解除chrome中http无法录音问题,权限
前端·chrome