SPGooglePlacesAutocomplete is a simple objective-c wrapper around the Google Places Autocomplete API. The API can be used to provide autocomplete functionality for text-based geographic searches, by returning Places such as businesses, addresses, and points of interest as a user types. SPGooglePlacesAutocomplete also provides support for converting Place results into CLPlacemark objects for easy mapping with MKMapView.
SPGooglePlacesAutocomplete requires a deployment target >= iOS 6.0 and ARC.
- Create a new group in your project
- Drag all the files from /SPGooglePlacesAutocomplete into this group
- Include SPGooglePlacesAutocomplete wherever you need it with
#import "SPGooglePlacesAutocomplete.h"
.
Instantiate a new SPGooglePlacesAutocompleteQuery and fill in the properties you'd like to specify.
#import "SPGooglePlacesAutocomplete.h"
...
SPGooglePlacesAutocompleteQuery *query = [[SPGooglePlacesAutocompleteQuery alloc] initWithApiKey:@"YourGoogleAPIKey"];
query.input = @"185 berry str"; // search key word
query.location = CLLocationCoordinate2DMake(37.76999, -122.44696); // user's current location
query.radius = 100.0; // search addresses close to user
query.language = @"en"; // optional
query.types = SPPlaceTypeGeocode; // Only return geocoding (address) results.
Then, call -fetchPlaces to ping Google's API and fetch results. The resulting array will return objects of the SPGooglePlacesAutocompletePlace class.
[query fetchPlaces:^(NSArray *places, NSError *error) {
NSLog(@"Places returned %@", places);
}];
If you need to update the query (for instance, as the user types), simply update the appropriate properties and call -fetchPlaces again. Any outstanding requests will automatically be cancelled and a new request with the updated properties will be issued.
The Google Places Autocomplete API will return the names of Places that match your query. It will not, however, return lat-long information about these results. SPGooglePlacesAutocomplete handles this by resolving Place results to placemarks. Simply call -resolveToPlacemark on a SPGooglePlacesAutocompletePlace:
[query fetchPlaces:^(NSArray *places, NSError *error) {
SPGooglePlacesAutocompletePlace *place = [places firstObject];
if (place) {
[place resolveToPlacemark:^(CLPlacemark *placemark, NSString *addressString, NSError *error) {
NSLog(@"Placemark: %@", placemark);
}];
}
}];
When searching for "geocode" (address) Places, the library utilizes CLGeocoder to geocode the address. When searching for "establishment" (business) Places, the library will automatically ping The Google Places API to fetch the details needed to geolocate the business.
For an example of how to use SPGooglePlacesAutocomplete, please see the included example project. I put a functional Google API key in the project, please don't use it elsewhere!