根据经纬度算出距离

       地球是一个近乎标准的椭球体,它的赤道半径为6378.140千米,极半径为 6356.755千米,平均半径6371.004千米。如果我们假设地球是一个完美的球体,那么它的半径就是地球的平均半径,记为R。如果以0度经线为基 准,那么根据地球表面任意两点的经纬度就可以计算出这两点间的地表距离(这里忽略地球表面地形对计算带来的误差,仅仅是理论上的估算值)。设第一点A的经 纬度为(LonA, LatA),第二点B的经纬度为(LonB, LatB),按照0度经线的基准,东经取经度的正值(Longitude),西经取经度负值(-Longitude),北纬取90-纬度值(90- Latitude),南纬取90+纬度值(90+Latitude),则经过上述处理过后的两点被计为(MLonA, MLatA)和(MLonB, MLatB)。那么根据三角推导,可以得到计算两点距离的如下公式:

C = sin(MLatA)*sin(MLatB)*cos(MLonA-MLonB) + cos(MLatA)*cos(MLatB)

Distance = R*Arccos(C)*Pi/180

这里,R和Distance单位是相同,如果是采用6371.004千米作为半径,那么Distance就是千米为单位,如果要使用其他单位,比如mile,还需要做单位换算,1千米=0.621371192mile。

java主要代码如下:

public static double getDistance()
    {  
        for(int i=0;i<list.size()-1;i++){
            BDLocation p1 = list.get(i);
            BDLocation p2 = list.get(i+1);
            double lat1 = (Math.PI/180)*(p1.getLatitude());
            double lon1 = (Math.PI/180)*(p1.getLongitude());
            double lat2 = (Math.PI/180)*(p2.getLatitude());
            double lon2 = (Math.PI/180)*(p2.getLongitude());
            double R = 6371.004;//地球半径,单位KM
            distance += Math.acos(Math.sin(lat1)*Math.sin(lat2)+Math.cos(lat1)*Math.cos(lat2)*Math.cos(lon2-lon1))*R*1000;
        } 
        return distance;            //单位:m
    }
   
    public static void main(String[] args) {
        list=new ArrayList<BDLocation>();    
        BDLocation bd1=new BDLocation(38.891819,115.521052);
        BDLocation bd2=new BDLocation(38.891901,115.521109);
        BDLocation bd3=new BDLocation(38.891994,115.521194);
        list.add(bd1);
        list.add(bd2);
        list.add(bd3);
        System.out.print(getDistance());
    }


完整代码如下:请点击这里

参考:http://www.cnblogs.com/ycsfwhh/archive/2010/12/20/1911232.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 经纬度是一种描述地球上地理位置的方式。在Android应用程序中,可以通过经纬度计算两点之间的距离和方位角,使用的是数学上的公式。 首先需要获取两个点的经纬度,可以使用GPS和地图API等方式获取。然后使用数学上的公式计算出两点之间的距离和方位角。 距离计算:根据地球的半径和两点的经纬度,可以计算出两点之间的距离。常用的公式是Haversine公式,它计算的是球面上的距离。 方位角计算:方位角是指从一个点到另一个点的方向,可以用0到360度的角度表示。计算方位角需要知道两点之间的经纬度以及两点之间连线的夹角。 在Android中,可以使用Java Math类的数学函数计算距离和夹角,也可以使用开源库如GeoTools进行计算。通过计算距离和方位角,可以帮助用户更好地了解他们在地球上的位置,为应用程序提供更多的功能和服务。 ### 回答2: 要根据经纬度算出两点及方位角,需要使用数学公式和算法来计算。在Android开发中,可以使用Java语言来实现计算。 首先,需要知道两点的经纬度坐标。可以使用Android提供的定位服务获取当前位置的经纬度坐标,或者手动输入需要计算的两个位置的经纬度坐标。 接下来,使用Haversine公式计算两点之间的距离。Haversine公式是根据两点之间的经纬度坐标计算地球上两点之间的距离的公式,其公式为: a = sin²(Δlat/2) + cos(lat1) * cos(lat2) * sin²(Δlon/2) c = 2 * atan2( √a, √(1−a) ) d = R * c 其中,lat1和lat2是两点之间的纬度,lon1和lon2是两点之间的经度,Δlat和Δlon分别是两点之间的纬度差和经度差,R是地球半径计算出两点之间的距离后,可以使用反三角函数计算出两点之间的方位角。方位角表示一个点相对于北极点的方位角度数,该值的范围为0°到360°。使用反三角函数计算方位角的公式为: θ = atan2( sin(Δlon) * cos(lat2), cos(lat1) * sin(lat2) - sin(lat1) * cos(lat2) * cos(Δlon) ) 其中,θ为方位角,lat1和lat2是两点之间的纬度,lon1和lon2是两点之间的经度,Δlon是两点之间的经度差。 最后,根据计算的结果将两点之间的距离和方位角显示在应用程序中。 总之,根据经纬度算出两点及方位角需要使用Haversine公式和反三角函数来计算,可以通过Android开发实现。 ### 回答3: 根据经纬度算出两点及方位角的方法,可以采用大圆航线公式或Vincenty公式。其中,大圆航线公式基于球体模型,而Vincenty公式基于椭球体模型,精度更高。 在Android中,可以使用Java语言来实现计算。首先需要将经纬度转换为弧度,然后应用公式计算出两点的距离和方位角。 对于大圆航线公式,公式如下: d=acos(sin(lat1)*sin(lat2)+cos(lat1)*cos(lat2)*cos(lon2-lon1))*R 其中,d为两点间距离,lat1和lat2为两点的纬度,lon1和lon2为两点的经度,R为地球半径。 方位角公式如下: θ=atan2(sin(lon2-lon1)*cos(lat2), cos(lat1)*sin(lat2)-sin(lat1)*cos(lat2)*cos(lon2-lon1)) 其中,θ为方位角,atan2为反正切函数。 对于Vincenty公式,比较复杂,需要迭代计算。具体的实现可以参考开源库GeoTools或JTS等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值