babylon.js-3:了解STL网格模型

网格模型上色

本篇文章主要介绍如何在 BabylonJS 中实现STL网格模型上色。

文章目录

    • 网格模型上色
      • 运用场景
      • 概要
      • 延申
      • 正文
        • 加载器库的支持
        • 认识 OBJ 和 STL 文件
        • GUI 色板选择器
        • 网格模型异步加载
        • 加载动画
        • 网格模型上色
        • 官方即将弃用 `ImportMesh` 而推荐使用 `ImportMeshAsync` 说明
        • OBJ 或 STL 文件 第三方资源
      • 总结

  • .STL文件:从官方上的叫法应该叫“标准三角面片文件”。但是为了易懂,我们下面称它为“网格模型”。当然,在场景渲染后它就是一个Mesh(网格)。

  • 图片
    在这里插入图片描述

运用场景

  • 产品私有化选型定制

概要

  • 加载器库
  • 初识 OBJ 和 STL 文件
  • GUI色板选择器
  • 网格模型异步加载
  • 加载动画
  • 网格模型上色
  • 官方即将弃用 ImportMesh 而推荐使用 ImportMeshAsync 说明
  • OBJ 或 STL 文件 第三方资源

延申

  • 网格模型局部部件上色

正文

加载器库的支持
  • CDN 引用

    <script src="https://cdn.babylonjs.com/loaders/babylonjs.loaders.min.js"></script>
    
  • npm 安装

    # @see: https://www.npmjs.com/search?q=babylonjs-loaders
    npm install babylonjs-loaders
    

    更多Vue支持请看: 如何在 Vue 中使用 BabylonJS

认识 OBJ 和 STL 文件

在这里插入图片描述

  • OBJ 文件
    • 定义:OBJ(Object)文件是一种三维对象文件格式,它是一种文本文件,包含了几何信息,如顶点位置、纹理坐标、法线向量和三角形面片信息等。
    • 用途:常用于在不同的三维软件和渲染引擎之间交换三维模型数据,广泛应用于 3D 建模、动画制作、游戏开发等领域,因为它可以存储丰富的几何信息,支持多面体几何图形,并且可以包含材质和纹理信息。
    • 结构:文件中通常以 v 开头的行表示顶点坐标,vt 表示纹理坐标,vn 表示法线,f 表示面信息,这些信息可以组合成一个完整的 3D 模型的几何形状。
    • 示例
      # Blender v2.79 (sub 0) OBJ File: ''
      # www.blender.org
      o Cube
      v 1.000000 -1.000000 -1.000000
      v 1.000000 -1.000000 1.000000
      ...vt 0.625000 0.500000vt 0.875000 0.500000
      ...vn 0.0000 0.0000 1.0000vn 0.0000 0.0000 -1.0000
      ...f 1/1/1 2/2/1 3/3/1f 3/3/1 4/4/1 1/1/1
      

在这里插入图片描述

  • STL 文件
    • 定义:STL(Stereolithography)文件有两种格式,一种是二进制格式,另一种是文本格式,主要用于描述三维表面几何形状,仅包含三角形面片信息,不包含颜色、纹理和其他属性。
    • 用途:主要用于快速成型系统,如 3D 打印,因为它的简单性和对表面几何形状的准确描述,使它成为 3D 打印机的标准输入文件之一。
    • 结构(文本格式):以 solid 开头,包含多个 facet normal 描述三角形面片的法线,然后是 outer loop 包含三角形的三个顶点,以 endloopendfacet 结束一个面片,最后以 endsolid 结束整个文件。
    • 示例(文本格式)
      solid Cube
      facet normal 0.0 0.0 1.0outer loopvertex 1.0 1.0 1.0vertex -1.0 1.0 1.0vertex -1.0 -1.0 1.0endloop
      endfacet
      ...
      endsolid Cube
      

二、VSCode 相关插件

在这里插入图片描述

  • 3D Viewer for VSCode:在 VSCode 中,可以使用 3D Viewer for VSCode 插件,它可以让你在编辑器中预览 STL 文件。安装该插件后,打开 STL 文件,在编辑器的侧边栏会出现一个 3D 视图,可以旋转、缩放和平移查看 STL 模型。
  • 市场:3dviewer
GUI 色板选择器

在这里插入图片描述

这里的颜色选择面板我们选用BABYLONJS内置原滋原味的GUI面板控件:ColorPicker

具体实现:

// 创建一个全屏的动态纹理
const advancedTexture = BABYLON.GUI.AdvancedDynamicTexture.CreateFullscreenUI("UI");
// 创建一个颜色选择器
const colorPicker = new BABYLON.GUI.ColorPicker();
// 设置颜色选择器的添加位置
advancedTexture.addControl(colorPicker);

