Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/makieorg/osmmakie.jl

A Makie.jl recipe for plotting OpenStreetMap data.
https://github.com/makieorg/osmmakie.jl

Last synced: 2 days ago
JSON representation

A Makie.jl recipe for plotting OpenStreetMap data.

Awesome Lists containing this project

README

        

# OSMMakie

A [Makie](https://github.com/JuliaPlots/Makie.jl) recipe for plotting [OpenStreetMap](https://www.openstreetmap.org/) data.
It makes heavy use of the [GraphMakie](https://github.com/JuliaPlots/GraphMakie.jl) package and extends it to work with the specific features of an `OSMGraph`.

Please note that this recipe provides some opinionated (but hopefully sane) defaults for how the OpenStreetMap data should be plotted.
However, users have full control over every aspect of the plot and can style them to their likings.

## Example

### Basic usage

```julia
using LightOSM
using OSMMakie
using GLMakie

# define area boundaries
area = (
minlat = 51.5015, minlon = -0.0921, # bottom left corner
maxlat = 51.5154, maxlon = -0.0662 # top right corner
)

# download OpenStreetMap data
download_osm_network(:bbox; # rectangular area
area..., # splat previously defined area boundaries
network_type = :drive, # download motorways
save_to_file_location = "london_drive.json"
);

# load as OSMGraph
osm = graph_from_file("london_drive.json";
graph_type = :light, # SimpleDiGraph
weight_type = :distance
)

# use min and max latitude to calculate approximate aspect ratio for map projection
autolimitaspect = map_aspect(area.minlat, area.maxlat)

# plot it
fig, ax, plot = osmplot(osm; axis = (; autolimitaspect))
```

Output:

![London map](https://github.com/fbanning/OSMMakie-assets/blob/master/London.png)

### Inspection

To enable edge inspection:

```julia
DataInspector(fig)
```

Output:

![London map with inspection enabled](https://github.com/fbanning/OSMMakie-assets/blob/master/London_inspection.png)

Inspection of nodes is disabled by default.
Set `inspect_nodes` to `true` to enable it.

```julia
fig, ax, plot = osmplot(osm; inspect_nodes = true)
ax.aspect = DataAspect()
DataInspector(fig)
```

### Buildings

Buildings polygons can also be added to the plot:

```julia
# download OpenStreetMap buildings data
download_osm_buildings(:bbox;
area...,
metadata = true,
download_format = :osm,
save_to_file_location = "london_buildings.osm",
);

# load as Buildings Dict
buildings = buildings_from_file("london_buildings.osm");

# plot London map with buildings
# also directly provide a figure size and limits for the plot
fig = Figure(; size = (1000,900))
ax = fig[1,1] = Axis(fig;
limits = ((area.minlon, area.maxlon), (area.minlat, area.maxlat)),
autolimitaspect
)
plot = osmplot!(osm; buildings)
```

Output:

![London map with buildings layer](https://github.com/fbanning/OSMMakie-assets/blob/master/London_buildings.png)

## Contributions

All contributions are welcome!
- If you need some inspiration what to work on, have a look at the [TODO lists](https://github.com/fbanning/OSMMakie.jl/projects).
- If you have a vague idea about a feature and it's not already on the list, get in touch via the discussion section.
- If you already know what you want to add/fix, please feel free to open a new issue.

This recipe is currently written for use with [LightOSM](https://github.com/DeloitteDigitalAPAC/LightOSM.jl) `OSMGraph`s but can be extended to work with other OSM backends as well.
PRs regarding this are also very much encouraged!

## License

Please refer to the [LICENSE](LICENSE) file included in this repository.