大疆智图_空三二维重建成果传输

news2024/11/24 8:30:10

一、软件环境

1.1 所需软件

  1、 大疆智图:点击下载;
  2、 ArcGIS Pro 3.1.5:点击下载,建议使用IDM或Aria2等多线程下载器;
  3、 IDM下载器:点击下载,或自行搜索;
  4、 FastCopy:自行搜索;
  5、 Rclone:自行搜索配置;
  6、 Python:安装软件ArcGIS Pro 3.1.5过程已安装,或自行搜索安装。

1.2 软件介绍

  1、 大疆智图:进行空三、二维重建,软件需授权。无有效授权使用其他同替软件;
  2、 ArcGIS Pro 3.1.5:使用Python脚本进行金字塔构建;
  3、 FastCopy:局域网内成果快速拷贝;
  4、 Rclone:配置账号后,成果上传对外分发;
  以上软件按需使用。

二、大疆智图软件操作

2.1 软件启动

  鼠标双击桌面“DJI Terra”图标,登录账号后进入软件。
在这里插入图片描述

2.2 任务创建

  鼠标点击“新建任务”,选择“可见光”。
在这里插入图片描述输入“任务名称”后点击“确定”。
在这里插入图片描述

2.3 导入照片

点击“添加照片”或“添加文件夹”,等待照片导入。
在这里插入图片描述

2.4 空三(建议操作,可跳过)

点击“空三”,“场景”:普通场景,点击“高级设置”—“像控点管理”。
在这里插入图片描述点击“坐标系”,“水平设置”:建议与二维重建坐标系一致;“高程设置”:按需设置。
在这里插入图片描述点击“空三”,等待重建。
在这里插入图片描述

2.5 空三质量报告导出(建议操作,可跳过)

空三重建完成后,核实无误。点击“空三质量报告”,点击“导出PDF”。
在这里插入图片描述

2.6 二维重建

“分辨率”:高“场景”:测绘场景(一般为测绘场景,农田无高差可选农田场景);
点击“高级设置”,“水平设置”:选择所需坐标系;“高程设置”:按需设置。
在这里插入图片描述
点击“开始重建”,等待重建。

三、成果传输操作

鼠标右键点击“影像_构建金字塔.py”;
选择“Run with ArcGIS Pro”,或选择“Edit with IDLE(ArcGIS Pro)”后按键盘“F5”按键。
在这里插入图片描述
输入“1”后,按“回车”键确认。
在这里插入图片描述输入或粘贴局域网存放成果的路径。
在这里插入图片描述构建金字塔运行情况。
在这里插入图片描述

四、代码

复制以下代码或点击下载脚本文件,并修改(注释、删除)以下(或者更多)参数,确保脚本能够正确执行。
#拼接大疆任务目录
dom_path
# 设置 7-Zip 可执行文件路径
seven_zip_path
# 设置 fcp 可执行文件路径
fcp_path
# 设置 rclone 可执行文件路径
rclone_path
# 设置 rclone 上传文件路径
rclone_up_path
#压缩至E盘根目录
compressed_file

import arcpy
import os
import time
import datetime
import subprocess
import concurrent.futures

# 判断金字塔文件是否存在
def check_ovr_file_exists(file_path):
    start_time = time.time()
    if os.path.isfile(file_path + ".ovr"):
        print(f"已经存在:{file_path} 金字塔文件")
    else:
        print(f"开始构建:{file_path} 金字塔文件")
        arcpy.management.BuildPyramids(file_path)
        end_time = time.time()
        execution_time = end_time - start_time
        td = datetime.timedelta(seconds=execution_time)
        hh, mm, ss = str(td).split(":")  # 将时间差转换为时分秒
        print(f"构建用时:{file_path} 构建{hh}小时{mm}分钟{ss}秒")

# 判断目录是否存在
def check_path_exists(dir_path):   
    if not os.path.exists(dir_path):
        print(f"指定目录:{dir_path} 不存在!")
        exit()

# 同步最新日期文件夹
def sync_update_folder(source_path, destination_path):
    print(f"正在同步:{source_path}")
    command = f'"{fcp_path}" /cmd=sync_update /force_close "{source_path}" /to="{destination_path}"'
    startupinfo = subprocess.STARTUPINFO()
    startupinfo.dwFlags |= subprocess.STARTF_USESHOWWINDOW
    subprocess.run(command, startupinfo=startupinfo, shell=True)

