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应用
相关推荐
光影少年3 小时前
react状态管理都有哪些及优缺点和应用场景
前端·react.js·前端框架
saber_andlibert4 小时前
TCMalloc底层实现
java·前端·网络
逍遥德4 小时前
如何学编程之01.理论篇.如何通过阅读代码来提高自己的编程能力?
前端·后端·程序人生·重构·软件构建·代码规范
冻感糕人~4 小时前
【珍藏必备】ReAct框架实战指南:从零开始构建AI智能体,让大模型学会思考与行动
java·前端·人工智能·react.js·大模型·就业·大模型学习
程序员agions4 小时前
2026年,“配置工程师“终于死绝了
前端·程序人生
alice--小文子5 小时前
cursor-mcp工具使用
java·服务器·前端
晚霞的不甘5 小时前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
小迷糊的学习记录5 小时前
0.1 + 0.2 不等于 0.3
前端·javascript·面试
梦帮科技6 小时前
Node.js配置生成器CLI工具开发实战
前端·人工智能·windows·前端框架·node.js·json
VT.馒头6 小时前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript