我希望您对第 89 页上的 stplanr 包 ( https://cran.r-project.org/web/packages/stplanr/stplanr.pdf ) 的 route_local 功能提供帮助。
您可能会意识到从示例函数生成了一个地图,显示了两点之间的路径(我留下了代码和下面生成的图像)。我想做同样的事情。就我而言,它显示了考虑我的道路的两点之间的路径。两者都是 shapefile 文件。我设法生成要显示的道路(下面的代码),但我想显示这些道路的任意两点之间的路线。有人能帮我吗??我将它留在了以下站点https://github.com/JovaniSouza/JovaniSouza5/blob/master/Example.zip以下载 shapefile。
library(geosphere)
library(sf)
library(stplanr)
roads<-st_read("C:/Users/Jose/Downloads/Example/Roads/Roads.shp")
p <- SpatialLinesNetwork(roads, uselonglat = FALSE, tolerance = 0)
plot(p)
代码生成的地图
例子
from <- c(-1.535181, 53.82534)
to <- c(-1.52446, 53.80949)
sln <- SpatialLinesNetwork(route_network_sf)
r <- route_local(sln, from, to)
plot(sln)
plot(r$geometry, add = TRUE, col = "red", lwd = 5)
plot(cents[c(3, 4), ], add = TRUE)
r2 <- route_local(sln = sln, cents_sf[3, ], cents_sf[4, ])
plot(r2$geometry, add = TRUE, col = "blue", lwd = 3)