iOS-计算两个经纬度之间的距离和方位

double DegreesToRadians(double degrees) {return degrees * M_PI / 180;};
double RadiansToDegrees(double radians) {return radians * 180 / M_PI;};

- (NSString *)bearingToLocationFromCoordinate:(CLLocation*)fromLoc toCoordinate:(CLLocation*)toLoc
{
    double lat1 = DegreesToRadians(fromLoc.coordinate.latitude);
    double lon1 = DegreesToRadians(fromLoc.coordinate.longitude);
    
    double lat2 = DegreesToRadians(toLoc.coordinate.latitude);
    double lon2 = DegreesToRadians(toLoc.coordinate.longitude);
    
    double dLon = lon2 - lon1;
    
    double y = sin(dLon) * cos(lat2);
    double x = cos(lat1) * sin(lat2) - sin(lat1) * cos(lat2) * cos(dLon);
    double radiansBearing = atan2(y, x);
    
    NSString *str ;
    double aDeg = RadiansToDegrees(radiansBearing);
    
    if (aDeg >= 75 && aDeg <= 105)
    {
        str = @"正东";
    }
    if (aDeg > 15 && aDeg < 75)
    {
        str = @"东北";
    }
    if (aDeg >= -15 && aDeg <= 15)
    {
        str = @"正北";
    }
    if (aDeg > -75 && aDeg < -15)
    {
        str = @"西北";
    }
    if (aDeg >= -105 && aDeg <= -75)
    {
        str = @"正西";
    }
    if (aDeg > -165 && aDeg < -105)
    {
        str = @"西南";
    }
    if ((aDeg >= 165 && aDeg <= 180) || (aDeg >= -180 && aDeg <= -165))
    {
        str = @"正南";
    }
    if (aDeg > 105 && aDeg < 165)
    {
        str = @"东南";
    }
    
    CLLocationDistance meters = [fromLoc distanceFromLocation:toLoc];
    return [NSString stringWithFormat:@"%@%f米", str, meters];
}
参考资料来自stackoverflow
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值