i'm trying make flow map in leaflet r map movement of 1 area (polygon) another.
library(sp) library(rgdal) library(tidyverse) library(leaflet)
i'm using this shapefile of local authorities (las) in england polygons, , i'm deriving lines coordinates those.
map <- readogr(dsn = "map", layer = "lea_boundaries") map <- map[!is.na(map$lad16cd),]
i'm wanting create lines centre of 1 polygon used origin , destination polygons latitude , longitude(s) derive beginning , end point of line. did through sampling la names map's data slot, sampling them again create starting , ending las, merging coordinates starting la on, followed coordinates ending la, follows:
startingla <- sample(map@data$lad16nm, 100000, replace = true) nextla <- sample(startingla, 100000, replace = true) movement <- data.frame(startingla, nextla) ld <- merge(movement, map@data[,c("lad16nm", "long", "lat")], by.x = "startingla", by.y = "lad16nm") %>% merge(map@data[,c("lad16nm", "long", "lat")], by.x = "nextla", by.y = "lad16nm", suffixes = c("",".y"))
after have tried 2 separate ways create spatial lines, 1 custom function add bezier line, , other gcintermediate()
, i'll use here it's more accessible , rules out programming errors in function.
flow <- gcintermediate(ld[,c("long", "lat")], ld[,c("long.y", "lat.y")], sp = true, addstartend = true)
and map itself; we'll add popup labels polygons can see las which.
leaflet() %>% addprovidertiles(providers$cartodb.positronnolabels) %>% addpolygons(data = map, weight = 1, col = "#000000", fillopacity = 0, popup = map@data$lad16nm) %>% addpolylines(data = flow)
and we'll take @ data used create line.
ld
on map have blue line joining 1 polygon next. startingla
in ld
, have 'east sussex', , nextla
'hillingdon', line points to/from birmingham , wandsworth.
this true using custom function fit bezier lines, makes me think happened before, data correct right until lines made spatiallines, , after goes haywire.
does have insight i'm going wrong here?
thank you.
the co-ordinates in map@data object not appropriate use case.
greenwich, instance, has co-ordinates -1.108940, 53.52697
, firmly located in doncaster. perhaps @ earlier processing step co-ordinates , ids got unmatched somehow?
in case, it's quickest/easiest re-calculate co-ordinates using using rgeos::gcentroid
on map object , replace offending columns in data file:
rgeos::gcentroid(map,byid = t)
Comments
Post a Comment