我正在尝试从空间点数据框周围的缓冲区内的几个USFWS国家湿地清单形状文件中提取成比例的土地覆盖值。在QGIS中绘制时,shapefile包含许多代表湿地的多边形,每个多边形具有不同的分类。我的目标是将此shapefile转换为正式类栅格图层,并使用raster :: extract()提取这些值。
我已经与library(FedData)和get_nlcd()一起成功地计算了缓冲点的比例土地覆盖率;但是,在尝试使用ESRI .shp文件时,我已经完全失败了。每次我尝试遵循其他人关于如何栅格化shapefile的说明时,提取的数据框都充满了空值。我不确定是否缺少步骤,或者仅仅是我正在使用的shapefile的本质,但我希望有人可以提供解决方案。
library(sp)
library(raster)
library(rgdal)
#making a spatial data frame from coordinates
coords = cbind(SeniorThesisSamples$Longitude, SeniorThesisSamples$Latitude)
points_spdf = SpatialPoints(coords, proj4string = crs("+proj=aea +ellps=GRS80 +datum=NAD83"))
#Extending spatial extent to make sure all points can have an X km buffer -----------------
r = raster(ncol = 3, nrow = 3)
extent(r) = extent(points_spdf) * 1.5
crs(r) = crs(points_spdf)
#read in National Wetlands Inventory ESRI shapefile
RI.nwi <- raster::shapefile("~/Documents/Senior Thesis Stuff/NWI Shapefiles/RI_shapefile_wetlands/RI_Wetlands.shp")
# Transform .shp to match CRS of the spdf
RI.nwi <- spTransform(RI.nwi, crs(r))
#creating an empty raster with the extent of my spdf and setting resolution to 100m
empty.raster <- raster(extent(r), res = 100)
crs(empty.raster) = crs(r)
RI.nwi.raster <- rasterize(RI.nwi, empty.raster)
#extracting raster values at a set buffer distance and put into data frame
wetlands1km <- raster::extract(x = RI.nwi.raster, y = points_spdf, buffer = 1000, df = T)
#this part I know works because I have used it effectively to extract NLCD data
detach(package:plyr) # this is so the n() works
prop.wetlands1km <- as.data.frame(wetlands1km) %>%
setNames(c("ID", "class")) %>%
group_by(ID, class) %>%
summarise(n = n()) %>%
mutate(pland = n / sum(n)) %>%
ungroup() %>%
dplyr::select(ID, class, pland) %>% # keep only these vars
tidyr::complete(ID, nesting(class), fill = list(pland = 0)) %>% # Fill in implicit landcover 0s
tidyr::spread(class, pland)
代码运行了,但是我留下了一个空的数据框,该框(根据以前的NLCD数据经验)应该具有土地覆盖分类,如每个单元格中的列标题和百分比值。
我从此链接(https://www.fws.gov/wetlands/Data/State-Downloads.html)下载了多个状态级别的shapefile供参考。我的spdf中的要点不仅限于罗德岛,但由于它是如此之小,因此它是使用最简单的shapefile。奖励指向任何可以帮助我找出将这些状态shapefile中的几个合并在一起的方法的人(ME,NH,MA,RI,CT,NY,NJ,DE,MD,VA),以便我可以在一走!任何帮助深表感谢!
编辑:随附一些要求的示例代码
> dput(head(SeniorThesisSamples))
structure(list(SiteName = c("Quonochontaug", "Quonochontaug",
"Quonochontaug", "Quonochontaug"), State = c("RI", "RI", "RI",
"RI"), SiteID = c("220450_p3", "220450_p3", "220450_p3", "220450_p3"
), Latitude = c(41.3335569999999, 41.3335569999999, 41.3335569999999,
41.3335569999999), Longitude = c(-71.7167649999999, -71.7167649999999,
-71.7167649999999, -71.7167649999999), Species = c("SALS", "SALS",
"SALS", "SALS"), BandNum = c(278184716, 278184718, 278184721,
278184715), HgConcentration = c(0.422, 0.32, 0.374, 0.309), Month = c(7,
7, 7, 7), Day = c(29, 29, 29, 29), Year = c(2018, 2018, 2018,
2018), Date = structure(c(17741, 17741, 17741, 17741), class = "Date")), class = c("tbl_df",
"tbl", "data.frame"), row.names = c(NA, -4L))
> RI.nwi
class : SpatialPolygonsDataFrame
features : 55398
extent : 1960230, 2051242, 2271966, 2388062 (xmin, xmax, ymin, ymax)
coord. ref. : +proj=aea +lat_1=29.5 +lat_2=45.5 +lat_0=23 +lon_0=-96 +x_0=0 +y_0=0 +datum=NAD83 +units=m +no_defs +ellps=GRS80 +towgs84=0,0,0
variables : 5
names : ATTRIBUTE, WETLAND_TY, ACRES, Shape_Leng, Shape_Area
min values : E1AB1L, Estuarine and Marine Deepwater, 1.000117e+00, 1.000005e+02, 1.000025e+03
max values : R5UBH, Riverine, 9.998890e-03, 9.999467e+01, 9.999969e+02
> head(RI.nwi)
ATTRIBUTE WETLAND_TY ACRES Shape_Leng Shape_Area
0 E2ABM Estuarine and Marine Wetland 0.5421139 192.1974 2193.857
1 E2ABM Estuarine and Marine Wetland 0.4598518 197.5223 1860.954
2 E2ABM Estuarine and Marine Wetland 2.9291088 453.6280 11853.683
3 E2AB3M Estuarine and Marine Wetland 2.0402979 514.5920 8256.793
4 E1AB1L Estuarine and Marine Deepwater 6.3219543 780.8088 25584.041
5 E1AB1L Estuarine and Marine Deepwater 2.0643299 361.9401 8354.047