注意:请务必添加GUI库,否则浏览器会报错,找不到 AdvancedDynamicTexture 属性

<!-- 引入 BabylonJS GUI 库 -->
<script src="https://cdn.babylonjs.com/gui/babylon.gui.min.js"></script>
网格模型异步加载

由于网格模型过大,正如素材里面的“vaze2.STL”文件165MB。所以在场景中加载的时候需要采用异步加载。

实现代码:

const result = await BABYLON.SceneLoader.ImportMeshAsync('meshName', './3066-vase-3d-model/', 'vaze2.STL', scene, (event) => {})
const newMeshes = result.meshes; // meshes是一个数组集
if (newMeshes.length > 0) {importedMesh = newMeshes[0];
}

参数剖析:

  • lengthComputable:用于检查是否可以计算进度的准确百分比。

    • 注意:为什么需要进入if (event.lengthComputable)这个判断作为前提?
    • event.lengthComputabletrue 时,意味着文件的总大小是已知的,并且可以计算出加载进度的准确百分比。这是因为有些文件的大小可能无法提前得知,例如在某些跨域请求或服务器没有正确设置 Content-Length 头信息时,文件的总大小是不确定的。
  • loaded:表示已经加载的数据量。

  • total:表示文件的总大小。

那么,通过获取以上参数,可以准确的计算当前网格模型加载的进度和展现进度百分比情况。同时可以控制加载完成后,网格模型与加载动画的显示与隐藏。

加载动画

加载动画的思路是一贯的,所以下面给出简单的逻辑和具体实现代码:

  1. 绘制进度条背景
    // 绘制进度背景
    const progressBar = new BABYLON.GUI.Rectangle();
    progressBar.width = "200px"; // 宽度200px
    progressBar.background = "gray";// 底色为灰色
    progressBar.horizontalAlignment = BABYLON.GUI.Control.HORIZONTAL_ALIGNMENT_CENTER; // 水平居中
    progressBar.verticalAlignment = BABYLON.GUI.Control.VERTICAL_ALIGNMENT_CENTER; // 垂直居中
    
  2. 绘制进度条
    // 绘制进度条
    const progressBarFill = new BABYLON.GUI.Rectangle();
    progressBarFill.width = "0px"; // 默认宽度为0
    progressBarFill.background = "blue"; // 底色为蓝色
    progressBarFill.horizontalAlignment = BABYLON.GUI.Control.HORIZONTAL_ALIGNMENT_LEFT; // 水平左对齐(不然会从中间向两天展开)
    
  3. 计算当前进度
    // 计算当前进度
    if (event.lengthComputable) {const progress = event.loaded / event.total;
    }
    
  4. 绘制进度和进度值
    // 宽度为当前进度乘以200
    progressBarFill.width = progress * 200 + "px"; 
    // 显示当前进度
    progressText.text = Math.floor(progress * 100) + "%"; 
    
  5. 加载完毕动作
    // 隐藏进度条
    progressBar.isVisible = false;
    
网格模型上色

颜色选择器绑定一个选择监视器事件,当选择颜色的时候,就给网格模型上色。

具体实现:

colorPicker.onValueChangedObservable.add((value) => {importedMesh.material.diffuseColor = new BABYLON.Color3(value.r, value.g, value.b);
});
官方即将弃用 ImportMesh 而推荐使用 ImportMeshAsync 说明

