Ответ 1
Попробуйте это вместо:
CLLocationDistance meters = [newLocation distanceFromLocation:oldLocation];
Метод, который вы пытаетесь использовать, - это метод объекта CLLocation :)
Просто быстрый вопрос о Core Location, я пытаюсь рассчитать расстояние между двумя точками, код ниже:
-(void)locationChange:(CLLocation *)newLocation:(CLLocation *)oldLocation
{
// Configure the new event with information from the location.
CLLocationCoordinate2D newCoordinate = [newLocation coordinate];
CLLocationCoordinate2D oldCoordinate = [oldLocation coordinate];
CLLocationDistance kilometers = [newCoordinate distanceFromLocation:oldCoordinate] / 1000; // Error ocurring here.
CLLocationDistance meters = [newCoordinate distanceFromLocation:oldCoordinate]; // Error ocurring here.
}
Я получаю следующую ошибку в последних двух строках:
error: невозможно преобразовать в тип указателя
Я искал Google, но ничего не могу найти.
Попробуйте это вместо:
CLLocationDistance meters = [newLocation distanceFromLocation:oldLocation];
Метод, который вы пытаетесь использовать, - это метод объекта CLLocation :)
Расстояние рассчитывается между 2 CLLocations, а не между координатами.
Вам нужно использовать эти координаты, чтобы получить CLLocations для соответствующих координат, используя следующую строку кода
CLLocation *newLocation = [[CLLocation alloc] initWithCoordinate: newCoordinate altitude:1 horizontalAccuracy:1 verticalAccuracy:-1 timestamp:nil];
Аналогично для другой координаты, а затем вы можете рассчитать расстояние между этими двумя местоположениями, используя следующую строку кода
CLLocationDistance kilometers = [newLocation distanceFromLocation:oldLocation] / 1000;
Надеюсь, это поможет вам.
Обновление: Swift 3.0
let distanceKiloMeters = (newLocation.distance(from: oldLocation))/1000
В Swift
Создайте функцию метода, которая вычисляет расстояние между двумя местоположениями:
func distanceBetweenTwoLocations(source:CLLocation,destination:CLLocation) -> Double{
var distanceMeters = source.distanceFromLocation(destination)
var distanceKM = distanceMeters / 1000
let roundedTwoDigit = distanceKM.roundedTwoDigit
return roundedTwoDigit
}
Если вам нужны только две цифры:
extension Double{
var roundedTwoDigit:Double{
return Double(round(100*self)/100)
}
}
Если вы собираетесь использовать 2 значения CLLocationCoordinate2D, вы можете использовать это.
Это Swift 2.1 на Xcode 7.1
import CoreLocation
extension CLLocationCoordinate2D {
func distanceInMetersFrom(otherCoord : CLLocationCoordinate2D) -> CLLocationDistance {
let firstLoc = CLLocation(latitude: self.latitude, longitude: self.longitude)
let secondLoc = CLLocation(latitude: otherCoord.latitude, longitude: otherCoord.longitude)
return firstLoc.distanceFromLocation(secondLoc)
}
}
Проблема заключается в том, что вы вызываете объект метод:
- (CLLocationDistance)distanceFromLocation:(const CLLocation *)location;
класса CLLocation.
CLLocationCoordinate2D на самом деле является структурой, состоящей из двух двухлокальных:
typedef struct
{
CLLocationDegrees latitude;
CLLocationDegrees longitude;
} CLLocationCoordinate2D;
Правильный способ сделать это - получить объект CLLocation
и вызвать на нем distanceFromLocation
. Вот так:
CLLocation* newLocation;
CLLocation* oldLocation;
CLLocationDistance distance = [newLocation distanceFromLocation:oldLocation];
Конечно, сначала вам нужно инициализировать оба этих значения (например, от CLLocationManager
).
#import <CoreLocation/CoreLocation.h>
CLLocation *locA = [[CLLocation alloc] initWithLatitude:"Value" longitude:"Value"];
CLLocation *locB = [[CLLocation alloc] initWithLatitude:"Value" longitude:"Value"];
CLLocationDistance distance = [locA distanceFromLocation:locB];
NSLog(@"distance:-%f",distance);//distance in Miter
Взято из превосходной библиотеки Утилиты CoreLocation:
- (CLLocationDistance) distanceFromCoordinate:(CLLocationCoordinate2D) fromCoord;
{
double earthRadius = 6371.01; // Earth radius in Kilometers
// Get the difference between our two points then convert the difference into radians
double nDLat = (fromCoord.latitude - self.coordinate.latitude) * kDegreesToRadians;
double nDLon = (fromCoord.longitude - self.coordinate.longitude) * kDegreesToRadians;
double fromLat = self.coordinate.latitude * kDegreesToRadians;
double toLat = fromCoord.latitude * kDegreesToRadians;
double nA = pow ( sin(nDLat/2), 2 ) + cos(fromLat) * cos(toLat) * pow ( sin(nDLon/2), 2 );
double nC = 2 * atan2( sqrt(nA), sqrt( 1 - nA ));
double nD = earthRadius * nC;
return nD * 1000; // Return our calculated distance in meters
}