如何计算地球任意两点之间距离


theme: jzman

jvideo

相关源码和模型的下载链接地址点击链接进行跳转

前言

本文通过百度地图api实现一个地球地图模型,通过运用精确的Haversine公式Vincenty公式,系统能够迅速计算出这两个坐标点之间的实际距离。文中力求使用专业的地理和数学的术语解释计算原理,如有失误,请指正,谢谢

技术栈

  • typescript
  • 百度地图api
  • vite

加载地图

获取应用AK

需要实现加载百度地图提供的地图服务api,首先需要创建一个属于自己的应用AK,在百度地图开放平台--控制台--我的应用

1 apikey.jpg

创建地球

```html // 引入文档

// 地图服务容器

``` 在引入对应的map服务后,就该创建一个地图实例,

ts // GL版命名空间为BMapGL var map_earth = new BMapGL.Map("allmap"); // 创建Map实例 map_earth.centerAndZoom(new BMapGL.Point(116.40396298757886, 39.91511908708907), 5); // 初始化地图,设置中心点坐标和地图级别 当前center设置的是北京天安门的经纬坐标,缩放级别为5,当然,这创建的是普通的2维平面地图,我们要创建的是一个地球的效果,所以需要修改一下地图的风格

typescript map_earth.enableScrollWheelZoom(true); //开启鼠标滚轮缩放 map_earth.setMapType(BMAP_EARTH_MAP); // 设置地图类型为地球模式

2 地球.jpg

这样我们就创建好了一个基础的地球地图模型

拾取经纬坐标

通过点击地球某个点位,拾取到经纬坐标,并记录这些坐标。

image.png

typescript // 点击获取经纬度 map_earth.addEventListener('click', function (e) {

  • 13
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 在MATLAB中,可以使用haversine公式来计算两个经纬度坐标之间的球面距离。具体步骤如下: 1. 首先,将经纬度坐标转换为弧度制。这可以通过将经纬度值除以180再乘以π来实现。 2. 然后,使用haversine公式来计算球面距离。haversine公式如下: d = 2 * R * asin(sqrt(sin((lat2-lat1)/2)^2 + cos(lat1) * cos(lat2) * sin((lon2-lon1)/2)^2)) 其中,d是距离,R是地球的半径(一般情况下为6371千米),lat1和lon1是第一个的纬度和经度,lat2和lon2是第二个的纬度和经度。 3. 最后,根据需要可以将距离换算为其他单位。 下面是一个MATLAB代码示例,可以根据上述步骤计算两个经纬度坐标之间的球面距离: ```matlab function distance = calculateDistance(lat1, lon1, lat2, lon2) R = 6371; % 地球半径,单位:千米 % 将经纬度转换为弧度制 lat1 = deg2rad(lat1); lon1 = deg2rad(lon1); lat2 = deg2rad(lat2); lon2 = deg2rad(lon2); % 使用haversine公式计算球面距离 dlat = lat2 - lat1; dlon = lon2 - lon1; a = sin(dlat/2)^2 + cos(lat1) * cos(lat2) * sin(dlon/2)^2; c = 2 * atan2(sqrt(a), sqrt(1-a)); distance = R * c; end ``` 使用这个函数,可以通过传入经纬度坐标调用该函数来计算两点之间的球面距离。例如: ```matlab lat1 = 31.21563; lon1 = 121.50891; lat2 = 39.90420; lon2 = 116.40740; distance = calculateDistance(lat1, lon1, lat2, lon2); disp(distance); % 输出球面距离,单位:千米 ``` 运行以上代码,将会输出上海和北京之间的球面距离约为1030千米。 ### 回答2: 在Matlab中,计算两点之间的球面距离可以利用Haversine公式。该公式基于经纬度坐标系,以一个球体来近似地描述地球的形状,计算两点之间的弧长。以下是一个实现该功能的简单示例代码: ```matlab function distance = computeDistance(lat1, lon1, lat2, lon2) % 地球的平均半径(单位:千米) radius = 6371; % 将角度转换为弧度 lat1 = deg2rad(lat1); lon1 = deg2rad(lon1); lat2 = deg2rad(lat2); lon2 = deg2rad(lon2); % 计算两点间的差值 dlat = lat2 - lat1; dlon = lon2 - lon1; % 使用Haversine公式计算球面距离 a = sin(dlat/2)^2 + cos(lat1) * cos(lat2) * sin(dlon/2)^2; c = 2 * atan2(sqrt(a), sqrt(1-a)); distance = radius * c; end ``` 在上述代码中,`lat1`和`lon1`表示第一个坐标的纬度和经度,`lat2`和`lon2`表示第二个坐标的纬度和经度。最终,函数返回两点之间的球面距离。注意,这里使用的是地球的平均半径,该值为6371公里。 你可以调用这个函数并传入相应的经纬度数据,以计算得到两点之间的球面距离。 ### 回答3: 在Matlab中,我们可以使用Haversine公式来计算两点之间的球面距离,该公式适用于两点之间的直线距离小于200km的情况。首先,我们需要获取两个的经纬度坐标。 假设A的经纬度坐标为(A_lat, A_lon),B的经纬度坐标为(B_lat, B_lon),则可以使用以下代码计算两点之间的球面距离: ```matlab function distance = calculateDistance(A_lat, A_lon, B_lat, B_lon) R = 6371; % 地球半径(单位:km) % 将角度转换为弧度 lat1 = deg2rad(A_lat); lon1 = deg2rad(A_lon); lat2 = deg2rad(B_lat); lon2 = deg2rad(B_lon); % 使用Haversine公式计算球面距离 delta_lat = lat2 - lat1; delta_lon = lon2 - lon1; a = sin(delta_lat/2)^2 + cos(lat1) * cos(lat2) * sin(delta_lon/2)^2; c = 2 * atan2(sqrt(a), sqrt(1-a)); distance = R * c; end ``` 使用上述函数即可计算两个经纬度坐标之间的球面距离。函数参数A_lat、A_lon分别表示A的纬度和经度,B_lat、B_lon表示B的纬度和经度。最后,返回的距离单位为千米(km)。 例如,我们可以调用该函数进行实际计算: ```matlab A_lat = 39.9042; A_lon = 116.4074; B_lat = 31.2304; B_lon = 121.4737; distance = calculateDistance(A_lat, A_lon, B_lat, B_lon); disp(distance); % 输出两个之间的球面距离(单位:km) ``` 通过以上示例,我们可以用Matlab计算任意两点间的球面距离。注意,如果两点之间的直线距离大于200km,我们应该使用其他更精确的球面距离计算方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

孙华鹏

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值