Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/SymbolixAU/spatialwidget
Utility package to convert R data into JSON for use in htmlwidget mapping libraries
https://github.com/SymbolixAU/spatialwidget
gis htmlwidgets r spatial
Last synced: 3 months ago
JSON representation
Utility package to convert R data into JSON for use in htmlwidget mapping libraries
- Host: GitHub
- URL: https://github.com/SymbolixAU/spatialwidget
- Owner: SymbolixAU
- License: other
- Created: 2018-10-27T23:32:10.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-05-20T23:42:31.000Z (8 months ago)
- Last Synced: 2024-09-30T10:48:45.037Z (4 months ago)
- Topics: gis, htmlwidgets, r, spatial
- Language: C++
- Homepage: https://symbolixau.github.io/spatialwidget/
- Size: 5.98 MB
- Stars: 18
- Watchers: 5
- Forks: 2
- Open Issues: 9
-
Metadata Files:
- Readme: README.Rmd
- License: LICENSE
Awesome Lists containing this project
README
---
output: github_document
---```{r setup, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "# ",
fig.path = "man/figures/README-",
out.width = "100%"
)
```# spatialwidget
### What's a 'spatialwidget'
Well, what do these packages have in common?
- leaflet
- googleway
- mapdeck
- mapview
- tmap1. They are all [htmlwidgets](https://www.htmlwidgets.org/)
2. They all plot interactive maps
3. They all take data from R and display it on the maps.And on 22nd August 2017 on the [r-spatial github page](https://github.com/r-spatial/discuss/issues/15#issue-251762127) it was requested if there could be a common package which could be shared by all the interactive web-plotting libraries
> Currently there is code in the leaflet package that extracts data from sp and sf objects and converts it into a dataframe that is then passed to the Javascript side (by converting it into a JSON).
This code is fairly generic and not really dependent on anything leaflet specific. It makes a lot of sense to take out this code and make it a package of its own. That way we can build other web plotting R packages to wrap say d3.geo or mapboxGL or cesium and reuse a major chunk of the code that takes data from spatial objects and passes it to Javascript.so **spatialwidget** is my attempt at this library.
### What does it do?
It takes a simple feature object (`sf`), plus some user-supplied arguments, and converts the data into JSON, ready for plotting/ parsing in whatever javascript library you chose.
### Can you show me?
Sure. In this example I'm using the `capitals` data, which is an `sf` object of all the capital cities.
```{r}
library(spatialwidget)
library(sf)
sf <- spatialwidget::widget_capitals
sf
```As each capital is a POINT, you can use `widget_point()` to conver it to JSON.
```{r}
l <- widget_point( data = sf[1:2, ], fill_colour = "country" , legend = F)
```Each row of `capitals` has been converted into a JSON object. And all these objects are within an array.
Look, here are the first two rows of `capitals` as JSON
```{r}
sf[1:2, ]
jsonify::pretty_json( l$data )
```You can see that the coordinates are inside a `geometry` object, and the user-defined `fill_colour` is within the `properties` object.
### That looks a lot like GeoJSON
Well spotted. But it's not quite GeoJSON for a very good reason.
Some plotting libraries can use more than one geometry, such as [mapdeck::add_arc()](https://github.com/SymbolixAU/mapdeck#basic-use), which uses an origin and destination. So spatialwidget needs to handle multiple geometries.
Typical GeoJSON will take the form
```js
[{"type":"Feature", "properties":{"stroke_colour":"#440154FF"},"geometry":{"type":"Point","coordinates":[0,0]}}]
```Whereas I've nested the geometries one-level deeper, so the pseudo-GeoJSON i'm using takes the form
```js
[{"type":"Feature", "properties":{"stroke_colour":"#440154FF"},"geometry":{"myGeometry":{"type":"Point","coordinates":[0,0]}}}]
```Where the `myGeometry` object is defined on a per-application bases. You are free to call this whatever you want inside your library.
### That sort of makes sense, but can you show me an example with multiple geometries?
Yep.
The `arcs` data is an `sf` object with two POINT geometry columns. So say we want to generate an arc-map showing an arc between Sydney and all the other capitals cities. Just call `widget_od`, supplying the origin and destination columns.
```{r}
l <- widget_od( widget_arcs[1:2, ], origin = "origin", destination = "destination")
jsonify::pretty_json( l$data )
```
Notice now the `geometry` object has within it an `origin` and a `destination`. This is why I've nested the geometries one level deeper within the GeoJSON
### How do I use it in my package?
You can use these R functions, but they have limited scope. This package has been designed so you use the C++ functions directly. I've gone into more detail in the [vignette](https://symbolixau.github.io/spatialwidget/), so it's probably best you read that to understand how to call the C++ functions.