# 同步文件夹
def sync_folder(source_path, destination_path):
    print(f"正在同步:{source_path}")
    command = f'"{fcp_path}" /cmd=sync /force_close "{source_path}" /to="{destination_path}"'
    startupinfo = subprocess.STARTUPINFO()
    startupinfo.dwFlags |= subprocess.STARTF_USESHOWWINDOW
    subprocess.run(command, startupinfo=startupinfo, shell=True)

# 选择目录    
choice = input("待构建金字塔文件DOM路径为:\n1、所在目录\n2、指定目录\n请选择:")
if choice == "1":
    current_file_path = os.path.abspath(__file__)
    folder_path = os.path.dirname(current_file_path)
    #拼接大疆任务目录
    dom_path = os.path.join(folder_path, "PCGSPRO\\XXX")
else:
    dom_path = input("请输入指定目录:")
check_path_exists(dom_path)

# 局域网存放路径
dst_path = input("请输入存放路径:")
check_path_exists(dst_path)

# 多线程处理map目录下dsm.tif与result.tif文件
def process_folder(foldername):
    folder_path = os.path.join(dom_path, foldername)
    if os.path.isdir(folder_path):
        check_ovr_file_exists(os.path.join(folder_path, "map\\dsm.tif"))
        check_ovr_file_exists(os.path.join(folder_path, "map\\result.tif"))

if __name__ == "__main__":
    # 设置 7-Zip 可执行文件路径
    seven_zip_path = r"C:\Program Files\7-Zip\7z.exe"
    # 设置 fcp 可执行文件路径
    fcp_path = r"C:\Program Files\FastCopy5.7.10_x64\fcp.exe"
    # 设置 rclone 可执行文件路径
    rclone_path = r"E:\rclone.exe"
    # 设置 rclone 上传文件路径
    rclone_up_path = "OneDrive:/航飞数据"
    # 压缩文件的列表
    compressed_files = []
    
    # 创建线程池,最大线程为4
    with concurrent.futures.ThreadPoolExecutor(max_workers=4) as executor:
        # 提交任务给线程池
        executor.map(process_folder, os.listdir(dom_path))

    # 局域网同步文件夹
    for foldername in os.listdir(dom_path):
        folder_path = os.path.join(dom_path, foldername)
        if os.path.isdir(folder_path):
            sync_folder(os.path.join(folder_path, "map\\dsm*.*"), os.path.join(dst_path, foldername))
            sync_folder(os.path.join(folder_path, "map\\result*.*"), os.path.join(dst_path, foldername))
            sync_folder(os.path.join(folder_path, "map\\*_质量报告.pdf"), os.path.join(dst_path, foldername, "空三"))
            sync_folder(os.path.join(folder_path, "AT\\report\\POS_residual_of_camera.csv"), os.path.join(dst_path, foldername, "空三"))

    # 压缩文件
    for foldername in os.listdir(dom_path):
        folder_path = os.path.join(dom_path, foldername)
        if os.path.isdir(folder_path):
            compressed_file = f"E:\{foldername}.7z"#压缩至E盘根目录
            compressed_files.append(compressed_file)
            seven_zip_command = [
                seven_zip_path,
                "a",
                compressed_file,
                os.path.join(folder_path, "map", "result.prj"),
                os.path.join(folder_path, "map", "result.tfw"),
                os.path.join(folder_path, "map", "result.tif.ovr"),
                os.path.join(folder_path, "map", "result.tif.xml"),
                os.path.join(folder_path, "map", "result.tif")
            ]
            print(f"正在压缩: {foldername}...")
            subprocess.run(seven_zip_command)

    # 使用 rclone 上传文件的函数
    def upload_file(compressed_file):
        rclone_command = [
            "rclone",
            "sync",
            compressed_file,
            rclone_up_path,
            "--progress"
        ]
        print(f"正在上传: {compressed_file}...")
        subprocess.run(rclone_command)
        print(f"上传成功: {compressed_file}")
    # 异步上传文件
    with concurrent.futures.ThreadPoolExecutor() as executor:
        futures = [executor.submit(upload_file, file) for file in compressed_files]
        concurrent.futures.wait(futures)
    
    # 删除本地 7z 文件
    for file in compressed_files:
        os.remove(file)
        print(f"本地文件: {file} 已删除!")

