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

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

一、软件环境

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”后,按“回车”键确认。
在这里插入图片描述输入或粘贴局域网存放成果的路径。
在这里插入图片描述构建金字塔运行情况。
在这里插入图片描述

四、代码

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_timetd = 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):cmd = "/cmd=sync_update /force_close"subprocess.run([fcp_path, cmd, source_path, f"/to={destination_path}"], shell=True)# 同步文件夹
def sync_folder(source_path, destination_path):cmd = "/cmd=sync /force_close"subprocess.run([fcp_path, cmd, source_path, f"/to={destination_path}"], 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 = []# 创建线程池,最大线程为4with 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_update_folder(os.path.join(folder_path, "map\\dsm.*"), os.path.join(dst_path, foldername))sync_update_folder(os.path.join(folder_path, "map\\result.*"), os.path.join(dst_path, foldername))sync_update_folder(os.path.join(folder_path, "map\\*_质量报告.pdf"), os.path.join(dst_path, foldername, "空三"))sync_update_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)print(f"压缩完成: {foldername}")# 使用 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!")

五、说明

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

相关文章:

  • Java finally catch try关键字
  • 反转链表 (oj题)
  • C++中的sizeof和strlen详解
  • 【玩转C语言】第三讲---> scanf 和 printf 函数详解(非常重要)!
  • Redisson知识
  • 斯坦福天才少女创5亿独角兽!Pika获8000万融资,金牌团队首曝光
  • 小主机折腾记24
  • 计算机基础(8)——音频数字化(模电与数电)
  • WPF中读取Excel文件的内容
  • 利用keepalived对zabbix-server做高可用,部署安装keepalived
  • 【WEB前端2024】智体OS:poplang编程控制成本小千元的长续航robot机器人底盘(开源)
  • C语言——内存函数
  • Linux 35.5 + JetPack v5.1.3@FC-Planner编译安装
  • 深入解析Java扩展机制:SPI与Spring.factories
  • Python的登录注册界面跳转汽车主页面
  • [译] 怎样写一个基础的编译器
  • ES6系统学习----从Apollo Client看解构赋值
  • JavaScript 基础知识 - 入门篇(一)
  • opencv python Meanshift 和 Camshift
  • React 快速上手 - 07 前端路由 react-router
  • SAP云平台里Global Account和Sub Account的关系
  • 产品三维模型在线预览
  • 基于axios的vue插件,让http请求更简单
  • 运行时添加log4j2的appender
  • 在Unity中实现一个简单的消息管理器
  • Hibernate主键生成策略及选择
  • LIGO、Virgo第三轮探测告捷,同时探测到一对黑洞合并产生的引力波事件 ...
  • mysql 慢查询分析工具:pt-query-digest 在mac 上的安装使用 ...
  • ​埃文科技受邀出席2024 “数据要素×”生态大会​
  • ​软考-高级-信息系统项目管理师教程 第四版【第19章-配置与变更管理-思维导图】​
  • #Z0458. 树的中心2
  • (1)Jupyter Notebook 下载及安装
  • (1/2)敏捷实践指南 Agile Practice Guide ([美] Project Management institute 著)
  • (12)Linux 常见的三种进程状态
  • (3)nginx 配置(nginx.conf)
  • (差分)胡桃爱原石
  • (附源码)ssm基于web技术的医务志愿者管理系统 毕业设计 100910
  • (十五)、把自己的镜像推送到 DockerHub
  • (限时免费)震惊!流落人间的haproxy宝典被找到了!一切玄妙尽在此处!
  • (一)Dubbo快速入门、介绍、使用
  • (一)SpringBoot3---尚硅谷总结
  • (转)setTimeout 和 setInterval 的区别
  • (转)总结使用Unity 3D优化游戏运行性能的经验
  • ***汇编语言 实验16 编写包含多个功能子程序的中断例程
  • .bat批处理(六):替换字符串中匹配的子串
  • .jks文件(JAVA KeyStore)
  • .NET MAUI Sqlite程序应用-数据库配置(一)
  • .net 验证控件和javaScript的冲突问题
  • .netcore 如何获取系统中所有session_如何把百度推广中获取的线索(基木鱼,电话,百度商桥等)同步到企业微信或者企业CRM等企业营销系统中...
  • .NET中使用Redis (二)
  • .sh文件怎么运行_创建优化的Go镜像文件以及踩过的坑
  • ::
  • @reference注解_Dubbo配置参考手册之dubbo:reference
  • @SuppressWarnings(unchecked)代码的作用
  • [04]Web前端进阶—JS伪数组