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

【量算分析工具-贴地距离】GeoServer改造Springboot番外系列九

【量算分析工具-概述】GeoServer改造Springboot番外系列三-CSDN博客

【量算分析工具-水平距离】GeoServer改造Springboot番外系列四-CSDN博客

【量算分析工具-水平面积】GeoServer改造Springboot番外系列五-CSDN博客

【量算分析工具-方位角】GeoServer改造Springboot番外系列六-CSDN博客

【量算分析工具-坡度】GeoServer改造Springboot番外系列七-CSDN博客

【量算分析工具-获取高程】GeoServer改造Springboot番外系列八-CSDN博客

【量算分析工具-贴地距离】GeoServer改造Springboot番外系列九-CSDN博客

【量算分析工具-贴地面积】GeoServer改造Springboot番外系列十-CSDN博客

贴地距离

1、思路

将两点之间线段抽象成为若干个具有高程的经纬度点,计算每两个点之间的距离,然后累加所有距离之和,即为贴地距离。

 如图,AB连线经过C、D、E、F、G五个点,他们的高程用H表示,他们两点之间的距离用L表示,那么算出A到B之间的贴地距离的公式:

Distance = AC+CD+DE+EF+FG+GB

=\sqrt{(H_{A}-H_{C})^{2}+L_{AC}^{2}}   +  \sqrt{(H_{C}-H_{D})^{2}+L_{CD}^{2}} +  \sqrt{(H_{D}-H_{E})^{2}+L_{DE}^{2}}

 +  \sqrt{(H_{E}-H_{F})^{2}+L_{EF}^{2}} +  \sqrt{(H_{F}-H_{G})^{2}+L_{FG}^{2}} +  \sqrt{(H_{G}-H_{B})^{2}+L_{GB}^{2}}

2、步骤

1、根据两点坐标获取瓦片范围;

2、合并瓦片成为一个新的大瓦片;

3、读取大瓦片的高程数据;

4、两点经纬度转换成像素坐标;

5、根据Bresenham直线算法,获取两点像素之间所有像素点坐标;

6、最后根据上面示意图的公式计算出地表距离。

3、代码

package com.gs.springboot.gmserver.util;import org.locationtech.jts.geom.Coordinate;import java.awt.image.BufferedImage;
import java.util.ArrayList;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Set;/*** 距离计算工具类*/
public class DistanceUtil {/*** 椭球平均半径,单位m,椭球半径是6,378,137m*/private static final double EARTH_RADIUS = 6371008.77138;/*** 获取高程数据的地表距离** @param zoom           层级* @param coordinateList 连线的经纬度集合* @param rootPathList   高程terrain-rgb数据文件夹集合* @return double*/public static double getSurfaceDistance(int zoom, List<double[]> coordinateList, List<String> rootPathList, String type) {if (coordinateList.size() < 2) {throw new IllegalArgumentException("The line list must contain exactly two coordinates
http://www.lryc.cn/news/360309.html

相关文章:

  • 【linux】(1)文件操作及vi
  • 【5】MySQL数据库备份-XtraBackup - 全量备份
  • 数据治理-数据标准演示
  • 基于Chisel的FPGA流水灯设计
  • LabVIEW齿轮调制故障检测系统
  • AI帮写:探索国内AI写作工具的创新与实用性
  • n后问题 回溯笔记
  • 简述Java中实现Socket通信的步骤
  • Asp.Net Core 实现分片下载的最简单方式
  • [Mac软件]Leech for Mac v3.2 - 轻量级mac下载工具
  • 留给“端侧大模型”的时间不多了
  • Pytest框架中的Setup和Teardown功能
  • yolov10/v8 loss详解
  • Typescript高级: 深入理解infer关键字
  • JQC-3FF-S-Z 继电器模块使用(arduino)
  • 黑马一站制造数仓实战2
  • 网络I/O模型
  • Docker 简介和安装
  • 【源码】Spring Data JPA原理解析之Repository自定义方法命名规则执行原理(二)
  • Vue前端中从后端获取图片验证码
  • 【源码】多语言H5聊天室/thinkphp多国语言即时通讯/H5聊天室源码/在线聊天/全开源
  • gitlab 创建 ssh 和 token
  • Docker - Kafka
  • 一键实现文件夹批量高效重命名:轻松运用随机一个字母命名,让文件管理焕然一新!
  • Vue3项目练习详细步骤(第二部分:主页面搭建)
  • [个人总结]-java常用方法
  • 什么是Java泛型?它有什么作用
  • [机缘参悟-197] - 《道家-水木然人间清醒1》读书笔记 -21-看问题从现象到本质的层次
  • AIGC商业案例实操课,发觉其创造和商业的无限可能,Ai技术在行业应用新的商机
  • Java学习路径图