news 2026/6/15 13:56:18

JSAPIThree 加载 3D Tiles 学习笔记:大规模三维场景渲染

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
JSAPIThree 加载 3D Tiles 学习笔记:大规模三维场景渲染

在实际项目中,我们经常需要加载大规模的三维场景数据,比如城市建筑模型、地形数据等。3D Tiles 是 Cesium 提出的开放标准,用于高效地流式传输和渲染大量 3D 内容。今天就来学习一下如何在 mapvthree 中使用 3D Tiles。

了解 3D Tiles

3D Tiles 是一种用于流式传输和渲染大量 3D 内容的开放标准,具有以下特点:

  • 层次化结构:使用空间层次结构组织数据,支持细节层次(LOD)
  • 流式传输:按需加载,只加载视野内的数据
  • 高性能:通过剔除、LOD 等技术优化渲染性能
  • 标准化:开放标准,支持多种数据格式

我的理解:3D Tiles 就像是一个智能的三维场景管理系统,能够根据相机位置和视角,自动决定加载哪些数据,以及加载到哪个细节层次。

第一步:从 URL 加载 3D Tiles

最简单的方式是从 URL 加载 3D Tiles 数据。

基本使用

import*asmapvthreefrom'@baidumap/mapv-three';constcontainer=document.getElementById('container');constengine=newmapvthree.Engine(container,{map:{center:[105.931,29.349,280],range:2000,pitch:75,provider:null,},});// 从 URL 加载 3D Tilesconsttileset=engine.add(newmapvthree.Default3DTiles({url:'data/3dtiles/tileset.json',}));

我的发现:只需要提供tileset.json的 URL,引擎会自动加载整个 3D Tiles 数据集。

我的理解

  • tileset.json是 3D Tiles 的入口文件,定义了整个数据集的层次结构
  • 引擎会根据相机位置自动加载需要的瓦片
  • 支持多种 3D Tiles 格式(b3dm、i3dm、pnts 等)

第二步:从 Cesium Ion 加载

如果数据存储在 Cesium Ion 上,可以使用 asset ID 加载。

使用 fromAssetId

// 从 Cesium Ion asset ID 加载consttileset=awaitmapvthree.Default3DTiles.fromAssetId('assetId',{errorTarget:16,});engine.add(tileset);

我的发现fromAssetId是静态方法,返回一个 Promise,需要等待加载完成。

我的理解

  • 需要先配置 Cesium Ion AccessToken
  • asset ID 是 Cesium Ion 中资源的唯一标识
  • 可以使用配置参数来优化加载和渲染

第三步:性能优化配置

3D Tiles 提供了很多性能优化参数,合理配置可以显著提升渲染性能。

errorTarget:屏幕空间误差

errorTarget控制屏幕空间误差目标值,影响 LOD 的切换时机。