各自的参数说明就不在赘述了,感兴趣的可以去官方查看,这里主要说明两者的运用场景,就目前环境下谁更好。

  • 使用方法比较

    • ImportMesh

      BABYLON.SceneLoader.ImportMesh("", "path/to/your/models/", "yourModel.obj", scene, function (newMeshes, particleSystems, skeletons) {if (newMeshes.length > 0) {const mesh = newMeshes[0];// 对导入的网格进行操作,例如设置位置和旋转mesh.position = new BABYLON.Vector3(0, 0, 0);mesh.rotation = new BABYLON.Vector3(0, Math.PI, 0);}
      }, function (event) {if (event.lengthComputable) {console.log(`Loaded ${event.loaded} of ${event.total} bytes`);}
      }, function (error) {console.error("Error loading mesh:", error);
      });
      
    • ImportMeshAsync

      const importMeshAsync = async function() {try {const result = await BABYLON.SceneLoader.ImportMeshAsync("", "path/to/your/models/", "yourModel.obj", scene, function (event) {if (event.lengthComputable) {console.log(`Loaded ${event.loaded} of ${event.total} bytes`);}});const newMeshes = result.meshes;if (newMeshes.length > 0) {const mesh = newMeshes[0];// 对导入的网格进行操作,例如设置位置和旋转mesh.position = new BABYLON.Vector3(0, 0, 0);mesh.rotation = new BABYLON.Vector3(0, Math.PI, 0);}} catch (error) {console.error("Error loading mesh:", error);}
      };
      importMeshAsync();
      
  • 区别和优点

    • ImportMesh 是一个传统的回调函数风格的方法,而 ImportMeshAsync 是一个返回 Promise 的异步方法,使用 async/await.then() 处理结果,更符合现代 JavaScript 的异步编程风格。

    • ImportMeshAsync 在使用时可以利用 try...catch 语句来捕获错误,代码结构更清晰,避免了回调函数的嵌套,使代码更易读和维护。

  • 使用场景

    • ImportMesh
      • 适用于传统的回调函数风格的编程,如果你更熟悉这种风格,或者项目中已经大量使用回调函数,可以使用 ImportMesh
      • 在不支持 async/await 的旧环境中使用。
    • ImportMeshAsync
      • 适用于现代 JavaScript 开发,使用 async/await 可以使代码更加简洁,避免回调地狱。
      • 在需要处理多个异步操作时,使用 async/await 可以让代码更易读,更容易组合和管理多个异步操作。
OBJ 或 STL 文件 第三方资源
  • 下载模型的站点:
    • creazilla

总结

  • 案例特点
    在加载大型网格模型,进度条让用户了解加载的进度,提高用户体验。 用户可以通过颜色选择器为模型上色,实现个性化定制。

  • 价值
    可以用于展示各种3D模型,如产品设计、建筑模型、艺术作品等,让用户可以从不同角度查看模型的细节,这在产品设计、游戏开发等领域非常有用。

  • 实现效果展示
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/68587.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大数据治理实战:架构、方法与最佳实践

&#x1f4dd;个人主页&#x1f339;&#xff1a;一ge科研小菜鸡-CSDN博客 &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; 1. 引言 大数据治理是确保数据质量、合规性和安全性的重要手段&#xff0c;尤其在数据驱动决策和人工智能应用日益普及的背景下&…

【时时三省】(C语言基础)文件的随机读写

山不在高&#xff0c;有仙则名。水不在深&#xff0c;有龙则灵。 ----CSDN 时时三省 fseek 根据文件指针的位置和偏移量来定位文件指针 示例&#xff1a; 这个输出的就是ade seek&#xff3f;cur的意思是从当前偏移量 2就是从a往后偏移两个就是d 偏移量 SEEK&#xff3f;CUR…

均方误差(MSE)揭秘:预测模型的“真面目”

前言 在这个充满数据的世界里,我们需要各种方式来衡量一个模型的表现,尤其在回归问题中,均方误差(MSE)是我们非常常见的“好朋友”。它就像一位忠诚的侦探,默默为我们揭示预测值与实际值之间的真相。今天,让我们一起进入均方误差的世界,看看它是如何用简单却有效的方式…

yolov5错误更改与相关参数详解(train.py)

1.错误更改 main中相关参数 if __name__ __main__:parser argparse.ArgumentParser()parser.add_argument(--weights, typestr, default, helpinitial weights path)parser.add_argument(--cfg, typestr, defaultmodels/yolov5s.yaml, helpmodel.yaml path)parser.add_arg…

第4章 基于中点电流的NPC逆变器中点电压平衡策略

1. 工作原理 1.1 NPC型三电平逆变器工作原理 NPC型三相三电平逆变器有A、B、C三个桥臂&#xff0c;其组成结构是相同的&#xff0c;本章以A相为例&#xff0c;对其工作原理进行分析。开关器件SA1和SA3、SA2和SA4为互补器件&#xff0c;通过控制开关器件的导通和关断状态&#…

【C++】内联函数inline、关键字auto与新式for

内联函数 内联函数背景 我们在使用C语言中我们都学过函数&#xff0c;我们知道函数在调用的过程中需要开辟栈帧。如果我们需要频繁的调用一个函数&#xff0c;假设我们调用10次Add()函数&#xff0c;那我们就需要建立10次栈帧。我们都知道在栈帧中要做很多事情&#xff0c;例如…

【深度学习】图像分类数据集

图像分类数据集 MNIST数据集是图像分类中广泛使用的数据集之一&#xff0c;但作为基准数据集过于简单。 我们将使用类似但更复杂的Fashion-MNIST数据集。 %matplotlib inline import torch import torchvision from torch.utils import data from torchvision import transfo…

DeepSeek-R1:多阶段训练提升推理能力

标题&#xff1a;DeepSeek-R1&#xff1a;多阶段训练提升推理能力 文章信息摘要&#xff1a; DeepSeek-R1通过结合监督学习与强化学习的多阶段训练方法&#xff0c;显著提升了大型语言模型的推理能力&#xff0c;尤其在处理复杂数学问题时表现优异。该方法克服了纯强化学习模型…

以创新芯片技术助力科技发展

在当今数字化与智能化浪潮中&#xff0c;芯片作为现代科技的核心&#xff0c;正悄然推动着各个行业的变革。厦门国科安芯科技有限公司专注于高性能芯片的研发与创新&#xff0c;致力于为工业、汽车和商业航天等领域提供高效、可靠的解决方案。以下是国科安芯推出的几款具有代表…

【MySQL — 数据库增删改查操作】深入解析MySQL的 Retrieve 检索操作

Retrieve 检索 示例 1. 构造数据 创建表结构 create table exam1(id bigint, name varchar(20) comment同学姓名, Chinesedecimal(3,1) comment 语文成绩, Math decimal(3,1) comment 数学成绩, English decimal(3,1) comment 英语成绩 ); 插入测试数据 insert into ex…

Ansible自动化运维实战--通过role远程部署nginx并配置(8/8)

文章目录 1、准备工作2、创建角色结构3、编写任务4、准备配置文件&#xff08;金甲模板&#xff09;5、编写变量6、编写处理程序7、编写剧本8、执行剧本Playbook9、验证-游览器访问每台主机的nginx页面 在 Ansible 中&#xff0c;使用角色&#xff08;Role&#xff09;来远程部…

RNN实现阿尔茨海默症的诊断识别

本文为为&#x1f517;365天深度学习训练营内部文章 原作者&#xff1a;K同学啊 一 导入数据 import torch.nn as nn import torch.nn.functional as F import torchvision,torch from sklearn.preprocessing import StandardScaler from torch.utils.data import TensorDatase…

【新春特辑】2025年春节技术展望:蛇年里的科技创新与趋势预测

&#x1f525;【新春特辑】2025年春节技术展望&#xff1a;蛇年里的科技创新与趋势预测 &#x1f4c5; 发布日期&#xff1a;2025年01月29日&#xff08;大年初一&#xff09; 在这个辞旧迎新的美好时刻&#xff0c;我们迎来了充满希望的2025年&#xff0c;也是十二生肖中的蛇…

使用 Docker + Nginx + Certbot 实现自动化管理 SSL 证书

使用 Docker Nginx Certbot 实现自动化管理 SSL 证书 在互联网安全环境日益重要的今天&#xff0c;为站点或应用部署 HTTPS 已经成为一种常态。然而&#xff0c;手动申请并续期证书既繁琐又容易出错。本文将以 Nginx Certbot 为示例&#xff0c;基于 Docker 容器来搭建一个…

C++11新特性之使用using(代替typedef)定义别名

1.介绍 传统的C使用typedef重定义一个类型存在一些限制&#xff0c;例如无法直接重定义一个模版。如下所示。 template <typename Val> struct str_map {typedef std::map<std::string, Val> type; };str_map<int>::type map1; 需要添加额外的类来实现&…

编程题-最长的回文子串(中等)

题目&#xff1a; 给你一个字符串 s&#xff0c;找到 s 中最长的回文子串。 示例 1&#xff1a; 输入&#xff1a;s "babad" 输出&#xff1a;"bab" 解释&#xff1a;"aba" 同样是符合题意的答案。示例 2&#xff1a; 输入&#xff1a;s &…

maven、npm、pip、yum官方镜像修改文档

文章目录 Maven阿里云网易华为腾讯云 Npm淘宝腾讯云 pip清华源阿里中科大华科 Yum 由于各博客繁杂&#xff0c;本文旨在记录各常见镜像官网&#xff0c;及其配置文档。常用镜像及配置可评论后加入 Maven 阿里云 官方文档 setting.xml <mirror><id>aliyunmaven&l…

CNN-GRU卷积门控循环单元时间序列预测(Matlab完整源码和数据)

CNN-GRU卷积门控循环单元时间序列预测&#xff08;Matlab完整源码和数据&#xff09; 目录 CNN-GRU卷积门控循环单元时间序列预测&#xff08;Matlab完整源码和数据&#xff09;预测效果基本介绍CNN-GRU卷积门控循环单元时间序列预测一、引言1.1、研究背景与意义1.2、研究现状1…

HTML-新浪新闻-实现标题-样式1

用css进行样式控制 css引入方式&#xff1a; --行内样式&#xff1a;写在标签的style属性中&#xff08;不推荐&#xff09; --内嵌样式&#xff1a;写在style标签中&#xff08;可以写在页面任何位置&#xff0c;但通常约定写在head标签中&#xff09; --外联样式&#xf…

搜索引擎友好:设计快速收录的网站架构

本文来自&#xff1a;百万收录网 原文链接&#xff1a;https://www.baiwanshoulu.com/14.html 为了设计一个搜索引擎友好的网站架构&#xff0c;以实现快速收录&#xff0c;可以从以下几个方面入手&#xff1a; 一、清晰的目录结构与层级 合理划分内容&#xff1a;目录结构应…