当前位置:网站首页>如何根据地图上的两个坐标点来确定方向
如何根据地图上的两个坐标点来确定方向
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轴正方向的夹角
边栏推荐
猜你喜欢

Phospholipid-polyethylene glycol-targeted neovascularization targeting peptide APRPG, DSPE-PEG-APRPG

DOM manipulation---magnifying glass case

Debian 10 NTP Service Configuration

querystring模块

DSPE-PEG-PDP, DSPE-PEG-OPSS, phospholipid-polyethylene glycol-mercaptopyridine supply, MW: 5000

骨架效果 之高级渐变,适用图片等待时

canvas--饼状图

微信小程序云开发之券码领取,怎么防止用户领取到相同的数据?

npm--package.json---require

Phospholipid-polyethylene glycol-azide, DSPE-PEG-Azide, DSPE-PEG-N3, MW: 5000
随机推荐
Customer Rating Control
区间问题 : 今年暑假不AC
Amazon sellers how to improve the conversion
DOM manipulation---magnifying glass case
正则笔记(1)- 正则表达式字符匹配攻略
这些JS题面试时一定要答对!
你的本地创建的项目库还在手动创建远端代码仓库再推送吗,该用它了
微信小程序怎么批量生成带参数的小程序码?
由中序遍历和后序遍历得到前序遍历(树的遍历)
Small program van-cell line wrapping can be left-aligned
我的小笔记 =》其他东东
L1-039 古风排版(C)
js基础知识
Cut out web icons through PS 2021
微信小程序实现文本安全监测
IndexError: only integers, slices (`:`), ellipsis (`...`), numpy.newaxis (`None`) and integer or boo
Debian 10 NTP Service Configuration
4.14到新公司的一天
SOCKS5
The difference between the knowledge question and answer session with the knowledge