Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jinagamvasubabu/polyfetcher
Gets the Polygon definitions from OpenStreetMaps and able to combine one or more polygons into one single Multipolygon
https://github.com/jinagamvasubabu/polyfetcher
hacktoberfest multipolygon-shape openstreetmaps polygons
Last synced: 29 days ago
JSON representation
Gets the Polygon definitions from OpenStreetMaps and able to combine one or more polygons into one single Multipolygon
- Host: GitHub
- URL: https://github.com/jinagamvasubabu/polyfetcher
- Owner: jinagamvasubabu
- Created: 2020-08-15T17:36:58.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2021-10-25T09:09:34.000Z (about 3 years ago)
- Last Synced: 2024-10-15T13:41:12.843Z (3 months ago)
- Topics: hacktoberfest, multipolygon-shape, openstreetmaps, polygons
- Language: Go
- Homepage: https://hangoutdude.com/poly_fetcher
- Size: 1.8 MB
- Stars: 4
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE-2.0.txt
Awesome Lists containing this project
README
polyfetcher
--
A Go Package can fetch polygon definitions from OpenStreet maps and it can also combine one or more polygons into one.
![alt text](https://github.com/jinagamvasubabu/polyfetcher/blob/master/images/poly_fetcher.jpg?raw=true)
## Overview
[![Build Status](https://circleci.com/gh/jinagamvasubabu/polyfetcher.svg?style=svg)](https://circleci.com/gh/jinagamvasubabu/polyfetcher)
[![Go Report Card](https://goreportcard.com/badge/github.com/jinagamvasubabu/polyfetcher)](https://goreportcard.com/report/github.com/jinagamvasubabu/polyfetcher)
[![GoDoc](https://godoc.org/github.com/jinagamvasubabu/polyfetcher?status.svg)](https://godoc.org/github.com/jinagamvasubabu/polyfetcher)
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)
[![Visits Badge](https://badges.pufler.dev/visits/jinagamvasubabu/polyfetcher)](https://badges.pufler.dev)
[![Maintainability](https://api.codeclimate.com/v1/badges/bc775ba7e9b6231175a2/maintainability)](https://codeclimate.com/github/jinagamvasubabu/polyfetcher/maintainability)## What it does?
* It can fetch Polygon definitions from `OpenstreetMaps` by taking an area name, throw error if the area is not in OSM database
* Combine one or more polygons into one single `Multipolygon`## Install
```
go get github.com/jinagamvasubabu/polyfetcher
```## How to use Fetch Polygons?
* get `polyfetcher`
```
go get github.com/jinagamvasubabu/polyfetcher
```
* import and use it like below:
```
import "github.com/jinagamvasubabu/polyfetcher"
import "github.com/sirupsen/logrus"
p := polyfetcher.GeometryUtils{}
resp, err := p.FetchPolygons(context.Background(), []string{"germany", "belgium"})
fmt.Println(resp)
```## How to use Combine Polygons?
* get `polyfetcher`
```
go get github.com/jinagamvasubabu/polyfetcher
```
* import and use it like below:
```
import "github.com/jinagamvasubabu/polyfetcher"
import "github.com/sirupsen/logrus"
p := polyfetcher.GeometryUtils{}
resp, err := p.CombinePolygons(context.Background(), []string{"germany", "belgium"})
fmt.Println(resp)
```### Response:
```go
//GeoJson Open street map response structure
type GeoJson struct {
Name string `json:"name"`
Type string `json:"type"`
Coordinates []interface{} `json:"coordinates"`
}
```## How to enable Debug logs?
* Pass logrus `LogLevel:logrus.DebugLevel` to `GeometryUtils` struct
```
import "github.com/jinagamvasubabu/polyfetcher"
p := polyfetcher.GeometryUtils{LogLevel:logrus.DebugLevel}
resp, err := p.CombinePolygons(context.Background(), []string{"germany", "belgium"})
```## How to validate the data ?
Response type is schema.GeoJson, you can marshal the response to string and use [geojsonlint](https://geojsonlint.com) to validate the geojson.
![alt text](https://github.com/jinagamvasubabu/polyfetcher/blob/master/images/geojsonlint.png?raw=true)Note:
If you get an error like Polygons and MultiPolygons should follow the right-hand rule then follow this below article to fix it.
[https://dev.to/jinagamvasubabu/solution-polygons-and-multipolygons-should-follow-the-right-hand-rule-2c8i](https://dev.to/jinagamvasubabu/solution-polygons-and-multipolygons-should-follow-the-right-hand-rule-2c8i)## Errors:
* If one of the area is invalid area then it can fetch the other areas if they are valid
* If all areas which were passed are invalid then it will throw error `error while fetching the polygon`## Goroutines Support:
Goroutines support to fetch areas concurrently instead of synchronously## Author
JinagamVasubabu
## License
Apache 2.0.