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

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 模式:

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

步骤 2:准备 p5.Geometry 对象

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

let myModel; // 存储3D模型function setup() {createCanvas(400, 400, WEBGL);// 用buildGeometry创建模型:传入一个画形状的函数myModel = buildGeometry(drawCone); 
}// 定义要画的形状(这里画一个圆锥)
function drawCone() {cone(50, 100); // 圆锥:底面半径50,高100
}

步骤 3:用 model () 绘制

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

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

完整代码

在这里插入图片描述

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° 查看模型。

在这里插入图片描述

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

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


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

可以➕我 green bubble 吹吹水咯

在这里插入图片描述

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

http://www.xdnf.cn/news/1225315.html

相关文章:

  • ubuntu 镜像克隆
  • hadoop.yarn 带时间的LRU 延迟删除
  • Ubuntu-Server-24.04-LTS版本操作系统如何关闭自动更新,并移除不必要的内核
  • C#常见的转义字符
  • Vue3 setup、ref和reactive函数
  • Vue 详情模块 1
  • C++对象访问有访问权限是不是在ide里有效
  • 解决MySQL不能编译存储过程的问题
  • 《Java 程序设计》核心知识点梳理与深入探究
  • SpringMVC全局异常处理+拦截器使用+参数校验
  • 2025 腾讯广告算法大赛 Baseline 项目解析
  • 为什么MCP协议是AI集成的未来API
  • 向华为学习——IPD流程体系之IPD术语
  • 京东云轻量云服务器与腾讯云域名结合配置网站及申请SSL证书流程详解
  • 使用 whisper, 音频分割, 初步尝试,切割为小块,效果还不错 1
  • 服务器地域选择指南:深度分析北京/上海/广州节点对网站速度的影响
  • 宝塔服务器挂载数据盘
  • OPENGLPG第九版学习 - 纹理与帧缓存 part2
  • 在SQL SERVER 中,用SSMS 实现存储过程的每日自动调用
  • Baumer工业相机堡盟工业相机如何通过YoloV8深度学习模型实现道路汽车的检测识别(C#代码,UI界面版)
  • Django模型查询与性能调优:告别N+1问题
  • 【Java面试题】缓存穿透
  • Linux文件系统理解2
  • Trust Management System (TMS)
  • AR智能巡检系统:制造业设备管理的效率革新
  • 2025.8.1
  • 计算机(电脑)是什么?零基础硬件软件详解
  • 什么是三防平板电脑?三防平板有什么作用?
  • android MVC/MVP/MVVM/MVI架构发展历程和编写范式
  • LLM Prompt与开源模型资源(2)提示工程关键技术