consttileset=engine.add(newmapvthree.Default3DTiles({url:'data/3dtiles/tileset.json',errorTarget:16,// 默认值,数值越小,细节越多,性能开销越大}));

我的理解

  • 数值越小,显示的细节越多,但性能开销越大
  • 数值越大,显示的细节越少,但性能更好
  • 需要根据场景和性能要求调整

cullRequestsWhileMoving:移动时剔除

cullRequestsWhileMoving控制相机移动时是否剔除请求,可以提升移动时的性能。

consttileset=engine.add(newmapvthree.Default3DTiles({url:'data/3dtiles/tileset.json',cullRequestsWhileMoving:true,// 移动时剔除请求,提升性能}));

我的发现:开启后,相机快速移动时不会加载新瓦片,等移动停止后再加载,可以避免不必要的网络请求。

cullWithChildrenBounds:使用子节点边界剔除

cullWithChildrenBounds控制是否使用子节点边界进行剔除,可以更精确地判断是否需要加载子节点。

consttileset=engine.add(newmapvthree.Default3DTiles({url:'data/3dtiles/tileset.json',cullWithChildrenBounds:true,// 使用子节点边界进行剔除}));

我的理解:开启后,会使用子节点的边界框来判断是否需要加载,可以更精确地剔除不可见的节点。

loadSiblings:加载兄弟节点

loadSiblings控制是否加载兄弟节点,可以预加载相邻的瓦片。

consttileset=engine.add(newmapvthree.Default3DTiles({url:'data/3dtiles/tileset.json',loadSiblings:true,// 加载兄弟节点,预加载相邻瓦片}));

我的发现:开启后,会预加载相邻的瓦片,当相机移动到相邻区域时,数据已经准备好了,可以提升用户体验。

其他性能参数

还有一些高级性能参数:

consttileset=engine.add(newmapvthree.Default3DTiles({url:'data/3dtiles/tileset.json',// 缓存配置cacheBytes:512*1024*1024,// 缓存大小(字节)// 动态屏幕空间误差dynamicScreenSpaceError:true,dynamicScreenSpaceErrorDensity:0.00278,dynamicScreenSpaceErrorHeightFalloff:0.25,// 注视点渲染(Foveated Rendering)foveatedScreenSpaceError:true,foveatedConeSize:0.1,foveatedMinimumScreenSpaceErrorRelaxation:2.0,// 其他配置forceUnlit:false,// 强制无光照模式progressiveResolutionHeightFraction:0.3,}));

我的理解:这些参数主要用于高级优化,一般使用默认值即可,除非有特殊的性能需求。

第四步:运行时调整参数

可以在运行时动态调整参数,实时优化性能。

consttileset=engine.add(newmapvthree.Default3DTiles({url:'data/3dtiles/tileset.json',errorTarget:16,}));// 运行时调整参数tileset.errorTarget=8;// 提高细节tileset.cullRequestsWhileMoving=true;// 开启移动剔除tileset.loadSiblings=true;// 开启兄弟节点加载

我的发现:可以根据场景需求动态调整参数,比如在性能不足时降低errorTarget,在需要流畅移动时开启cullRequestsWhileMoving

第五步:完整示例

我想写一个完整的示例,把学到的都用上:

import*asmapvthreefrom'@baidumap/mapv-three';constcontainer=document.getElementById('container');constengine=newmapvthree.Engine(container,{map:{center:[105.931,29.349,280],range:2000,pitch:75,provider:null,},});// 从 URL 加载 3D Tiles,配置性能参数consttileset=engine.add(newmapvthree.Default3DTiles({url:'data/3dtiles/tileset.json',errorTarget:16,cullRequestsWhileMoving:true,cullWithChildrenBounds:true,loadSiblings:true,}));

我的感受:掌握了这些配置,就可以根据实际需求优化 3D Tiles 的加载和渲染性能了!

第六步:踩过的坑

作为一个初学者,我踩了不少坑,记录下来避免再犯:

坑 1:3D Tiles 不显示

原因:URL 路径错误,或者 tileset.json 文件不存在。

解决

  1. 检查 URL 路径是否正确
  2. 确认 tileset.json 文件存在且可访问
  3. 检查浏览器控制台是否有错误信息

坑 2:加载很慢

原因:数据量大,或者网络慢,或者性能参数配置不当。

解决

  1. 检查网络连接
  2. 调整errorTarget参数,降低细节要求
  3. 开启cullRequestsWhileMoving优化移动性能
  4. 检查数据是否过大,考虑使用 LOD 优化

坑 3:内存占用过高

原因:缓存设置过大,或者加载了太多瓦片。

解决

  1. 调整cacheBytes参数,限制缓存大小
  2. 降低errorTarget,减少加载的瓦片数量
  3. 开启cullWithChildrenBounds精确剔除

坑 4:相机移动卡顿

原因:移动时加载了太多新瓦片,或者性能参数配置不当。

解决

  1. 开启cullRequestsWhileMoving,移动时暂停加载
  2. 开启loadSiblings,预加载相邻瓦片
  3. 调整errorTarget,降低细节要求

坑 5:Cesium Ion 加载失败

原因:没有配置 Cesium Ion AccessToken,或者 asset ID 错误。

解决

  1. 确保配置了 Cesium Ion AccessToken
  2. 检查 asset ID 是否正确
  3. 确认 asset ID 对应的资源存在且有访问权限

我的学习总结

经过这一天的学习,我掌握了:

  1. 从 URL 加载:使用new Default3DTiles({ url })从 URL 加载
  2. 从 Cesium Ion 加载:使用Default3DTiles.fromAssetId()从 Cesium Ion 加载
  3. 性能优化:理解errorTargetcullRequestsWhileMoving等参数的作用
  4. 运行时调整:可以在运行时动态调整参数

我的感受:3D Tiles 功能很强大,但配置参数也比较多。关键是要理解每个参数的作用,然后根据实际需求进行优化。性能优化是一个平衡的过程,需要在细节和性能之间找到平衡点!

下一步计划

  1. 学习更多 3D Tiles 的高级功能
  2. 尝试创建自定义的 3D Tiles 数据
  3. 做一个完整的大规模场景展示项目

学习笔记就到这里啦!作为一个初学者,我觉得 3D Tiles 功能很强大,但配置参数也比较多。关键是要理解每个参数的作用,然后根据实际需求进行优化。希望我的笔记能帮到其他初学者!大家一起加油!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 11:45:39

LobeChat能否实现思维发散引导?头脑风暴AI教练

LobeChat能否实现思维发散引导?头脑风暴AI教练 在创意枯竭的深夜,面对空白文档反复删改标题的产品经理;在课堂上试图激发学生想象力却陷入“标准答案”惯性的教师;在心理咨询室中努力帮助来访者打开表达通道的心理工作者——他们共…

作者头像 李华
网站建设 2026/6/15 5:59:00

人工智能之数字生命---绘画能力的生成3

下面这份清单按约束来:世界树中“存在”只有一层;更细的“子存在/局部世界”放到附属世界树里;因此这里只列需要“复合规则”才能生成/比较/还原的特征类型(= 不是单一标量就能表达/比较的那种)。 说明:像 位置X/Y/Z、尺寸_左右/上下/前后 这类原子标量特征不在此列。 1)…

作者头像 李华
网站建设 2026/6/15 11:49:11

现在数字生命已经能“看清物体的内部结构”了!

设计目标 输入:一个主存在的高分辨率裁剪图像 精确掩膜(来自点簇增强结果)输出:多个子存在观测(如杯子的把手、瓶盖、人的手臂等)递归:每个子存在可继续提取更细孙存在(支持任意深度…

作者头像 李华
网站建设 2026/6/15 11:47:31

为什么网盘不能彻底取代硬盘呢?

存储备份和只读、文档编辑等场景,网盘和NAS可以代替硬盘功能,但网盘需要依赖网络,比如安装操作系统、剪辑高清电影、游戏场景等对数据传输有要求的场景更适合硬盘。网盘和本地硬盘的核心差异在于数据控制权、访问稳定性和传输效率&#xff0c…

作者头像 李华
网站建设 2026/6/14 21:38:12

终极指南:用Applite轻松实现macOS应用管理的完整方案

终极指南:用Applite轻松实现macOS应用管理的完整方案 【免费下载链接】Applite User-friendly GUI macOS application for Homebrew Casks 项目地址: https://gitcode.com/gh_mirrors/ap/Applite 在当今数字时代,macOS用户面临着日益复杂的应用管…

作者头像 李华
网站建设 2026/6/14 10:56:23

Lucky Draw抽奖系统全面使用手册

Lucky Draw是一款基于Vue.js开发的轻量级企业年会抽奖程序,支持自定义抽奖规则、数据本地存储和结果展示功能,无需后端服务即可快速部署使用。 【免费下载链接】lucky-draw 年会抽奖程序 项目地址: https://gitcode.com/gh_mirrors/lu/lucky-draw …

作者头像 李华