print("\nOVER!")
input("按任意键继续...")

五、说明

  1、大疆智图空三丢失图片:
  因空三导入的区域不连续,并且接壤的地方没有重叠。导致空三时,无法获取到对应的特征点,从而重建缺失或者失败。只能单独重建或补飞。见官方说明,与客服沟通情况。
在这里插入图片描述
  2、构建金字塔:
  默认使用4线程操作,最大线程数量可修改;
  3、局域网同步:
  sync_update_folder或sync_folder可选,考虑硬盘读写情况,使用FastCopy顺序同步;
  局域网同步也可以搭建webdav等方式后使用rclone同步,速度尚可&省一个软件&省代码;
  4、压缩文件:
  7Z参数可修改,考虑硬盘读写情况,使用7Z顺序压缩;
  5、上传文件:
  配置账号(自行搜索)后,使用rclone异步上传;
  6、删除文件:
  上传文件后删除压缩包节约本地空间。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1804136.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

最近一直没动静的Pika Labs原来在筹集融资,加快构建视频基础模型

Pika 筹集了 8000 万美元,因此任何人都可以根据命令制作视频。 今天对我们来说是一个重要的日子。自从我们从斯坦福大学退学去构建 Pika 以来已经一年了,在这段时间里,我们在 Discord 上进行了秘密发布,发布了我们的 1.0 模型和 …

找了半天,还不如自己写一个图片转ico格式的程序

关于jpg、png等图片转ICO格式 最近突然急需一张ico格式的文件,就拿着处理好的png图片出网上找在线转换器,找了一个小时,绝了,不是需要注册充钱就是下载不下来,好不容易下载下来还是个文件错误。想着找个PS插件直接导出…

2024 cicsn ezbuf

文章目录 参考protobuf逆向学习复原结构思路exp 参考 https://www.y4ng.cn/posts/pwn/protobuf/#ciscn-2024-ezbuf protobuf 当时压根不知道用了protobuf这个玩意,提取工具也没提取出来,还是做题做太少了,很多关键性的结构都没看出来是pro…

WEB漏洞服务能提供哪些帮助

在数字化浪潮的推动下,Web应用程序已成为企业展示形象、提供服务、与用户进行交互的重要平台。然而,随着技术的飞速发展,Web应用程序中的安全漏洞也日益显现,成为网络安全的重大隐患。这些漏洞一旦被恶意攻击者利用,可…

极简主义在UI设计中的应用及解析

极简主义,即“少就是多”。在设计中,极简主义是许多艺术概念之一,它描述了一种内容形式,可以在许多方面使用。现在移动UI界面和网页设计中的极简主义设计越来越多。即时设计认为,极简主义UI界面不仅美观,而…

The 18th Northeast Collegiate Programming Contest(5/9/13)

心得 赛中ac:5,目前ac:9,题目总数:13 中档可做题还是很多的,可惜遇到了难绷的queueforces, 最后15min才判出来,oi赛制5wa4遗憾离场,赛后把几个题都给调过了&#xff0…

mysql (事物)

一.什么是事物 事物是一组操作的集合,不可分割的工作单位,事物会把所有的操作当作一个整体一起向系统提交或撤销操作请求,就是这些操作要么一起成功要么一起失败。 二.事物操作 (这个就是一个理解) 1.事务特性 原子性…

MongoDB CRUD操作:可重试写入

MongoDB CRUD操作:可重试写入 文章目录 MongoDB CRUD操作:可重试写入使用的先决条件部署的限制支持的存储引擎3.6 MongoDB 驱动程序MongoDB 版本写确认 可重试写入和多文档事务启用可重试写入MongoDB驱动mongosh 可重试的写操作行为持续的网络错误故障切…

46-1 护网溯源 - 钓鱼邮件溯源

一、客户提供钓鱼邮件样本 二、行为分析 三、样本分析 对钓鱼邮件中的木马程序1111.exe文件进行了分析,提交了360安全大脑沙箱云和微步在线云沙箱。 360安全大脑沙箱云显示,该1111.exe文件存在危险,因此在解压时需要谨慎操作,以免触发木马程序。 建议使用360压缩软件进行…

