Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Dhi13man/open_route_service
An encapsulation made around openrouteservice API for Dart and Flutter projects. Made for easy generation of Routes and Directions on Maps, Isochrones, Time-Distance Matrix, Pelias Geocoding, POIs, Elevation and routing Optimizations using their amazing API.
https://github.com/Dhi13man/open_route_service
api-rest api-wrapper dart dart-library dart-package directions-api elevation-data flutter flutter-package geocoding hacktoberfest isochrones maps open-route-service open-source openrouteservice optimizations ors pois time-distance-matrix
Last synced: 4 months ago
JSON representation
An encapsulation made around openrouteservice API for Dart and Flutter projects. Made for easy generation of Routes and Directions on Maps, Isochrones, Time-Distance Matrix, Pelias Geocoding, POIs, Elevation and routing Optimizations using their amazing API.
- Host: GitHub
- URL: https://github.com/Dhi13man/open_route_service
- Owner: Dhi13man
- License: mit
- Created: 2021-09-25T07:37:20.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-04-07T06:21:19.000Z (11 months ago)
- Last Synced: 2024-08-01T12:26:12.170Z (7 months ago)
- Topics: api-rest, api-wrapper, dart, dart-library, dart-package, directions-api, elevation-data, flutter, flutter-package, geocoding, hacktoberfest, isochrones, maps, open-route-service, open-source, openrouteservice, optimizations, ors, pois, time-distance-matrix
- Language: Dart
- Homepage: https://pub.dev/packages/open_route_service
- Size: 1.23 MB
- Stars: 27
- Watchers: 1
- Forks: 8
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# open_route_service
[data:image/s3,"s3://crabby-images/cc136/cc136d407f5ba26865eb461db3ee8d341ed4eaa0" alt="License"](https://github.com/Dhi13man/open_route_service/blob/main/LICENSE)
[data:image/s3,"s3://crabby-images/2bffd/2bffdad3da5a33c7e162aadcea80ca1d3754225f" alt="Language"](https://dart.dev)
[data:image/s3,"s3://crabby-images/9b661/9b661b649e075c8346ee50b65e54f4e7a16d21e1" alt="Language"](https://flutter.dev)
[data:image/s3,"s3://crabby-images/1528c/1528c2ee57f21be64d75def190565815f37f3e3b" alt="Contributors"](https://github.com/Dhi13man/open_route_service/graphs/contributors)
[data:image/s3,"s3://crabby-images/6b8ac/6b8ac94d1038d44ae2482c203d9dfaa71540dfb9" alt="GitHub forks"](https://github.com/Dhi13man/open_route_service/network/members)
[data:image/s3,"s3://crabby-images/7b623/7b6238ae89cf2efb359e229a00ffd3888b11e829" alt="GitHub Repo stars"](https://github.com/Dhi13man/open_route_service/stargazers)
[data:image/s3,"s3://crabby-images/356e0/356e0a4985a42614e573a396ab2e55c48d9f9cdd" alt="Last Commit"](https://github.com/Dhi13man/open_route_service/commits/main)
[data:image/s3,"s3://crabby-images/6eb2f/6eb2fe75803bb89e7ceeecfdc12a82c729498342" alt="Build, Format, Test"](https://github.com/Dhi13man/open_route_service/actions)
[data:image/s3,"s3://crabby-images/91143/91143518b70460fe028d645ef338120f23aa8416" alt="open_route_service version"](https://pub.dev/packages/open_route_service)[data:image/s3,"s3://crabby-images/2f403/2f4034f43c95f3da94a0c32089d590fdbf21349b" alt=""Buy Me A Coffee""](https://www.buymeacoffee.com/dhi13man)
This package is an encapsulation/wrapper made around [openrouteservice API](https://openrouteservice.org) for Dart and Flutter projects.
The package enables the easy integration of the openrouteservice API with relevant data models, for generation of Routes and Directions on Maps, Isochrones, Time-Distance Matrix, Pelias Geocoding, POIs, Elevation, routing Optimizations etc, using their amazing API.
[Contribute to openrouteservice API by donating](https://openrouteservice.org/donations/) to help keep the service free and accessible to everyone. For more information about the API, view the [openrouteservice API documentation](https://openrouteservice.org/dev/#/api-docs).
## Contents
- [open\_route\_service](#open_route_service)
- [Contents](#contents)
- [Features](#features)
- [Getting started](#getting-started)
- [Steps for Usage](#steps-for-usage)
- [Example Usage](#example-usage)
- [Contribution Guidelines](#contribution-guidelines)
- [Dependencies](#dependencies)
- [Additional information](#additional-information)
- [Sponsor Message](#sponsor-message)## Features
The goal is to develop an all-encompassing package that can encapsulate everything openrouteservice API offers.
With all of their internal Optimizations, this includes:
1. **[Directions](https://openrouteservice.org/dev/#/api-docs/v2/directions/):**
Route Generation between any two or more coordinates for any mode of transportation. For example, from a starting point to a destination on `'foot-walking'`.E.g. `ORSDirections.directionsRouteCoordsGet` gives a `List` of `ORSCoordinate` which can then be easily used to draw a Polyline route on a map in a Flutter Application or anything else you can think of.
| Route Drawn on Flutter App Map using Coordinates |
| ------------------------------------------------ |
| ![Route Drawn on Map (Flutter)][route_img] |[route_img]: https://raw.githubusercontent.com/Dhi13man/open_route_service/main/screenshots/directions_map.png
2. **[Elevation](https://openrouteservice.org/dev/#/api-docs/elevation/):**
Get the elevation of a coordinate, or a list of coordinates. Fetches the `ElevationData` by taking a 2D `ORSCoordinate` or planar line geometry, and enriching it with elevation from a variety of datasets.| Elevation Response Received |
| ------------------------------------------- |
| ![Sample Elevation Response][elevation_img] |[elevation_img]: https://raw.githubusercontent.com/Dhi13man/open_route_service/main/screenshots/elevation_response.png
3. **[Isochrones](https://openrouteservice.org/dev/#/api-docs/v2/isochrones/):**
Obtain Isochrone (areas of reachability) Data for the locations given. The isochrone is a polygon that encloses a given point and is bounded by a given time.The isochrone data can be used to draw them on a map in a Flutter Application, or anything else you can think of.
| Isochrone Drawn on Map |
| ---------------------------------------- |
| ![Isochrone Drawn on Map][isochrone_img] |[isochrone_img]: https://raw.githubusercontent.com/Dhi13man/open_route_service/main/screenshots/isochrone_map.png
4. **[Time-Distance Matrix](https://openrouteservice.org/dev/#/api-docs/matrix):**
Obtain one-to-many, many-to-one and many-to-many matrices for time and distance. Returns duration or distance matrix for multiple source and destination points.5. **[Pelias Geocoding](https://openrouteservice.org/dev/#/api-docs/geocode):**
Resolve input coordinates to addresses and vice versa. Provides functionality for geocoding autocomplete queries, search queries, and reverse geocoding.| Reverse Geocoding Information used on Map |
| ------------------------------------------- |
| ![Reverse Geocode on Map][reverse_geo_img] |[reverse_geo_img]: https://raw.githubusercontent.com/Dhi13man/open_route_service/main/screenshots/reverse_geocoding_map.png
6. **[POIs](https://openrouteservice.org/dev/#/api-docs/pois):**
Obtains information about the Points of Interest (POIs) in the area surrounding a geometry which can either be a bounding box, polygon or buffered linestring, or point.The Points of Interest can be marked on a map in a Flutter Application, or their properties and information visualized in various ways, or anything else you can think of.
| Points of Interest Drawn on Map |
| ------------------------------- |
| ![POI Drawn on Map][pois_img] |[pois_img]: https://raw.githubusercontent.com/Dhi13man/open_route_service/main/screenshots/pois_map.png
7. **[Routing Optimizations](https://openrouteservice.org/dev/#/api-docs/optimization):**
The optimization endpoint solves Vehicle Routing Problems and can be used to schedule multiple vehicles and jobs, respecting time windows, capacities and required skills.This service is based on the excellent [Vroom](https://github.com/VROOM-Project/vroom) project. Please also consult [its API documentation](https://github.com/VROOM-Project/vroom/blob/master/docs/API.md).
| Optimization Data for Vroom Jobs and Vehicles extracted and their route information printed in Console |
| ------------------------------------------------------------------------------------------------------ |
| ![Optimization Route Data][optimization_routes_img] |[optimization_routes_img]: https://raw.githubusercontent.com/Dhi13man/open_route_service/main/screenshots/optimization_console.png
Appropriate tests have also been written for each of the above APIs and can be used to check if the package and/or API are functioning properly.
## Getting started
Run `dart pub add open_route_service` or `flutter pub add open_route_service` in your Dart/Flutter project directory to install the package.
## Steps for Usage
1. Import the package where needed:
```dart
import 'package:open_route_service/open_route_service.dart';
```2. Create a new instance of the class with your [openrouteservice API Key](https://openrouteservice.org/dev/#/signup):
```dart
OpenRouteService openrouteservice = OpenRouteService(apiKey: 'YOUR-API-KEY');
```3. Use the handy class methods to easily generate Directions, Isochrones, Time-Distance Matrix, Pelias Geocoding, POIs, Elevation and routing Optimizations etc, letting the package handle all the complex HTTP requests in the background for you.
### Example Usage
To use the package with the [Directions API](https://openrouteservice.org/dev/#/api-docs/v2/directions) to generate and draw a Route on a map in a Flutter application:
```dart
import 'package:open_route_service/open_route_service.dart';Future main() async {
// Initialize the openrouteservice with your API key.
final OpenRouteService client = OpenRouteService(apiKey: 'YOUR-API-KEY');// Example coordinates to test between
const double startLat = 37.4220698;
const double startLng = -122.0862784;
const double endLat = 37.4111466;
const double endLng = -122.0792365;// Form Route between coordinates
final List routeCoordinates = await client.directionsRouteCoordsGet(
startCoordinate: ORSCoordinate(latitude: startLat, longitude: startLng),
endCoordinate: ORSCoordinate(latitude: endLat, longitude: endLng),
);// Print the route coordinates
routeCoordinates.forEach(print);// Map route coordinates to a list of LatLng (requires google_maps_flutter package)
// to be used in the Map route Polyline.
final List routePoints = routeCoordinates
.map((coordinate) => LatLng(coordinate.latitude, coordinate.longitude))
.toList();// Create Polyline (requires Material UI for Color)
final Polyline routePolyline = Polyline(
polylineId: PolylineId('route'),
visible: true,
points: routePoints,
color: Colors.red,
width: 4,
);// Use Polyline to draw route on map or do anything else with the data :)
}```
## Contribution Guidelines
- Check the [in-depth Contribution Guide](https://github.com/Dhi13man/open_route_service/blob/main/CONTRIBUTING.md) for exact steps on how to contribute to the package.
- Contributions are welcome on [GitHub](https://www.github.com/dhi13man/open_route_service). Please ensure all the tests are running before pushing your changes. Write your own tests too!
- File any [issues or feature requests here,](https://www.github.com/dhi13man/open_route_service/issues) or help me resolve existing ones. :)
## Dependencies
- [Dart](https://www.dartlang.org/) or [Flutter](https://flutter.dev/), for the Dart SDK which this obviously runs on.
- [http,](https://pub.dev/packages/http) for internally making RESTful HTTP Network requests to the API endpoints.## Additional information
- Please [contribute to openrouteservice API by donating](https://openrouteservice.org/donations/) to help keep the service free and accessible to everyone.
- Go through the full documentation here: [openrouteservice API Documentation](https://openrouteservice.org/dev/#/api-docs/v2/directions).
- Reach out to me directly @dhi13man on [Twitter](https://twitter.com/dhi13man) or [GitHub](https://www.github.com/dhi13man) if you have any general questions or suggestions.
### Sponsor Message
The first release of this package was sponsored by [Cashtic](https://cashtic.com/), a Cross-Platform peer-to-peer ATM cash network for Android and Web. Get it on [Google Play!](https://play.google.com/store/apps/details?id=com.cashtic&hl=en&gl=US)