Czy istnieje sposób na wyeliminowanie małych „kawałków” między wielobokami R
? Pożądane rozwiązanie stworzyłoby nowy, w SpatialPolygonsDataFrame
którym wspólne granice między wielokątami są zbieżne. Szczególnie interesuje mnie rozwiązanie, które wykorzystuje R
, a nie ArcMap lub QGIS.
Byłbym również zainteresowany wyjaśnieniem, dlaczego te luki istnieją przede wszystkim.
Oto odtwarzalny przykład danych przestrzennych, z którymi pracuję:
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)
Jak widać na powyższym zrzucie ekranu, między wielobokami grupy bloków spisowych są małe przerwy. Lokalizacja tych przerw jest renderowana w różny sposób w zależności od poziomu powiększenia, ale zawsze są widoczne pewne przerwy.
Czy ktoś może polecić R
funkcję (lub kombinację funkcji) programowego dostosowania wielokątów w celu wyeliminowania tych luk?