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

2024-06-12 06:12

本文主要是介绍大疆智图_空三二维重建成果传输,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、软件环境

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

# -*- coding: cp936 -*-
import arcpy
import os
import time
import datetime
import subprocess
import concurrent.futures# 判断指定目录是否存在
def check_path_exists(dir_path):   if not os.path.exists(dir_path):print(f"指定目录:{dir_path} 不存在!")exit()# 判断金字塔文件是否存在
def check_pyramids_file_exists(file_path):if os.path.isfile(f"{file_path}.ovr"):print(f"已经存在:{file_path} 金字塔文件")check_pyramids_file(file_path)else:pyramids_file(file_path)  # 检查金字塔文件是否正确
def check_pyramids_file(file_path):result = arcpy.management.CheckPyramids(file_path)if result:print(f"检查文件:{file_path} 金字塔文件正确")else:print(f"检查文件:{file_path} 金字塔文件错误")pyramids_file(file_path)  # 构建金字塔文件
def pyramids_file(file_path):print(f"开始构建:{file_path} 金字塔文件")start_time = time.time()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}秒")# fascoy同步最新日期目录
def sync_update_folder(source_path, destination_path):print(f"正在同步:{source_path}")cmd = f'"{fcp_path}" /cmd=sync_update /force_close "{source_path}" /to="{destination_path}"'startupinfo = subprocess.STARTUPINFO()startupinfo.dwFlags |= subprocess.STARTF_USESHOWWINDOWsubprocess.run(cmd, startupinfo=startupinfo, shell=True)# fascoy同步目录
def sync_folder(source_path, destination_path):print(f"正在同步:{source_path}")cmd = f'"{fcp_path}" /cmd=sync /force_close "{source_path}" /to="{destination_path}"'startupinfo = subprocess.STARTUPINFO()startupinfo.dwFlags |= subprocess.STARTF_USESHOWWINDOWsubprocess.run(cmd, startupinfo=startupinfo, shell=True)# rclone同步文件
def upload_file(compressed_file, rclone_up_path):print(f"正在上传:{compressed_file}")cmd = f"{rclone_path} sync {compressed_file} {rclone_up_path} --progress"startupinfo = subprocess.STARTUPINFO()startupinfo.dwFlags |= subprocess.STARTF_USESHOWWINDOWsubprocess.run(cmd, startupinfo=startupinfo, shell=True)print(f"上传成功:{compressed_file}")# 7Z压缩目录
def seven_zip_file(dom_path):# 获取文件名cmd = f'{rclone_path} ls "{rclone_up_path}"'process = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True)output, error = process.communicate()# 解析输出,将文件名存入列表中rclone_list = [line.split()[-1] for line in output.decode('utf-8').splitlines() if line.split()[-1]]for foldername in os.listdir(dom_path):folder_path = os.path.join(dom_path, foldername)if f"{foldername}.7z" not in rclone_list:compressed_file = f"E:\{foldername}.7z"#压缩至E盘根目录compressed_files.append(compressed_file)command = f'"{seven_zip_path} u {compressed_file} "{os.path.join(folder_path, "map", "result*.*")}"'print(f"正在压缩:{foldername}")startupinfo = subprocess.STARTUPINFO()startupinfo.dwFlags |= subprocess.STARTF_USESHOWWINDOWsubprocess.run(command, startupinfo=startupinfo, shell=True)else:print(f"已经存在:{foldername} ;如需更新,请先删除 {rclone_up_path} 中同名文件。")# 删除本地 7z 文件       
def delete_file(compressed_file):for file in compressed_files:os.remove(file)print(f"本地文件:{file} 已删除!")# 多线程处理map目录下dsm.tif与result.tif文件
def process_folder(foldername):folder_path = os.path.join(dom_path, foldername)if os.path.isdir(folder_path):check_pyramids_file_exists(os.path.join(folder_path, r"map\dsm.tif"))check_pyramids_file_exists(os.path.join(folder_path, r"map\result.tif"))# 选择目录    
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)if __name__ == "__main__":# 设置 7-Zip 可执行文件路径seven_zip_path = f'"C:/Program Files/7-Zip/7z.exe"'# 设置 fcp 可执行文件路径fcp_path = f'"C:/Program Files/FastCopy5.7.10_x64/fcp.exe"'# 设置 rclone 可执行文件路径rclone_path = f'"D:/Program Files/rclone/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(f'"{os.path.join(folder_path, "map", "dsm*.*")}" "{os.path.join(folder_path, "map", "result*.*")}"', os.path.join(dst_path, foldername))sync_folder(f'"{os.path.join(folder_path, "map", "*_质量报告.pdf")}" "{os.path.join(folder_path, r"AT/report/POS_residual_of_camera.csv")}"', os.path.join(dst_path, foldername, "空三"))#压缩文件seven_zip_file(dom_path)# 异步上传文件with concurrent.futures.ThreadPoolExecutor() as executor:futures = [executor.submit(upload_file, file, rclone_up_path) for file in compressed_files]concurrent.futures.wait(futures)#删除压缩文件 delete_file(compressed_file)print("\nOVER!")
input("按任意键继续...")

五、说明

  1、大疆智图空三丢失图片:
  因空三导入的区域不连续,并且接壤的地方没有重叠。导致空三时,无法获取到对应的特征点,从而重建缺失或者失败。只能单独重建或补飞。见官方说明,与客服沟通情况。
