
Security News
ECMAScript 2025 Finalized with Iterator Helpers, Set Methods, RegExp.escape, and More
ECMAScript 2025 introduces Iterator Helpers, Set methods, JSON modules, and more in its latest spec update approved by Ecma in June 2025.
react-native-maps-directions-routes-api
Advanced tools
Routes Component for react react native using the NEW Routes API
A comprehensive React Native component built on top of Google Maps New Routes API to render directions and routes on a map. This package allows you to render routes between an origin and destination with options for alternative routes, intermediate stops, extra markers, and more.
The MapViewDirectionsRoutesAPI
component streamlines the process of fetching routes from the Google Maps Routes API and rendering them on a map. It uses various React hooks to manage state and effects, supports rerendering on prop changes, and includes built-in support for alternative routes and extra markers.
By adding this package to your application, you can easily configure the map rendering behavior with flexible options such as:
To install the MapViewDirectionsRoutesAPI
package, run the following command in your terminal:
npm install react-native-maps-directions-routes-api
yarn add react-native-maps-directions-routes-api
Ensure you have your Google Maps API key ready for usage. Usage Minimal Setup The minimal setup only requires an origin, destination, and an API key. Import and use the component as follows:
import React from 'react';
import { View } from 'react-native';
import MapViewDirectionsRoutesAPI from 'react-native-maps-directions-routes-api';
const origin = {
latitude: 6.5244,
longitude: 3.3792,
heading: 0,
customMarker: {
image: require('./assets/myloc.png'),
width: 40,
height: 50,
pinColor: 'blue',
title: 'Start',
},
};
const destination = {
latitude: 6.6000,
longitude: 3.3500,
heading: 0,
customMarker: {
image: require('./assets/destino.png'),
width: 40,
height: 50,
pinColor: 'yellow',
title: 'Destino',
anchorX: 0.5,
anchorY: 0.25,
centerOffsetX: 0,
centerOffsetY: 0,
},
};
const MinimalSetupExample = () => (
<View style={{ flex: 1 }}>
<MapViewDirectionsRoutesAPI
origin={origin}
destination={destination}
apikey={"GOOGLE_MAPS_APIKEY"}
/>
</View>
);
export default MinimalSetupExample;
To add intermediate stops along your route use the intermediates prop. This is ideal for journeys with stops or drop-offs.
import React from 'react';
import { View } from 'react-native';
import MapViewDirectionsRoutesAPI from 'react-native-maps-directions-routes-api';
const origin = { /* Same as above */ };
const destination = { /* Same as above */ };
const intermediateStop = {
location: {
latLng: {
latitude: 6.5500,
longitude: 3.3600,
customMarker: {
image: require('./assets/stop.png'),
width: 30,
height: 30,
pinColor: 'green',
title: 'Stop',
},
},
},
};
const IntermediateStopsExample = () => (
<View style={{ flex: 1 }}>
<MapViewDirectionsRoutesAPI
origin={origin}
destination={destination}
intermediates={[intermediateStop]}
apikey={"GOOGLE_MAPS_APIKEY"}
/>
</View>
);
export default IntermediateStopsExample;
The onReady callback is triggered when routes have been successfully fetched and are ready for use. You can access details like the distance, duration, legs, COORDINATES, polyline and more.
import React from 'react';
import { View, Alert } from 'react-native';
import MapViewDirectionsRoutesAPI from 'react-native-maps-directions-routes-api';
const origin = { /* Origin as above */ };
const destination = { /* Destination as above */ };
const onReadyHandler = (routes) => {
// For instance, route distances and durations can be used to update UI components.
console.log('Routes ready:', routes);
Alert.alert('Routes loaded', `Distance: ${routes[0].distance} meters\nDuration: ${routes[0].duration} seconds`);
};
const OnReadyExample = () => (
<View style={{ flex: 1 }}>
<MapViewDirectionsRoutesAPI
origin={origin}
destination={destination}
apikey={"GOOGLE_MAPS_APIKEY"}
onReady={onReadyHandler}
/>
</View>
);
export default OnReadyExample;
You can dynamically display extra markers by tying the extraMarkers prop to a state. This is useful when you want to update markers based on real-time data (e.g., driver locations).
import React, { useState, useEffect } from 'react';
import { View } from 'react-native';
import MapViewDirectionsRoutesAPI from 'react-native-maps-directions-routes-api';
const origin = { /* Origin as above */ };
const destination = { /* Destination as above */ };
const generateExtraMarkers = () =>
Array.from({ length: 40 }, (_, index) => {
const isBike = Math.random() < 0.1; // 10% chance
return {
latitude: 6.52 + Math.random() * 0.01,
longitude: 3.38 + Math.random() * 0.001,
heading: Math.floor(Math.random() * 360),
customMarker: {
image: isBike ? require('./assets/bikemap.png') : require('./assets/carmap.png'),
width: 30,
height: 40,
pinColor: isBike ? 'blue' : 'yellow',
title: isBike ? 'Bike Stop' : 'Car Stop',
anchorX: 0.5,
anchorY: 0.25,
centerOffsetX: 0,
centerOffsetY: 0,
},
};
});
const ExtraMarkersExample = () => {
const [drivers, setDrivers] = useState([]);
useEffect(() => {
// Simulate fetching/updating extra markers data.
const markers = generateExtraMarkers();
setDrivers(markers);
}, []);
return (
<View style={{ flex: 1 }}>
<MapViewDirectionsRoutesAPI
origin={origin}
destination={destination}
apikey={"GOOGLE_MAPS_APIKEY"}
extraMarkers={drivers}
/>
</View>
);
};
export default ExtraMarkersExample;
API Configuration Options Below is a summary of the key configuration props available:
* origin (object, required): The starting point of the route. Must include latitude, longitude, heading (optional), and a customMarker object (optional) (for customizing marker appearance).
* destination (object, required): The end point of the route. Similar structure as origin.
* apikey (string, required): Your Google Maps API key.
* waypoints (array, optional): Additional stop points along the route.
* intermediates (array, optional): Intermediate stops along the route. Each element should have a location property with latLng.
* onStart (function, optional): Callback invoked when route fetching begins.
* onReady (function, optional): Callback invoked when routes are successfully fetched. Provides route details (distance, duration, legs, etc.).
* onError (function, optional): Callback invoked when there is an error fetching the route.
* onSelectRoute (function, optional): Callback when a user selects a particular route.
* mode (string, default: DRIVE): Travel mode such as driving, walking, etc.
* languageCode (string, default: en-US): Language for the API responses.
* resetOnChange (boolean, default: true): Whether to reset state when key properties change.
* optimizeWaypoints (boolean, default: false): Optimize the order of intermediate waypoints.
* computeAlternativeRoutes (boolean, default: false): Whether to compute alternative routes.
* directionsServiceBaseUrl (string, default: https://routes.googleapis.com/directions/v2:computeRoutes): Base URL for the routes API.
* units (string, default: IMPERIAL): Measurement units.
* region (string): The region code.
* precision (string, default: low): Precision of the route.
* timePrecision (string, default: none): Time precision.
* channel (string): Optional channel.
* fieldMask (string): Fields to include in the response.
* routingPreference (string, default: TRAFFIC_AWARE_OPTIMAL): Routing preference.
* polylineQuality (string, default: OVERVIEW): Quality of the encoded polyline.
* polylineEncoding (string, default: ENCODED_POLYLINE): Polyline encoding.
* departureTime (any): Departure time.
* arrivalTime (any): Arrival time.
* routeModifiers (object): Modifiers for the route.
* regionCode (string): Specific region code.
* requestedReferenceRoutes (any): To request specific reference routes.
* extraComputations (array): Additional computations such as FUEL_CONSUMPTION, TOLLS.
* transitPreferences (object): Preferences for transit.
* fitToCoordinates (object): Configuration for auto-fitting the displayed markers on the map view. See the Fit to Coordinates section.
* extraMarkers (array): Additional markers to display on the map.
Customize markers by providing a customMarker object on each coordinate object. The keys include: -- # image: Local asset to use as the marker. -- # width & height: Dimensions for the marker. -- # pinColor: Color if no custom image is provided. -- # title: Title for the marker. -- # anchorX & anchorY: Anchor points. -- # centerOffsetX & centerOffsetY: Offset adjustments. If customMarker is omitted, the default marker (red) is used.
let sampleOrigin = {
"latitude": 16.5702678, //sample coordinates
"longitude": -3.264719, //sample coordinates
"latitudeDelta": 0.0005, //to control zoom levels
"longitudeDelta": 0.0005, //to control zoom levels
heading: 0, //marker direction/angle
customMarker: {
image: require("./assets/destino.png"),
width: 40, // image size
height: 50, // image size
pinColor: 'yellow', // not needed if image is set
title: 'Destino',
anchorX: 0.25, // play around with these figures to position your customMarker at the exact position
anchorY: 0.25, // play around with these figures to position your customMarker at the exact position
centerOffsetX: 0.5, // play around with these figures to position your customMarker at the exact position
centerOffsetY: 0.2 // play around with these figures to position your customMarker at the exact position
}
let styleMarker = {
bubble: { backgroundColor: '#000' },
arrow: {
borderColor: '#000',
borderLeftWidth: 3,
borderRightWidth: 3,
},
}
let sampleOrigin = {
"latitude": 16.5702678, //sample coordinates
"longitude": -3.264719, //sample coordinates
"latitudeDelta": 0.0005, //to control zoom levels
"longitudeDelta": 0.0005, //to control zoom levels
heading: 0, //marker direction/angle
customMarker: {
customText: "13 mins",
style: styleMarker // pass in your own styles to change marker properties
//omit style to use default text marker green (TOOLTIP STYLE)
anchorX: 0.25,
anchorY: 0.25,
centerOffsetX: 0.5,
centerOffsetY: 0.2
}
style.container = {}
style.bubble = {}
style.text = {}
style.arrow = {}
const style = {
container: {
flexDirection: 'column',
alignSelf: 'flex-start',
},
bubble: {
flexDirection: 'row',
alignSelf: 'flex-start',
backgroundColor: '#38902f',
padding: 4,
borderRadius: 60,
borderWidth: 0,
},
text: {
color: '#fff',
fontSize: 12,
},
arrow: {
width: 0,
height: 0,
borderLeftWidth: 10,
borderRightWidth: 10,
borderTopWidth: 10,
borderBottomWidth: 15,
borderStyle: 'solid',
borderLeftColor: 'transparent',
borderRightColor: 'transparent',
borderTopColor: '#38902f',
borderBottomColor: 'transparent',
alignSelf: 'center',
marginTop: -1,
},
};
The component uses the mapRef to automatically adjust the map view via the fitToCoordinates property. This positions the map so that all markers are visible. Adjust the edgePadding and animation settings via the fitToCoordinates prop.
Example configuration:
fitToCoordinates={{
edgePadding: { top: 90, right: 50, bottom: 100, left: 50 },
animated: true,
}}
You can mix and match the configurations as needed to suit your application. For example:
Switching between selected and non-selected routes: Tapping a route polyline updates the selected route using the onPress handler. Dynamically update extra markers: Bind the extraMarkers prop to a state that fetches or updates marker locations in real-time. Refer to the code samples provided in the usage section for practical implementations.
The MapViewDirectionsRoutesAPI
component accepts the following props:
apikey
: A string representing the API key for the directions service.origin
: An object representing the starting point of the route. An object with latitude
and longitude
properties (e.g. { latitude: 40.7128, longitude: -74.0060 }
).destination
: An object representing the ending point of the route. An object with latitude
and longitude
properties (e.g. { latitude: 34.0522, longitude: -118.2437 }
).intermediates
: An array of objects representing intermediate points along the route. Objects with latitude
and longitude
properties (e.g. [{ latitude: 41.8781, longitude: -87.6298 }, { latitude: 39.7392, longitude: -104.9903 }]).extraMarkers
: An array of objects representing additional markers to display along the route. Objects with latitude
and longitude
properties (e.g. [{ latitude: 40.7128, longitude: -74.0060 }, { latitude: 34.0522, longitude: -118.2437 }]).mode
: A string representing the mode of transportation (e.g. "DRIVE", "WALK", "TWO_WHEELER", "BICYCLE", "TRANSIT").languageCode
: A string representing the language code for the directions service (e.g. "en-US").resetOnChange
: A boolean indicating whether to reset the route when the origin, destination, or intermediates change.optimizeWaypoints
: A boolean indicating whether to optimize the route by reordering the waypoints.directionsServiceBaseUrl
: A string representing the base URL for the directions service.region
: A string representing the region for the directions service (e.g. "US").selectedRouteColor
: A string representing the color of the selected route.notselectedRouteColor
: A string representing the color of the non-selected routes.fieldMask
: A string representing the field mask for the directions service.computeAlternativeRoutes
: A boolean indicating whether to compute alternative routes.routingPreference
: A string representing the routing preference (e.g. "TRAFFIC_AWARE", "TRAFFIC_UNAWARE", "TRAFFIC_AWARE_OPTIMAL").units
: A string representing the units for the route distances (e.g. "METRIC", "IMPERIAL").polylineQuality
: A string representing the quality of the polyline (e.g. "OVERVIEW", "HIGH_QUALITY").polylineEncoding
: A string representing the encoding of the polyline (e.g. "ENCODED_POLYLINE", "GEO_JSON_LINESTRING").requestedReferenceRoutes
: A string representing the requested reference routes (e.g. "FUEL_EFFICIENT", "SHORTER_DISTANCE").extraComputations
: An array of strings representing the extra computations to perform (e.g. ["TOLLS", "FUEL_CONSUMPTION", "TRAFFIC_ON_POLYLINE"]).transitPreferences
: An object representing the transit preferences (e.g. { allowedTravelModes: ["BUS", "SUBWAY"], routingPreference: "LESS_WALKING" }
).routeModifiers
: An object representing the route modifiers (e.g. { avoidTolls: true, avoidHighways: false, vehicleInfo: { emissionType: "GASOLINE" } }
).onStart
: A function to call when the directions service starts.onReady
: A function to call when the directions service is ready.onError
: A function to call when an errorBelow are example screenshots to demonstrate different setups:
Ensure your API key is valid. A missing or invalid key will cause a warning error. Verify that the origin and destination objects include both latitude and longitude. When dealing with custom markers, confirm that the asset paths are correct and accessible. Use the browser or device console to check logs printed from console.warn for additional debugging information. License Distributed under the MIT License. See LICENSE for more information.
Happy Mapping! Work is in progress PR's are welcome
FAQs
Routes Component for react react native using the NEW Routes API
The npm package react-native-maps-directions-routes-api receives a total of 9 weekly downloads. As such, react-native-maps-directions-routes-api popularity was classified as not popular.
We found that react-native-maps-directions-routes-api demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
ECMAScript 2025 introduces Iterator Helpers, Set methods, JSON modules, and more in its latest spec update approved by Ecma in June 2025.
Security News
A new Node.js homepage button linking to paid support for EOL versions has sparked a heated discussion among contributors and the wider community.
Research
North Korean threat actors linked to the Contagious Interview campaign return with 35 new malicious npm packages using a stealthy multi-stage malware loader.