Chrome DevTools

Console 面板 此章节请打开 justwe7.github.io/devtools/console/console.html 一起食用 一方面用来记录页面在执行过程中的信息(一般通过各种 console 语句来实现),另一方面用来当做 shell 窗口来执行脚本以及与页面文档、DevTools 等进行交…

Linux云计算架构师涨薪班就业服务有哪些?

学员一站式就业服务:一次学习,薪资翻倍 简历制作与指导 学员在培训期间,人才顾问会提供简历制作和指导服务,帮助学员制作出一份专业、有吸引力的简历。简历是求职者给招聘单位的第一印象,因此非常重要 模拟面试与技巧指导 为了让…

一种方法实现latex公式中显示空格

要解决的问题 我想要实现latex中出现空格。比如打出 Dice coefficients,然而一般情况下是不会显示出这两个单词之间的空格的,对吧。 解决方法 使用 \verb| |。 D i c e c o e f f i c i e n t s Dice coefficients Dicecoefficients D i c e c o e f f i c i e …

还不会线程池?JUC线程池源码级万字解析

线程池主要解决了两个问题: 第一个是当大量执行异步任务的时候提供较好的性能;在不使用线程池的时候,每次需要执行一个异步任务都需要新建一个 Thread 来进行,而线程的创建和销毁都是需要时间的,所以可以通过线程池来实…

数据集笔记:DGraph 大规模动态图数据集

dgraph-web (xinye.com) 1 数据集介绍 DGraph 是一个有向无权的动态图,包含超过 370 万个节点以及 430 万条动态边DGraph 中的节点表示金融借贷用户,有向边表示紧急联系人关系,每个节点包含脱敏后的属性特征,以及表示是否为金融…

Java 的循环

Java 有三种循环&#xff1a;for&#xff0c;while&#xff0c;do while。 for 基本语法&#xff1a; for (循环变量初始化; 循环条件; 循环变量迭代){循环语句; }程序示例&#xff1a; public static void main(String[] args) {for (int i 0, j 0; i < 3; i, j--) {…

45-2 waf绕过 - XSS 绕过WAF方法

环境准备: 43-5 waf绕过 - 安全狗简介及安装-CSDN博客然后安装pikachu靶场:构建完善的安全渗透测试环境:推荐工具、资源和下载链接_渗透测试靶机下载-CSDN博客打开pikachu靶场 http://127.0.0.1/pikachu-master/vul/xss/xss_reflected_get.php 使用常见payload被安全狗拦截…

树莓派 AI 套件,售价 70 美元

系列文章目录 前言 2024 年 6 月 4 日 Naush Patuck 如果您曾想在您的 Raspberry Pi 5 上尝试神经网络、人工智能和机器学习&#xff0c;我们为您准备了完美的产品&#xff1a;Raspberry Pi AI Kit。AI Kit 是与 Hailo 合作开发的&#xff0c;它提供了一种便捷的方法&…

STM32F103C8T6基于HAL库移植uC/OS-III

文章目录 一、建立STM32CubeMX工程二、移植1、 uC/OS-III源码2、移植过程 三、配置相关代码1、bsp.c和bsp.h2、main.c3、修改启动代码4、修改app_cfg.h文件5、修改includes.h文件6、修改lib_cfg.h文件 四、编译与烧录总结参考资料 学习嵌入式实时操作系统&#xff08;RTOS&…

OpenStack学习笔记之三:用软件定义的理念做安全

第3章 用软件定义的理念做安全 1.不进则退&#xff0c;传统安全回到“石器时代” 1.1 企业业务和IT基础设施的变化 随着企业办公环境变得便利&#xff0c;以及对降低成本的天然需求&#xff0c;企业始终追求IT集成设施的性价比、灵活性、稳定性和开放性。而云计算、移动办公…

HAL STM32F1 通过查表方式实现SVPWM驱动无刷电机测试

HAL STM32F1 通过查表方式实现SVPWM驱动无刷电机测试 &#x1f4cd;相关篇《基于开源项目HAL STM32F4 DSP库跑SVPWM开环速度测试》 ✨针对STM32F1系列&#xff0c;硬件上没有可用的浮点单元&#xff08;FPU&#xff09;&#xff0c;为了实现特定函数的浮点运算快速计算&#xf…