A lightweight wrapper for The Google Directions API. See the Google Maps API Web Services documentation.
As Google wrote: "The Google Directions API is a service that calculates directions between locations using an HTTP request. You can search for directions for several modes of transportation, include transit, driving, walking or cycling. Directions may specify origins, destinations and waypoints either as text strings (e.g. "Chicago, IL" or "Darwin, NT, Australia") or as latitude/longitude coordinates. The Directions API can return multi-part directions using a series of waypoints."
The OCGoogleDirectionsAPI library allows your iOS apps to deal with this powerful service easily. IMPORTANT: It uses NSURLSession
only available in iOS 7.0+. It is not compatible with iOS 6.x and lower.
CocoaPods is the dependency manager for Objective-C projects. It has thousands of libraries and can help you scale your projects elegantly.
platform :ios, '7.0'
pod "OCGoogleDirectionsAPI", "~> 0.1.6"
It's really simple. To get directions you need to do 4 easy steps.
-
Importing headers. From now all
OCDirections*
general classes will be accessible for you.#import <OCGoogleDirectionsAPI/OCGoogleDirectionsAPI.h>
-
Secondly you can provide your Google API Key. The method
application:didFinishLaunchingWithOptions:
in AppDelegate seams to be a good place for this code. However the API Key is now optional. Please check API Key section to decide if you need the key or not.[OCDirectionsAPIClient provideAPIKey:@"<YOUR API KEY>"];
-
Prepare a
OCDirectionsRequest
object to specify route(s) you want to retrieve from the service.OCDirectionsRequest *request = [OCDirectionsRequest requestWithOriginString:@"<ORIGIN>" andDestinationString:@"<DESTINATION>"];
-
Create an instance of
OCDirectionsAPIClient
and calldirections:response:
method to retrieve required data (OCDirectionsResponse
) asynchronously.OCDirectionsAPIClient *client = [OCDirectionsAPIClient new]; [client directions:request response:^(OCDirectionsResponse *response, NSError *error) { // e.g. if (error) { return; } if (response.status != OCDirectionsResponseStatusOK) { return } // some code }];
Some init methods of OCDirectionsAPIClient
:
- (instancetype)initWithKey:(NSString *)key;
- (instancetype)initWithNoKeyUseHttps:(BOOL)useHttps;
- (instancetype)initWithKey:(NSString *)key useHttps:(BOOL)https;
Sequence diagram
That's all! It's quite easy, isn't it? If you like to know a bit more about requests please read the next section OCDirectionsRequest.
To create an isntance of OCDirectionsRequest
you can use one of the following factory methods.
+ (instancetype)requestWithOriginLocation:(CLLocation *)origin andDestinationLocation:(CLLocation *)destination;
+ (instancetype)requestWithOriginString:(NSString *)origin andDestinationLocation:(CLLocation *)destination;
+ (instancetype)requestWithOriginLocation:(CLLocation *)origin andDestinationString:(NSString *)destination;
+ (instancetype)requestWithOriginString:(NSString *)origin andDestinationString:(NSString *)destination;
To read more about available attributes please see the Request parameters page.
[request setAlternatives:YES];
[request setRegion:@"pl"];
[request setLanguage:@"pl"];
Here you can find the list of supported languages: https://developers.google.com/maps/faq#languagesupport
There are 3 different restrictions:
OCDirectionsRequestRestrictionAvoidTolls
OCDirectionsRequestRestrictionAvoidHighways
OCDirectionsRequestRestrictionAvoidFerries
You can ask to avoid one or even all of them by calling the setRestrictions:
method.
[request setRestrictions:@[@(OCDirectionsRequestRestrictionAvoidTolls), @(OCDirectionsRequestRestrictionAviodFerries)];
The API allows to choose one of the following travel modes:
OCDirectionsRequestTravelModeDriving
OCDirectionsRequestTravelModeWalking
OCDirectionsRequestTravelModeBicycling
OCDirectionsRequestTravelModeTransit
[request setTravelMode:OCDirectionsRequestTravelModeBicycling];
Available units:
OCDirectionsRequestUnitDefault
OCDirectionsRequestUnitMetric
OCDirectionsRequestUnitImperia
[request setUnit:OCDirectionsRequestUnitMetric];
You need to set NSArray
of NSString
and CLLocation
objects.
CLLocation *firstLocation = [[CLLocation alloc] initWithLatitude:51.2314 longitude:21.3243];
CLLocation *secondLocation = [[CLLocation alloc] initWithLatitude:51.1314 longitude:21.1321];
[request setWaypoints:@[@"London", firstLocation, "Reading", secondLocation]];
[request setWaypointsOptimise:YES];
[request setTrafficModel:OCDirectionsRequestTrafficModelOptimistic];
[request setTransitMode:OCDirectionsRequestTransitModeBus | OCDirectionsRequestTransitModeTrain];
[request setTransitRoutingPreference:OCDirectionsRequestTransitRoutingPreferenceFewerTransfers];
Classes:
- OCDirectionsResponse
- OCDirectionsResponseStatus
- OCDirectionsRoute
- OCDirectionsLeg
- OCDirectionsPolyline
- OCDirectionsBounds
- OCDirectionsDistance
- OCDirectionsDuration
- OCDirectionsStep
- OCDirectionsWaypoint
- OCDirectionsFare
Properties:
- dictionary
NSDictionary*
- status
OCDirectionsResponseStatus
- routes
NSArray*
(array ofOCDirectionsRoute*
) - errorMessage
NSString*
- route
NSDirectionsRoute*
Be aware that geocoded_waypoints
property is not supported in the current version (#8).
Enum:
OCDirectionsResponseStatusNotInitialized
OCDirectionsResponseStatusOK
OCDirectionsResponseStatusNotFound
OCDirectionsResponseStatusZeroResults
OCDirectionsResponseStatusMaxWaypointsExceeded
OCDirectionsResponseStatusInvalidRequest
OCDirectionsResponseStatusOverQueryLimit
OCDirectionsResponseStatusRequestDenied
OCDirectionsResponseStatusUnknownError
Properties:
- dictionary
NSDictionary*
- legs
NSArray*
(array ofOCDirectionsLeg*
) - copyrights
NSString*
- warnings
NSArray*
(array ofNSString*
) - waypointOrder
NSArray*
(array ofNSNumber*
) - overviewPolyline
OCDirectionsPolyline*
- bounds
OCDirectionsBounds*
- summary
NSString*
Properties:
- dictionary
NSDictionary*
- distance
OCDirectionsDistance*
- duration
OCDirectionsDuration*
- durationInTraffic
OCDirectionsDuration*
- endAddress
NSString*
- endLocation
OCLocationCoordinate2D
- startAddress
NSString*
- startLocation
OCLocationCoordinate2D
- steps
NSArray*
(array ofOCDirectionsStep*
) - viaWaypoint
NSArray*
(array ofOCDirectionsWaypoint*
)
Properties:
- dictionary
NSDictionary*
- points
NSString*
Properties:
- dictionary
NSDictionary*
- southwest
CLLocationCoordinate2D
- northeast
CLLocationCoordinate2D
Properties:
- dictionary
NSDictionary*
- text
NSString*
- value
NSNumber*
Properties:
- dictionary
NSDictionary*
- text
NSString*
- value
NSNumber*
Properties:
- dictionary
NSDictionary*
- distance
OCDirectionsDistance*
- duration
OCDirectionsDuration*
- endLocation
CLLocationCoordinate2D
- htmlInstructions
NSString*
- maneuver
NSString*
- polyline
OCDirectionsPolyline*
- startLocation
CLLocationCoordinate2D
- travelMode
OCDirectionsRequestTravelMode
Properties:
- dictionary
NSDictionary*
- location
CLLocationCoordinate2D
- stepIndex
NSNumber*
- stepInterpolation
NSNumber*
Properties:
- dictionary
NSDictionary*
- currency
NSString*
- text
NSString*
- value
NSNumber*
Did you find a bug? Do you have great ideas how to make the library better? or you just want to say hello:) ... drop me a line on twitter @marciniwanicki.
- Add samples.
- Write unit tests.
- Implement releasing dictionary object when the response tree is fully initialised.
OCGoogleDirectionsAPI is available under the MIT license. See the LICENSE file for more info.