Routing and displaying driving directions on map, including instructions for navigation, distance to destination, traffic etc. are few of the most important parts of developing a map based application. This REST API calculates driving routes between specified locations including via points based on route type(fastest or shortest), includes delays for traffic congestion , and is capable of handling additional route parameters like: type of roads to avoid, travelling vehicle type etc.
try {
DirectionResponse? directionResponse = await MapplsDirection(origin: LatLng(28.594475, 77.202432),destination: LatLng(28.554676, 77.186982)).callDirection();
} catch(e) {
PlatformException map = e as PlatformException;
print(map.code);
}
//OR
MapplsDirection(origin: LatLng(28.594475, 77.202432),destination: LatLng(28.554676, 77.186982)).callDirection().then((response) {
//Handle response
},onError: (e) {
print(e.code);
}).onError((error, stackTrace) => {});
origin(LatLng)
: pass the origin point- origin can also takes mapplsPin in parameter eg.,
originMapplsPin("17ZUL7")
- origin can also takes mapplsPin in parameter eg.,
destination(LatLng)
: pass the destination point- destination can also takes mapplsPin in parameter eg.,
destinationMapplsPin("MMI000")
- destination can also takes mapplsPin in parameter eg.,
profile(String)
: Below are the available profile:- DirectionsCriteria.PROFILE_DRIVING is Default :Meant for car routing
- DirectionsCriteria.PROFILE_WALKING: Meant for pedestrian routing. Routing with this profile is restricted to route_adv only. region & rtype request parameters are not supported in pedestrian routing
- DirectionsCriteria.PROFILE_BIKING:Meant for two-wheeler routing. Routing with this profile is restricted to route_adv only. region & rtype request parameters are not supported in two-wheeler routing.
- DirectionsCriteria.PROFILE_TRUCKING:Meant for Truck routing. Routing with this profile is restricted to route_adv only. region & rtype request parameters are not supported in truck routing.
resource(String)
: Below are the available resource:- DirectionsCriteria.RESOURCE_ROUTE is Default: to calculate a route & its duration without considering traffic conditions.
- DirectionsCriteria.RESOURCE_ROUTE_ETA get the updated duration of a route considering live traffic; Applicable for India only "region=ind" and "rtype=1" is not supported. This is different from route_traffic; since this doesn't search for a route considering traffic, it only applies delays to the default route.
- DirectionsCriteria.RESOURCE_ROUTE_TRAFFIC:
to search for routes considering live traffic; Applicable for India only “region=ind” and “rtype=1” is not supported
steps(bool)
:Return route steps for each route leg. Possible values are true/false. By default it will be used as false.overview(String)
: Add overview geometry either full, simplified according to highest zoom level it could be display on, or not at all. Below are the available value:- DirectionsCriteria.OVERVIEW_FULL
- DirectionsCriteria.OVERVIEW_FALSE
- DirectionsCriteria.OVERVIEW_SIMPLIFIED
excludes(List<String>)
: Additive list of road classes to avoid, order does not matter. Below are the available value: - DirectionsCriteria.EXCLUDE_FERRY- DirectionsCriteria.EXCLUDE_MOTORWAY
- DirectionsCriteria.EXCLUDE_TOLL
waypoint(List<LatLng>)
: pass single waypoint at a time- waypoint also takes mapplsPin in parameter eg.,
waypointMapplsPin(["MMI000"])
- waypoint also takes mapplsPin in parameter eg.,
alternatives(bool)
: Search for alternative routes.radiuses(List<double>)
: Limits the search to given radius in meters. For all way-points including start and end points.geometries(String)
: This parameter used to change the route geometry format/density (influences overview and per step).Below are the available value:- DirectionsCriteria.GEOMETRY_POLYLINE: with 5 digit precision
- DirectionsCriteria.GEOMETRY_POLYLINE6 (Default): with 6 digit precision
code
(String): if request is successful, response is .ok.. Else, see the service dependent and general status codes. In case of error, .NoRoute. code is supported (in addition to the general ones) which means .no route found..routes
(List<DirectionsRoute>
): A list of DirectionsRoute objects, each having potentially multiple via pointswaypoints
(List<DirectionsWaypoint>
): Array of DirectionsWaypoint objects representing all waypoints in order
distance
(double): The distance travelled by the route; unit is meter.duration
(double): The estimated travel time; unit is second.geometry
(String): returns the whole geometry of the route as per given parameter .geometries. default is encoded .polyline6. with 6 digit accuracy for positional coordinates.legs
(List<RouteLeg>
): The legs between the given waypoints, representing an array of RouteLeg between two waypoints.
distance
(double): The distance of travel to the subsequent legs, in metersduration
(double): The estimated travel time, in secondssteps
(List<LegStep>
): Return route steps for each route leg depending upon steps parameter.
distance
(double) :The distance of travel to the subsequent step, in metersduration
(double): The estimated travel time, in secondsgeometry
(double): The un-simplified geometry of the route segment, depends on the given geometries parameter.name
(String): The name of the way along which travel proceeds.mode
(String): signifies the mode of transportation; driving as default.maneuver
(StepManeuver): A StepManeuver object representing a maneuverdrivingSide
(String): .Left. (default) for India, Sri Lanka, Nepal, Bangladesh & Bhutan.intersections
(List<StepIntersection>
): A list of StepIntersection objects that are passed along the segment, the very first belonging to the StepManeuver
location
(LatLng): A Point describing the location of the turnbearingBefore
(double): The clockwise angle from true north to the direction of travel immediately before the maneuver.bearingAfter
(double): The clockwise angle from true north to the direction of travel immediately after the maneuver.type
(String): An optional string indicating the direction change of the maneuver.modifier
(String): A string indicating the type of maneuver. New identifiers might be introduced without API change. Types unknown to the client should be handled like the .turn. type, the existence of correct modifier values is guaranteed.
location
(LatLng): point describing the location of the turn.bearings
(List<Integer>
): A list of bearing values (e.g. [0,90,180,270]) thxat are available at the intersection. The bearings describe all available roads at the intersection.classes
(List<String>
): Categorised types of road segments e.g. Motorwayentry
(List<Boolean>
): A list of entry flags, corresponding in a 1:1 relationship to the bearings. A value of true indicates that the respective road could be entered on a valid route. false indicates that the turn onto the respective road would violate a restriction.in
(Integer): index into bearings/entry array. Used to calculate the bearing just before the turn. Namely, the clockwise angle from true north to the direction of travel immediately before the maneuver/passing the intersection. Bearings are given relative to the intersection. To get the bearing in the direction of driving, the bearing has to be rotated by a value of 180. The value is not supplied for depart maneuvers.out
(Integer): index into the bearings/entry array. Used to extract the bearing just after the turn. Namely, The clockwise angle from true north to the direction of travel immediately after the maneuver/passing the intersection. The value is not supplied for arrive maneuvers.lanes
(List<IntersectionLanes>
Array of IntersectionLanes objects that denote the available turn lanes at the intersection. If no lane information is available for an intersection, the lanes property will not be present.):valid
(bool): verifying lane info.indications
(List<String>
): Indicating a sign of directions like Straight, Slight Left, Right, etc.
name
(String): Name of the street the coordinate snapped to.location
(LatLng): Point describing the snapped location of the waypoint.
Adding driving directions API would help to add predicted travel time & duration from a given origin point to a number of points. The Driving Distance Matrix API provides driving distance and estimated time to go from a start point to multiple destination points, based on recommended routes from Mappls Maps and traffic flow conditions
Get driving time and distance between a center point and up to 10 destination points using Mappls Maps Distance API
try {
DistanceResponse? response = await MapplsDistanceMatrix(sources: ["77.89,28.777"], destinations: ["MMI000"]).callDistanceMatrix();
} catch(e) {
PlatformException map = e as PlatformException;
print(map.code);
}
//OR
MapplsDistanceMatrix(sources: ["77.89,28.777"], destinations: ["MMI000"]).callDistanceMatrix().then((response) {
//Handle response
},onError: (e) {
print(e.code);
}).onError((error, stackTrace) => {});
sources(List<String>)
: A List full of sources.destinations(List<String>)
: A full list of destinations
profile(String)
: Only supports DistanceCriteria.PROFILE_DRIVING.resource(Strng)
: Below are the available value:- DistanceCriteria.RESOURCE_DISTANCE Default: to calculate the route & duration without considering traffic conditions.
- DistanceCriteria.RESOURCE_DISTANCE_ETA: to get the updated duration considering live traffic; Applicable for India only “region=ind” and “rtype=1” is not supported. This is different from distance_matrix_traffic; since this doesn't search for a route considering traffic, it only applies delays to the default route.
- DistanceCriteria.RESOURCE_DISTANCE_TRAFFIC: to search for routes considering live traffic; Applicable for India only “region=ind” and “rtype=1” is not supported
responseCode
(int): Response codes of the api.version
(String): Version of the Api.results
(DistanceResults): Array of results, each consisting of the following parameters
code
: if the request was successful, code is ok.durations
(List<Double[]>
): Duration in seconds for source to source (default 0), 1st, 2nd, 3rd secondary locations... from source.distances
(List<Double[]>
): Distance in meters for source to source (default 0), 1st, 2nd, 3rd secondary locations... from source.
For any queries and support, please contact:
Email us at apisupport@mappls.com
Support
Need support? contact us!