threejs加载3dtiles(倾斜摄影)数据

1、安装 3dTilesRenderer 插件

使用npm 安装 

npm install 3d-tiles-renderer --save

或者去官网下载都行

GitHub - NASA-AMMOS/3DTilesRendererJS: Renderer for 3D Tiles in Javascript using three.js

2、使用

首先引入,在填入3dtiles数据的地址,可以是文件路径也可以是网站路径

const tilesRenderer = new TilesRenderer( './path/to/tileset.json' );

const tilesRenderer = new TilesRenderer( 'http://192.168.1.136:8080/path/to/tileset.json' );

注意在动画函数中添加更新  tilesRenderer.update();

import { TilesRenderer } from '3d-tiles-renderer';

// ... initialize three scene ...

const tilesRenderer = new TilesRenderer( './path/to/tileset.json' );
tilesRenderer.setCamera( camera );
tilesRenderer.setResolutionFromRenderer( camera, renderer );
scene.add( tilesRenderer.group );

animate();

function animate() {
	tilesRenderer.update();
	renderer.render( camera, scene );
    requestAnimationFrame( animate);
}

 3、问题总结

官方的3dtiles数据格式可能与我们自己使用osg2cesiumApp和cesiumlab切片工具切出来的数据格式不同,使用我们自己的数据可能加载不出来,那是因为3dTilesRenderer 插件默认只处理和.b3dm数据同级目录下的.json文件,由官方的数据格式对比可以看出,自己数据的文件夹更深。

 如果将文件夹目录换成更深一级或几级,也是可以正常加载的,但只能加载这一小片。

 所以要处理加载方式,我们查看自己数据的tileset.json发现这里存储着每块的路径,我们就可以取出这些路径一块一块的加载,这样就可以加载全部的3dtiles数据了。

const tilesRendererArr = []
// 加载json,解析json 取出children中的路径进行拼装加载
  const qzpath = 'http://192.168.1.136:8077/sqsftilte/'

  get(qzpath + 'tileset.json').then((res)=>{
    // console.log(res)
    const tilesetArr = res.root.children
    for (const tilese of tilesetArr) {
      // console.log(qzpath + tilese.content.uri)
      tilesRenderer = new TilesRenderer( qzpath + tilese.content.uri )
      tilesRenderer.setCamera( camera )
      tilesRenderer.setResolutionFromRenderer( camera, renderer )
      const tilesObj = tilesRenderer.group
      tilesObj.rotation.set(-Math.PI / 2, 0, 0)
      scene.add( tilesObj )
      tilesRendererArr.push(tilesRenderer)
    }
  })
// 动画
function animate() {
  controls.update()
  for (const tilesRenderer of tilesRendererArr) {
    tilesRenderer.update()
  }
  renderer.render(scene, camera)
  requestAnimationFrame(animate)
}

  • 12
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 29
    评论
在Three.js中3DTiles,可以使用3d-tiles-renderer库来实现。首先,你需要引入`TilesRenderer`类,并初始化一个`TilesRenderer`对象,传入tileset.json的路径作为参数。然后,设置相机和渲染器的分辨率,并将`TilesRenderer`的group添到场景中。最后,在动画函数中调用`tilesRenderer.update()`来更新3DTiles的显示。以下是一个3DTiles的示例代码: ```javascript import { TilesRenderer } from '3d-tiles-renderer'; // 初始化Three.js场景和相机 const tilesRenderer = new TilesRenderer('./path/to/tileset.json'); tilesRenderer.setCamera(camera); tilesRenderer.setResolutionFromRenderer(camera, renderer); scene.add(tilesRenderer.group); animate(); function animate() { tilesRenderer.update(); renderer.render(camera, scene); requestAnimationFrame(animate); } ``` 如果你需要多个3DTiles,你可以创建一个`TilesRenderer`对象的数组,并在tileset.json后循环遍历数组,为每个`TilesRenderer`对象设置相机和渲染器的分辨率,并将其group添到场景中。在动画函数中,循环遍历`TilesRenderer`对象数组,并调用每个对象的`update()`方法来更新3DTiles的显示。以下是一个多个3DTiles的示例代码: ```javascript const tilesRendererArr = \[\]; // tileset.json并解析 const qzpath = 'http://192.168.1.136:8077/sqsftilte/'; get(qzpath + 'tileset.json').then((res) => { const tilesetArr = res.root.children; for (const tilese of tilesetArr) { const tilesRenderer = new TilesRenderer(qzpath + tilese.content.uri); tilesRenderer.setCamera(camera); tilesRenderer.setResolutionFromRenderer(camera, renderer); const tilesObj = tilesRenderer.group; tilesObj.rotation.set(-Math.PI / 2, 0, 0); scene.add(tilesObj); tilesRendererArr.push(tilesRenderer); } }); animate(); function animate() { controls.update(); for (const tilesRenderer of tilesRendererArr) { tilesRenderer.update(); } renderer.render(scene, camera); requestAnimationFrame(animate); } ``` 希望这些代码能帮助你3DTiles到Three.js中。 #### 引用[.reference_title] - *1* *2* [threejs3dtiles倾斜摄影数据](https://blog.csdn.net/m0_54850604/article/details/123431441)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [threejs3dtiles以及gpu picking真实三维坐标点](https://blog.csdn.net/weixin_44464760/article/details/97922823)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 29
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值