1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > android地图方位角 根据两点经纬度 计算距离 方位角

android地图方位角 根据两点经纬度 计算距离 方位角

时间:2023-10-13 06:34:29

相关推荐

android地图方位角 根据两点经纬度 计算距离 方位角

两点经纬度,计算距离

计算公式:

1.Lat1 Lung1表示A点经纬度,Lat2 Lung2表示B点经纬度;

2.a=Lat1–Lat2为两点纬度之差b=Lung1 -Lung2为两点经度之差;

3.6378.137为地球半径,单位为千米;

计算出来的结果单位为千米。

也有人/archive//07/04/442771.html)说直接从google maps的脚本里扒了段代码,maps的代码:计算的结果是米为单位。

//计算两点距离

privatefinaldoubleEARTH_RADIUS= 6378137.0;

privatedoublegps2m(doublelat_a,doublelng_a,doublelat_b,doublelng_b) {

doubleradLat1 = (lat_a * Math.PI/ 180.0);

doubleradLat2 = (lat_b * Math.PI/ 180.0);

doublea = radLat1 - radLat2;

doubleb = (lng_a - lng_b) * Math.PI/ 180.0;

doubles = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2)

+ Math.cos(radLat1) * Math.cos(radLat2)

* Math.pow(Math.sin(b / 2), 2)));

s = s *EARTH_RADIUS;

s = Math.Round(s * 10000) / 10000;

returns;

}

两点经纬度,计算方位角

计算方位角pab,

其中lat_a, lng_a是A的纬度和经度;lat_b, lng_b是B的纬度和经度。代码如下:

//计算方位角pab。

privatedoublegps2d(doublelat_a,doublelng_a,doublelat_b,doublelng_b) {

doubled = 0;

lat_a=lat_a*Math.PI/180;

lng_a=lng_a*Math.PI/180;

lat_b=lat_b*Math.PI/180;

lng_b=lng_b*Math.PI/180;

d=Math.sin(lat_a)*Math.sin(lat_b)+Math.cos(lat_a)*Math.cos(lat_b)*Math.cos(lng_b-lng_a);

d=Math.sqrt(1-d*d);

d=Math.cos(lat_b)*Math.sin(lng_b-lng_a)/d;

d=Math.asin(d)*180/Math.PI;

// d = Math.round(d*10000);

returnd

}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。