Как рассчитать расстояние между двумя местами, используя формулу Haversine в iPhone? - PullRequest
0 голосов
/ 03 августа 2011

Я хочу рассчитать расстояние между двумя местами, используя формулу Хаверсайна. На самом деле у меня есть значения широты и долготы в двух местах. Теперь я хочу вычислить расстояние между этими местами, используя формулу Haversine.

Например:

 First Place: 
           "lat" :  12.97159870,
           "lng" : -77.59456270

Second Place:
           "lat" :  9.915996999999999,
           "lng" : -78.1218470
        },

Теперь я хочу вычислить расстояние, используя Формула Хаверсайна .

Пожалуйста, помогите мне. Спасибо!

Ответы [ 3 ]

12 голосов
/ 03 августа 2011

Вы можете использовать метод distanceLromation класса CLLocation (CoreLocation.framework): (CLLocation *) loc;

CLLocation *locA = [[CLLocation alloc] initWithLatitude:lat1 longitude:long1];
CLLocation *locB = [[CLLocation alloc] initWithLatitude:lat2 longitude:long2];
CLLocationDistance distance = [locA distanceFromLocation:locB];
[locA release]; [locB release];
6 голосов
/ 03 августа 2011

iOS предоставляет стандартные средства для расчета расстояния между двумя географическими точками - для этого вам нужно использовать класс CLLocation:

#import <CoreLocation/CoreLocation.h>

CLLocation *loc1 = [[[CLLocation alloc] initWithLatitude:12.97159870 longitude:-77.59456270] autorelease];

CLLocation *loc2 = [[[CLLocation alloc] initWithLatitude: 9.915996 longitude:-78.1218470] autorelease];

double distance = [loc1 distanceFromLocation: loc2];

Вам также необходимо добавить CoreLocation.framework для связи с вашим проектом.

1 голос
/ 19 июня 2015

// Скопируйте библиотеку в ваш проект https://github.com/heycarsten/haversine-objc. Затем вы получите расстояние между двумя точками с помощью

    Haversine *hvs = [[Haversine alloc]initWithLat1:Lati1 lon1:Longi1 lat2:Lati2 lon2:Longi2];

// Получение расстояния с помощью математической формулы ..

    double dLat1InRad = DEGREES_TO_RADIANS(Lati1);
    double dLong1InRad = DEGREES_TO_RADIANS(Longi1);
    double dLat2InRad = DEGREES_TO_RADIANS(Lati2);
    double dLong2InRad = DEGREES_TO_RADIANS(Longi2);
    double dLongitude = dLong2InRad - dLong1InRad;
    double dLatitude = dLat2InRad - dLat1InRad;
    double a = pow(sin(dLatitude/2.0), 2)+ cos(dLat1InRad) * cos(dLat2InRad) * pow(sin(dLongitude / 2.0), 2);
    double c = 2.0 * asin(sqrt(a));
    const double kEarthRadiusKms = 6376.5;
    double dDistance = kEarthRadiusKms * c;
...