views:

671

answers:

3

I have a Core Data database with latitude and longitude properties. Is there a way to use Core Location's getDistanceFrom: method to find the five nearest locations to a CLLocation obtained from the GPS? Do I have to load all the objects using Core Data and parse through them, using getDistanceFrom: on each one or is there an easier way?

+1  A: 

You can't use CoreData to find the nearest object, but might want to narrow down the query by using a bounding box. To find the nearest object, you might prefer to use simply the difference in lat/long which is considerably faster than calculating the actual distances.

I had a similar question:

http://stackoverflow.com/questions/1625187/coredata-find-minimum-of-calculated-property

Felix
Thanks for the link.
nevan
+5  A: 

Hi,

You will have to iterate through them one by one; as far as I know there is no other way to do it.

However, you can make this more efficient by using a bounding box when you get the items from core data - this will reduce the number of objects that will be returned.

i.e. Something like

float latMax = wantedLat + 1;
float latMin = wantedLat - 1;
float lngMax = wantedLng + 1;
float lngMin = wantedLng - 1;
NSPredicate *predicate = [NSPredicate
    predicateWithFormat:@"lat > %f and lat < %f and lng > %f and lng < %f",
    latMin, latMax, lngMin, lngMax];

Though, depending on how much data you have and how closely it's spaced, you will want to use a different number than 1!

Sam

PS Also, I haven't taken into account the fact that longitude wraps!

deanWombourne
Looks like useful code, thanks.
nevan
Thanks for this -- I used something similar in my app. But it looks to me that both sets of < and > are the wrong way now!
iPhoneDollaraire
You're right - oops!
deanWombourne
A: 

The following example is almost what you are looking for. It uses a SQLite function to calculate the distance in the ORDER BY clause (Haversine formula). Problem is that this example does not use Core-Data, but the SQLite API directly.

http://www.thismuchiknow.co.uk/?p=71

Bjinse