在这里插入图片描述
  2、构建金字塔:
  默认使用4线程操作,最大线程数量可修改;
  3、局域网同步:
  sync_update_folder或sync_folder可选,考虑硬盘读写情况,使用FastCopy顺序同步;
  FastCopy同步:支持通配符,无需额外搭建环境;
  Rclone同步:自用更倾向于搭建webdav等方式同步,速度尚可;
  4、压缩文件:
  7Z参数可修改,考虑硬盘读写情况,使用7Z顺序压缩;
  5、脚本文件使用:
  需要键入参数适合人工交互处理,修改代码固定参数之后便于定时任务自动化处理。

六、更新

  20240611:
1、调整脚本文件代码顺序,便于注释、删除功能;
2、修改金字塔文件验证方式。

这篇关于大疆智图_空三二维重建成果传输的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1053404

相关文章

poj2576(二维背包)

题意:n个人分成两组,两组人数只差小于1 , 并且体重只差最小 对于人数要求恰好装满,对于体重要求尽量多,一开始没做出来,看了下解题,按照自己的感觉写,然后a了 状态转移方程:dp[i][j] = max(dp[i][j],dp[i-1][j-c[k]]+c[k]);其中i表示人数,j表示背包容量,k表示输入的体重的 代码如下: #include<iostream>#include<

hdu2159(二维背包)

这是我的第一道二维背包题,没想到自己一下子就A了,但是代码写的比较乱,下面的代码是我有重新修改的 状态转移:dp[i][j] = max(dp[i][j], dp[i-1][j-c[z]]+v[z]); 其中dp[i][j]表示,打了i个怪物,消耗j的耐力值,所得到的最大经验值 代码如下: #include<iostream>#include<algorithm>#include<

HDU 2159 二维完全背包

FATE 最近xhd正在玩一款叫做FATE的游戏,为了得到极品装备,xhd在不停的杀怪做任务。久而久之xhd开始对杀怪产生的厌恶感,但又不得不通过杀怪来升完这最后一级。现在的问题是,xhd升掉最后一级还需n的经验值,xhd还留有m的忍耐度,每杀一个怪xhd会得到相应的经验,并减掉相应的忍耐度。当忍耐度降到0或者0以下时,xhd就不会玩这游戏。xhd还说了他最多只杀s只怪。请问他能

二维旋转公式

二维旋转公式 ros的tf工具包可以很方便的实现任意坐标系之间的坐标转换。但是,如果只是想简单的测试想法,而又不想编写过于庞杂的代码,考虑自己写二维旋转的函数。而与二维旋转问题对偶的另一个问题便是二维坐标系旋转变换。这两个问题的形式基本一样,只是旋转的角度相差一个负号。就是这个容易搞混,所以做个笔记,以备查用。 1. 二维旋转公式(算法) 而(此文只针对二维)旋转则是表示某一坐标点 ( x

C语言批量数据到动态二维数组

上一篇文章将文件读取放到静态创建的二维数组中,但是结合网络上感觉到今天的DT时代,这样批量大量读取一个上百行的数据,分配的内存是否可能因为大量的数据而产生溢出呢,最近一直研究里malloc函数,通过它来动态建立所需的二维数组,因此,通过文件操作和动态创建二维数组结合起来,将大量的数据动态的放入矩阵中,不知道这样的思想是否正确,下午把程序运行出来了,将程序贴上来,欢迎大家一起探讨:对于有规律的大数据

远程桌面文件传输异常或者取消传输后一直显示正在取消

环境: Window Servers 2008 R2 摘要说明: 本篇文章主要讲述当应用远程桌面进行文件传输时,若因网络等导致进程中断,再次传输时则不能进行文件传输;或者传输时取消传输,然后一直显示正在取消。此时可以通过重启window的rdpclip.exe进程来解决此问题 步骤 1.关闭rdpclip.exe进程 远程桌面连上上传输异常的服务器,打开资源管理器,在进程列关闭rdpc

HLJUOJ1118(二维树状数组)

1118: Matrix Time Limit: 4 Sec   Memory Limit: 128 MB Submit: 77   Solved: 12 [ Submit][ Status][ Web Board] Description 给定一个1000*1000的二维矩阵,初始矩阵中每个数都为1,然后为矩阵有4种操作. S x1 y1 x2 y2:计算(x1,y1)、(x2

hdu1892(二维树状数组)

See you~ Time Limit: 5000/3000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others) Total Submission(s): 3726    Accepted Submission(s): 1168 题目链接: http://acm.hdu.edu.cn/showproblem.php

”CSS 网格“二维布局系统(补充)——WEB开发系列32

CSS 网格布局是一种二维布局系统,用于网页设计。通过使用网格,你可以将内容以行和列的形式进行排列。此外,网格布局还能够简便地实现一些复杂的布局结构。 一、什么是网格布局? CSS网格布局是一种二维布局系统,它允许我们创建复杂的网页布局,既可以处理行也可以处理列。与传统的布局方法不同,网格布局将网页分成多个可控的区域,这些区域可以任意排列、对齐和调整大小。网格布局使得创建灵活且响应

Java传输本地目录到远程服务器

在使用Java进行开发时,有时需要将本地目录中的文件复制或传输到远程服务器上。这种场景在部署应用程序或进行数据迁移时尤为常见。JSch库提供了一种简便的方法来实现这一功能。以下是从Codekru网站获取的信息摘要,并结合相关内容,展示如何使用JSch库实现从本地计算机复制整个目录到远程服务器的过程。 准备工作 首先,确保您的项目中已经包含了JSch库的依赖。如果您使用Maven作为构建工具,可