The giscourse package has four composite high level functions that load in data for a site.
You can either use a string of characters to geocode the site, or the coordinates as latitude and longitude. If a distance in meters is provided the functions download all features within this radius. If no distance is given then the default is to download all the features inside the OS 5km grid square for the site.
library(giscourse)
conn<-connect()
lcover<-landcover("Arne, Dorset")
sssi<-sssi("Arne, Dorset")
phabitat<-phabitat("Arne, Dorset")
osm<-osm("Arne, Dorset")
dem<-mkdem("Arne, Dorset")
This code has loaded land-cover, sssi boundaries, priority habitat, open street map paths, tracks and roads and the 12m resolution digital elevation model for the 5km grid square that contains R.
Higher resolution DTMs are available by changing the zoom value. The highest resolution provided by elevatr is 3.5 meters. The server contains some Lidar data at higher resolution for chosen sites such as R. The functions given here will work for any site in the South of England.
Use burst =TRUE to plot each land use separately. Useful for exploration.
mapviewOptions(legend=FALSE)
mapview(lcover,zcol="bhab",burst=TRUE, hide = TRUE) %>% extras()
mapview(osm) +mapview(dem)
dem[dem<1]<-NA
sloper<-terrain(dem,"slope","radians")
aspectr<-terrain(dem,"aspect","radians")
hs<-hillShade(sloper,aspectr)
library(tmap)
lcover %>% filter(bhab !="Saltwater") %>%
qtm("bhab") + tmap_style("classic") + tmap_options(legend.outside=TRUE) + tm_scale_bar() + tm_compass(type="arrow") + tm_shape(hs) +
tm_raster(alpha=0.5,palette = gray(0:100 / 100), n = 100, legend.show = FALSE)
These coordinates are for a study point in the New forest
lon<--1.5
lat<-50.86
landcover(lon,lat,dist=2000) ->lcover
sssi(lon,lat,dist=2000) ->sssi
phabitat(lon,lat,dist=2000) -> phabitat
mapview(lcover,zcol="bhab",burst=TRUE, hide = TRUE) %>% extras()
lcover %>%
qtm("bhab") + tmap_style("classic") + tmap_options(legend.outside=TRUE) + tm_scale_bar() + tm_compass(type="arrow")
It’s easy to calculate total areas of each habitat.
lcover$bhab<-as.factor(lcover$bhab)
lcover %>% data.frame() %>% group_by(bhab) %>% summarise(n=n(), area_ha=round(sum(area)/10000,1)) -> areas
library(ggplot2)
areas %>% arrange(area_ha) %>% mutate(bhab = factor(bhab, bhab)) %>%
ggplot(aes(x=bhab,y=area_ha,lab=area_ha)) +geom_bar(stat="identity",fill="grey") + geom_label(aes(x = bhab, y = area_ha, label = paste(area_ha,"ha"))) + coord_flip() + theme_bw()
All the layers can be written to a single geodata package file. The geodata package can then be exported from the server and dropped into a local QGIS project for work offline.
st_write(arne_lcover, dsn="geodata.gpkg", layer="arne_lcover")
st_write(arne_sssi, dsn="geodata.gpkg", layer="arne_sssi")
## Etc, etc ..
The package allows the SAGA functions to be run on a clipped digital terrain model.
corfe_dem<-mkdem(-2.057,50.64,dist=1000,z=13)
sol<-insol(corfe_dem)
twi<-twi(corfe_dem)
mapview(twi)
sloper<-terrain(corfe_dem,"slope","radians")
aspectr<-terrain(corfe_dem,"aspect","radians")
hs<-hillShade(sloper,aspectr)
landcover(-2.057,50.64,dist=1000)->lc
tm_shape(hs) +
tm_raster(palette = gray(0:100 / 100), n = 100, legend.show = FALSE) + tm_shape(lc) + tm_fill("bhab",alpha=0.8) +tmap_style("classic") + tmap_options(legend.outside=TRUE) ->mp
tmap_mode("view")
mp + tm_minimap()
Data from ftp://fuoco.geog.umd.edu/modis/C6/mcd14ml/ have been downloaded and reformatted for Postgis. The current data cover the period between December 2000 and January 2019.
fires<-get_fires(-1.7,50.8,0.4)
library(RColorBrewer)
pal <- brewer.pal(n = 7, name = "OrRd")
fires %>% mapview(zcol="year",col.regions =pal,legend=FALSE) %>% hansen_wms()
library(dplyr)
library(ggplot2)
fires %>% filter(year>2000) %>% group_by(year) %>% summarise(n=n()) %>% ggplot(aes(x=year,y=n)) + geom_line() +geom_point()
fires<-get_fires(-92,16.5,0.4)
lc<-get_lc(-92,16.5,50)
library(RColorBrewer)
pal <- brewer.pal(n = 7, name = "OrRd")
fires %>% mapview(zcol="year",col.regions =pal,legend=FALSE) + mapview(lc$lc,col.regions=lc$pal) -> mp
mp %>% hansen_wms()
fires %>% filter(year>2000) %>% group_by(year) %>% summarise(n=n()) %>% ggplot(aes(x=year,y=n)) + geom_line() +geom_point()
land_cover<-data.frame(id=raster::extract(lc$lc,as(fires,"Spatial")))
land_cover<-base::merge(land_cover,lc$legend)
data.frame(table(land_cover$land_cover)) %>% DT::datatable()
library(dplyr)
library(ggplot2)
fires %>% filter(year>2000) %>% group_by(year) %>% summarise(n=n()) %>% ggplot(aes(x=year,y=n)) + geom_line() +geom_point()