WebODM生成3DTiles模型在Cesium地图上会垂直显示问题解决(y-up-to-z-up)

问题描述

3dtiles模型生成后,在Cesium中显示时,y轴向上,z轴向上,x轴向上,导致模型显示异常,无法正常显示

问题原因

WebODM是先生成glb模型,而后再进行3dtiles转换; glb模型一般是y轴向上,所以转换后的3dtiles模型也是Y轴向上; WebODM生成的3dtile是使用其自研的Obj2Tiles🔗进行转换的,但Obj2Tiles其实是有z-up的api配置; 由于WebODM在调用Obj2Tiles的时候没有做z-up的配置选项,故而需要修改调用源代码;

解决思路

修改ODM🔗仓库内的ogctiles.py🔗代码,如下:

python 复制代码
    # .......上文忽略......

      try:
        kwargs = {
            'input': input_obj,
            'output': output_path,
            'divisions': divisions,
            'lat': lat,
            'lon': lon,
            'alt': alt,
        }
        system.run('Obj2Tiles "{input}" "{output}" --divisions {divisions} --lat {lat} --lon {lon} --alt {alt} '.format(**kwargs))

    # 改为以下↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓

    try:
        kwargs = {
            'input': input_obj,
            'output': output_path,
            'divisions': divisions,
            'lat': lat,
            'lon': lon,
            'alt': alt,
        }
        CmdStr = 'Obj2Tiles "{input}" "{output}" --divisions {divisions} --lat {lat} --lon {lon} --alt {alt}'.format(**kwargs)
        # 方向转换,空格不可缺
        CmdStr += ' --y-up-to-z-up'

        system.run(CmdStr)

  # .......下文忽略......

具体操作

WebODM安装参考: 透過WSL2在Windows執行WebODM🔗

在docker中安装好WebODM仓库后,使用docker命令行进入 名称为 webodm-node-odm-1 的容器中, cd进入仓库目录 /code/opendm,然后修改其文件下的ogctiles.py文件

shell 复制代码
# 1. 查看容器列表,找到odm服务容器,一般名称都为 webodm-node-odm-1
docker ps -a 

# 2. 将容器内的文件复制到服务器目录下
docker cp webodm-node-odm-1:/code/opendm/ogctiles.py /服务器某个目录/ogctiles.py 

# 3. 将文件中的代码添加--y-up-to-z-up,如上述代码

# 4. 将修改后的文件复制回容器中
docker cp /服务器某个目录/ogctiles.py webodm-node-odm-1:/code/opendm/ogctiles.py

# 5. 进入容器内部
docker exec -it webodm-node-odm-1 bash

# 6. 查看文件是否已更改
cat /code/opendm/ogctiles.py

# 7. 如未更改则重新复制,已更改则重启docker应用
相关推荐
花归去2 分钟前
echarts 柱状图曲线图
开发语言·前端·javascript
喝拿铁写前端2 分钟前
当 AI 会写代码之后,我们应该怎么“管”它?
前端·人工智能
老前端的功夫6 分钟前
TypeScript 类型魔术:模板字面量类型的深层解密与工程实践
前端·javascript·ubuntu·架构·typescript·前端框架
Nan_Shu_61430 分钟前
学习: Threejs (2)
前端·javascript·学习
G_G#38 分钟前
纯前端js插件实现同一浏览器控制只允许打开一个标签,处理session变更问题
前端·javascript·浏览器标签页通信·只允许一个标签页
@大迁世界1 小时前
TypeScript 的本质并非类型,而是信任
开发语言·前端·javascript·typescript·ecmascript
GIS之路1 小时前
GDAL 实现矢量裁剪
前端·python·信息可视化
是一个Bug1 小时前
后端开发者视角的前端开发面试题清单(50道)
前端
Amumu121381 小时前
React面向组件编程
开发语言·前端·javascript
持续升级打怪中1 小时前
Vue3 中虚拟滚动与分页加载的实现原理与实践
前端·性能优化