当前位置:网站首页>如何根据地图上的两个坐标点来确定方向
如何根据地图上的两个坐标点来确定方向
2022-08-02 03:23:00 【呆呆papa】
在地图上有这么两个点,黄鹤楼(A点)和黄鹤楼的公园管理处(B点),怎么确定B点在A点的什么方向呢。
在地理坐标系中可以将纬度看做直角坐标系中的Y轴,正方向由南向东北;将经度看做直角坐标系中的X轴,正方向由西向东。虽然地球是个球,但是放大了来看,球面的弧度并不影响我们将它看做一个平面直角坐标系。
以B点为原点建立平面直角坐标系,求B点在A点的方向问题就变成了求角度问题,只要计算出线段AB和X轴或者Y轴的夹角,就可以描述A和B之间的方向。
根据经纬度的坐标点先计算出AB两点之间的距离以及A、B两点的经度差值、纬度差值,计算出cos值或者sin值,然后利用JavaScript的Math对象的acos或者asin(反三角函数)来求出夹角对应的弧度值,再将弧度值转换为角度值。
JavaScript中弧度和角度的转换关系为:角度乘以 0.017453293 (或2PI/360)即可转换为弧度,PI为Math对象中的常量。
具体实现
function calculateAngle(points) {
var lastPrePoi = points[0];
var lastPoi = points[1];
if (lastPoi.lng == lastPrePoi.lng) {
if (lastPoi.lat == lastPrePoi.lat) {
// 横坐标相同、纵坐标相同
return;
} else {
// 横坐标相同、纵坐标不同
return lastPoi.lat > lastPrePoi.lat ? 0 : 180;
}
} else {
if (lastPoi.lat == lastPrePoi.lat) {
// 横坐标不同、纵坐标相同
return lastPoi.lng > lastPrePoi.lng ? 90 : -90;
} else {
let first_side_length = lastPoi.lng - lastPrePoi.lng;
let second_side_length = lastPoi.lat - lastPrePoi.lat;
let third_side_length = Math.sqrt(Math.pow(first_side_length, 2) + Math.pow(second_side_length, 2));
let cosine_value = first_side_length / third_side_length;
let radian_value = Math.acos(cosine_value);
let angle_value = radian_value * 180 / Math.PI;
if (angle_value < 90) {
return second_side_length > 0 ? 90 - angle_value : 90 + angle_value;
} else {
return second_side_length > 0 ? 90 - angle_value : angle_value - 270;
}
}
}
}
注:此方法中的角度值是以Y轴正方向为参考,角度为AB线段与Y轴正方向的夹角
边栏推荐
- 暴力方法求解(leetcode14)查找字符串数组中的最大公共前缀
- canvas--饼状图
- 【 application 】 life many years of operations, what turned scored 12 k + annual bonus salary?
- 最新,每天填坑,Jeston TX1 精卫填坑,第一步:刷机
- Phospholipid-polyethylene glycol-hydrazide, DSPE-PEG-Hydrazide, DSPE-PEG-HZ, MW: 5000
- 一个结构体 = 另一个结构体(同类型结构体之间可直接赋值操作)
- 针对简历上的问题
- pyppeteer使用样例脚本
- 每天填坑,精卫填坑第二集,TX1 配置从固态启动,安装Pytorch
- querystring模块
猜你喜欢
canvas--饼状图
配置mmdet来训练Swin-Transformer之一配置环境
微信小程序云开发如何将页面生成为pdf?
PCL—point cloud data segmentation
我的小笔记 =》原生微信小程序
DSPE-PEG-PDP, DSPE-PEG-OPSS, phospholipid-polyethylene glycol-mercaptopyridine supply, MW: 5000
Error in render: “TypeError: Cannot read properties of null (reading ‘0‘)“ 报错解决方案
npm --package.json---require
三元判断再三元判断
URL URL
随机推荐
小程序 van-cell 换行能左对齐问题
我的小笔记 =》原生微信小程序
querystring模块
每日五道面试题 2022/7/27
np.unique() function
--fs module--
广州华为面试总结
啃瓜记录又一天
Debian 10 NTP Service Configuration
DSPE-PEG-Silane, DSPE-PEG-SIL, phospholipid-polyethylene glycol-silane modified active group
啃瓜记录第一天
[Learning Records of Boxue Valley] Super summary, share with heart | Software Testing Interface Testing Basics
L1-039 古风排版(C)
我的小笔记 =》其他东东
How to check whether a table is locked in mysql
正则笔记(2)- 正则表达式位置匹配攻略
---静态页面---
C语言中关于2的n次方求值问题(移位运算)
js作用域与闭包
npm和package.json