【LBS】移动互联网基于LBS地理位置应用开发必备

原文:【LBS】移动互联网基于LBS地理位置应用开发必备

源代码下载地址:http://www.zuidaima.com/share/1694743146056704.htm

功能:计算两个点(经纬度坐标)之间的距离

使用示例:

double distance = LatLng.distance(113.926496000000000, 22.538393000000000, 114.23, 22.23);

01 package com.haohui.util;
02  
03 /**
04  * 计算两个经纬度之间的距离的工具类
05  *
06  * Feb 13, 2014
07  * @author ZhihaoChen
08  */
09 public class LatLng {
10     private static double lngPerMeter = 1.E-005D;
11  
12     public double getLat(double _curLat, int _radius) {
13         return _radius * lngPerMeter;
14     }
15  
16     public double getLng(int _radius) {
17         return _radius * lngPerMeter;
18     }
19  
20     /**
21      * 计算两个经纬度之间的距离
22      *
23      * @param _lng1
24      * @param _lat1
25      * @param _lng2
26      * @param _lat2
27      * @return
28      */
29     public static double distance(double _lng1, double _lat1, double _lng2,
30             double _lat2) {
31         if ((_lng1 == 0.0D) || (_lat1 == 0.0D) || (_lng2 == 0.0D)
32                 || (_lat2 == 0.0D)) {
33             return 0.0D;
34         }
35         double rad_lat1 = Rad(_lat1);
36         double rad_lat2 = Rad(_lat2);
37         double a = rad_lat1 - rad_lat2;
38         double b = Rad(_lng1) - Rad(_lng2);
39         double s = 2.0D * Math.asin(Math.sqrt(Math
40                 .pow(Math.sin(a / 2.0D), 2.0D)
41                 + Math.cos(rad_lat1)
42                 * Math.cos(rad_lat2)
43                 * Math.pow(Math.sin(b / 2.0D), 2.0D)));
44         s *= 6378137.0D;
45         s = Math.round(s * 10000.0D) / 10000L;
46         return s;
47     }
48  
49     private static double Rad(double _d) {
50         return _d * 3.141592653589793D / 180.0D;
51     }
52      
53 }




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值