多边形 shapefile 不在传单 R 中呈现
Polygon shapefile doesn't render in leaflet R
我正在尝试使用 R 中的传单包向传单地图添加一些边界。我在 RStudio 中写道:
library(rgdal)
fw<-readOGR("/local/path/to/FWC_UT_MASTER_0623_2016.shp",verbose=FALSE)`
为了将多边形添加到传单中,我写道:
library(leaflet)
fw %>%
leaflet() %>%
addTiles() %>%
addPolygons(stroke = FALSE, fillOpacity = 0.5, smoothFactor = 0.5)
看起来很直观。我想不通为什么这些小家伙不渲染。我认为 SpatialPolygonsDataFrame 需要在 WGS84 中。原文件没有。
..@ proj4string:Formal class 'CRS' [package "sp"] with 1 slot
.. .. ..@ projargs: chr "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0 +k=1.0 +units=m +nadgrids=@null +no_defs"
所以我尝试重新投影原始 shapefile
fw.proj<-spTransform(fw, CRS("+init=epsg:4326"))
然而,
fw.proj %>%
leaflet() %>%
addTiles() %>%
addPolygons(stroke = FALSE, fillOpacity = 0.5, smoothFactor = 0.5)
也呈现空白地图。我在这里保存了原始形状文件:
https://github.com/uky994/firewise
如有任何帮助,我们将不胜感激。
我很惊讶你的 readOGR
没有发出任何警告,因为 layer
参数是必需的。
但是你是对的,你需要将形状转换为 lat/lon,因为这是传单所期望的。
这是一些工作代码;您必须确定要使用的确切 CRS
。
library(leaflet)
library(rgdal)
setwd("~/Downloads/firewise-master/")
fw <- readOGR(dsn = ".",
layer = "FWC_UT_MASTER_0623_2016",
verbose = FALSE)
fw_latlon <- spTransform(fw, CRS("+proj=longlat +datum=WGS84"))
leaflet() %>%
addTiles() %>%
addPolygons(data = fw_latlon)
我正在尝试使用 R 中的传单包向传单地图添加一些边界。我在 RStudio 中写道:
library(rgdal)
fw<-readOGR("/local/path/to/FWC_UT_MASTER_0623_2016.shp",verbose=FALSE)`
为了将多边形添加到传单中,我写道:
library(leaflet)
fw %>%
leaflet() %>%
addTiles() %>%
addPolygons(stroke = FALSE, fillOpacity = 0.5, smoothFactor = 0.5)
看起来很直观。我想不通为什么这些小家伙不渲染。我认为 SpatialPolygonsDataFrame 需要在 WGS84 中。原文件没有。
..@ proj4string:Formal class 'CRS' [package "sp"] with 1 slot
.. .. ..@ projargs: chr "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0 +k=1.0 +units=m +nadgrids=@null +no_defs"
所以我尝试重新投影原始 shapefile
fw.proj<-spTransform(fw, CRS("+init=epsg:4326"))
然而,
fw.proj %>%
leaflet() %>%
addTiles() %>%
addPolygons(stroke = FALSE, fillOpacity = 0.5, smoothFactor = 0.5)
也呈现空白地图。我在这里保存了原始形状文件: https://github.com/uky994/firewise
如有任何帮助,我们将不胜感激。
我很惊讶你的 readOGR
没有发出任何警告,因为 layer
参数是必需的。
但是你是对的,你需要将形状转换为 lat/lon,因为这是传单所期望的。
这是一些工作代码;您必须确定要使用的确切 CRS
。
library(leaflet)
library(rgdal)
setwd("~/Downloads/firewise-master/")
fw <- readOGR(dsn = ".",
layer = "FWC_UT_MASTER_0623_2016",
verbose = FALSE)
fw_latlon <- spTransform(fw, CRS("+proj=longlat +datum=WGS84"))
leaflet() %>%
addTiles() %>%
addPolygons(data = fw_latlon)