Esiste un modo per eliminare i piccoli "frammenti" tra i poligoni R
? La soluzione desiderata creerebbe una nuova in SpatialPolygonsDataFrame
cui i confini condivisi tra poligoni sono coincidenti. Sono particolarmente interessato a una soluzione che utilizza R
, piuttosto che ArcMap o QGIS.
Sarei anche interessato a sentire una spiegazione sul perché queste lacune esistano in primo luogo.
Ecco un esempio riproducibile dei dati spaziali con cui sto lavorando:
library(rgdal)
library(sp)
library(tigris)
library(magrittr)
library(leaflet)
library(gplots)
# This project will use WGS 84 projected coordinate system
crs_proj <- CRS("+init=epsg:4326")
# These are the FIPS codes of the specific block groups in my study area
sel <- c("530330079005", "530330079001", "530330079004",
"530330085002", "530330085003", "530330086003",
"530330087003", "530330085001", "530330090001",
"530330091001", "530330091002", "530330092001",
"530330092002", "530330086001", "530330090002",
"530330086002", "530330079003", "530330079002",
"530330087002", "530330087001")
# Create polygons
polygons <- tigris::block_groups(state = "WA",county = "King") %>%
.[.@data$GEOID %in% sel,] %>%
spTransform(CRSobj = crs_proj)
# Map the result
leaflet() %>%
addProviderTiles("CartoDB.Positron") %>%
addPolygons(data = polygons,
stroke = F,
fillColor = col2hex("red"), fillOpacity = 1)
Come puoi vedere nello screenshot sopra, ci sono piccoli spazi tra i poligoni del gruppo di blocchi di censimento. La posizione di questi spazi vuoti viene visualizzata in modo diverso a seconda del livello di zoom, ma sono sempre visibili alcuni spazi vuoti.
Qualcuno può raccomandare una R
funzione (o una combinazione di funzioni) per regolare programmaticamente i poligoni per eliminare questi vuoti?