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

诚信宁津建设网站宁波网络营销公司

诚信宁津建设网站,宁波网络营销公司,友情链接交换教程,恩施网页设计原生的 three.js 目前不支持 3d tiles 数据的加载#xff0c;不过开源社区已经给出了一些解决方案#xff0c;其中最活跃的要属 3DTilesRendererJS。它为 three.js 提供了加载和调度 3d tiles 数据的基本能力#xff0c;虽说和 Cesium.js 对 3d tiles 的支持相比还有很大的差…原生的 three.js 目前不支持 3d tiles 数据的加载不过开源社区已经给出了一些解决方案其中最活跃的要属 3DTilesRendererJS。它为 three.js 提供了加载和调度 3d tiles 数据的基本能力虽说和 Cesium.js 对 3d tiles 的支持相比还有很大的差距但也比没有的好。毕竟 3d tiles 数据的加载和调度还是比较复杂的要自己写也没那么容易这一点在以前研究 Cesium.js 相关源码的时候就深有体会。 3DTilesRendererJS 最核心的类是 TilesRenderer用来渲染和调度一份 3d tiles 数据相当于Cesium.js 里的 Cesium3DTileset。使用起来非常简单构造的时候传入 JSON 文件的 url 即可。 const tileset new TilesRenderer(http://localhost:8080/XXX/tileset.json); 构造 TilesRenderer 实例 接着需要把 TilesRenderer 实例和 three.js 的 camera 以及 renderer 关联起来根据 three.js 的相机和渲染器参数来设置切片显示的分辨率。 tileset.setCamera(camera); tileset.setResolutionFromRenderer(camera, renderer); 关联 three.js 的相机和渲染器参数  很多 3d tiles 数据都是做了顶点压缩或纹理压缩的比如顶点的 DRACO 压缩、KTX2 和 DDS 等纹理压缩格式对于这类数据需要在GLTF解析器GLTFLoader中添加解压缩的能力。下面以解压缩 DRACO 为例用代码加以说明。 // 配置GLTF数据的解析器 const dracoLoader new DRACOLoader(); dracoLoader.setDecoderPath(./jsm/libs/draco/gltf/);const loader new GLTFLoader(tileset.manager); loader.setDRACOLoader(dracoLoader); tileset.manager.addHandler(/\.gltf$/, loader); 为GLTF解析器配置解压缩 DRACO 的能力  3d tiles数据以往基本上都是在 WGS84椭球上呈现的。现在要在 three.js 的局部场景下展示则需要把它放在局部场景相机的视野范围内并保证数据的上方向正确。这里封装了一个 adjustTilesPositionAndDirection 方法将数据放置在局部场景的中心并将Y轴正方向Y作为数据的上方向。这样数据在 three.js 三维场景中就能正常摆放了。 function rotationBetweenDirections(dir1, dir2) {const rotation new THREE.Quaternion();const a new THREE.Vector3().crossVectors(dir1, dir2);rotation.x a.x;rotation.y a.y;rotation.z a.z;rotation.w 1 dir1.clone().dot(dir2);rotation.normalize();return rotation; }function adjustTilesPositionAndDirection(tiles) {if (!tiles) {return;}const sphere new THREE.Sphere();tiles.getBoundingSphere(sphere);const position sphere.center.clone();const distanceToEllipsoidCenter position.length();const surfaceDirection position.normalize();const up new THREE.Vector3(0, 1, 0);const rotationToNorthPole rotationBetweenDirections(surfaceDirection, up);tiles.group.quaternion.x rotationToNorthPole.x;tiles.group.quaternion.y rotationToNorthPole.y;tiles.group.quaternion.z rotationToNorthPole.z;tiles.group.quaternion.w rotationToNorthPole.w;tiles.group.position.y - distanceToEllipsoidCenter; } 调整数据在 three.js 场景中的位置和上方向  最后在每一帧渲染时都去执行一次 TilesRenderer 的更新。至此一份3d tiles数据的基本加载就完成了。 function renderLoop() {// 更新 TilesRenderer 之前需要更新 three.js 的相机参数camera.updateMatrixWorld();tileset.update(); // 更新 TilesRendererrenderer.render(scene, camera); } 每一帧都更新 TilesRenderer  以上是使用 3DTilesRendererJS 的基本流程。还可以做一些辅助工作。 可以根据需要为数据注册一些插件可选的插件在官方文档中查看。下面的示例以调试插件为例简要说明插件的注册和使用方式。 // 注册调试插件 tileset.registerPlugin(new DebugTilesPlugin());// ...// 获取调试插件并显示包围盒的线框 tileset.getPluginByName(DEBUG_TILES_PLUGIN).displayBoxBounds true; 插件的注册和使用  当场景中加载了多份 3d tiles 数据时最好共享内存和下载队列以减少性能开销。 // 设置图层1的缓存大小 tileset.lruCache.minSize 900; tileset.lruCache.maxSize 1300;// 图层2和图层1共享内存和下载队列以减少性能开销 tileset2.lruCache tileset.lruCache; tileset2.downloadQueue tileset.downloadQueue; tileset2.parseQueue tileset.parseQueue; 共享内存和下载队列 个人觉得和 Cesium.js 相比3DTilesRendererJS 加载和调度 3d tiles 的能力还是挺弱的。小场景、和数据之间交互操作、修改要求不那么高的情况下可以尝试。如果是做大场景下的 GIS 应用也许 Cesium.js 和 Three.js 做深度融合绘制在同一个 canvas 上深度值做统一GIS 功能交给 Cesium.jsThree.js 做一些效果上的补充可能会是更好的方案。
http://www.hkea.cn/news/14294823/

相关文章:

  • 在线游戏网站40岁软件工程师的出路
  • 广州市 住房建设局网站常州网站建设联系电话
  • 深圳网站和app建设wordpress添加主题不显示
  • 杭州设计网站最好的公司做营销网站建设
  • 网页版快手重庆seo排名公司
  • 金寨建设工程质量监督站网站wordpress feed
  • 发外链的网站排名茂名哪里有网站开发公司
  • 北京建网站公司推荐江苏盐城建筑公司网站
  • 使用jquery的网站域名站长工具
  • 单位做网站资料需要什么郑州百度推广开户
  • 汉中专业网站建设公司百度权重怎么提高
  • 渭南市住房和城乡建设局官方网站潍坊网络推广
  • 服装设计有哪些网站合肥seo推广公司
  • 自己做衣服网站新手怎么开网店
  • 找设计案例的网站如何建设网站咨询跳转页面
  • 东莞正规的免费网站优化wordpress多大vps
  • 烟台企业自助建站系统网址信息查询
  • 如何建设盈利网站wordpress付费会员
  • 荣县网站开发做彩票网站需要学习什么
  • 定制开发网站如何报价公司网站优化推广方案
  • 商城网站模板建设网站推广定义
  • 售后服务方案 网站建设建设网站总结
  • 论坛网站开发技术福建设计招标网站
  • 修改目录wordpress共享门店新增跑腿距离计算优化
  • seo网站建设方案手机百度app下载安装
  • Ie8网站后台编辑文章百度快速收录技术
  • 个体搞网站建设 经营范围怎么把网站设置为主页面
  • 网站开发外包费用焦作网站建设公司哪家好
  • 网站建站费用多少钱怎么开电商
  • 机票旅游网站开发网站建设合同的内容与结构