我试图确定两个位置(每个位置有自己的纬度和经度值)是否在彼此的特定距离内,例如半径为3英里.我有两个值来表示每个位置的纬度和经度.
//Location 1
Double lattitude1 = 40.7143528;
Double longitude1 = -74.0059731;
//Location 2
Double lattitude2 = 33.325;
Double longitude2 = 44.422000000000025;
Run Code Online (Sandbox Code Playgroud)
我想知道如何确定这两个位置是否在彼此的半径范围内,因为我不完全确定如何使用这种类型的值.
查看大圆距离
double CoordDistance(double latitude1, double longitude1, double latitude2, double longitude2)
{
return 6371 * Math.acos(
Math.sin(latitude1) * Math.sin(latitude2)
+ Math.cos(latitude1) * Math.cos(latitude2) * Math.cos(longitude2 - longitude1));
}
Run Code Online (Sandbox Code Playgroud)
如果您的经度和纬度以度为单位,则将其转换为弧度。
要获取两点之间的距离,您只需要使用这段代码。
Point2D p1 = new Point2D(lattitude1, longitude2);
Point2D p2 = new Point2D(lattitude2, longitude2);
double distanceBetweenTwoPoints = (double)Math.sqrt((double)Math.pow((p1.x - p2.x), 2.0) + (double)Math.pow((p1.y - p2.y), 2.0));
Run Code Online (Sandbox Code Playgroud)
--- 已编辑 ---
请检查两坐标(非二维)解决方案的注释。
| 归档时间: |
|
| 查看次数: |
22224 次 |
| 最近记录: |