我用SpatialPolygon
这种方式创建
#make spatial points
#assign Original CRS WGS84 EPSG:4326 (DATUM --> on sphere)
cornersEPSG4326 <- SpatialPoints(coords=cbind(x,y), proj4string = CRS("+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs"))
#transform to EPSG3857 (Web Mercator PROJECTION)
cornersEPSG3857 <- spTransform(cornersEPSG4326, CRS("+init=epsg:3857"))
#create Polygon
bbox <- Polygon(cornersEPSG3857)
#create PolygonsObject
myPolygon <- Polygons(list(bbox),1)
#create SpatialPolygonsObject
finalPolygon <- SpatialPolygons(list(myPolygon))
#say that polygon is EPSG3857 (Web Mercator PROJECTION)
proj4string(finalPolygon) <- CRS("+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 +wktext +no_defs")
这样SpatialPoints
:
#make spatial points
#assign Original CRS WGS84 EPSG:4326 (DATUM --> on sphere)
spatialEPSG4326 <- SpatialPoints(coords=cbind(x,y), proj4string = CRS("+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs"))
#transform to EPSG3857 (Web Mercator PROJECTION)
spatialEPSG3857 <- spTransform(spatialEPSG4326, CRS("+init=epsg:3857"))
allPointsSpatial <- spatialEPSG3857
我想运行这个over()
功能:
pointsInPolygon <- over(allPointsSpatial, finalPolygon)
print(length(pointsInPolygon))
但是,我收到以下错误消息:
警告:观察者中未处理的错误:相同的CRS(x,y)不是TRUE
当我将此行添加到我的SpatialPoints
#say that points is EPSG3857 (Web Mercator PROJECTION)
proj4string(spatialEPSG3857) <- CRS("+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 +wktext +no_defs")
我收到以下错误:
proj4string<-
( , value = )中的警告*tmp*
:新的 CRS 已分配给具有现有 CRS 的对象:+init=epsg:3857 +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 不重新投影。对于重投影,使用包 rgdal 中的函数 spTransform
- 为什么会出现
CRS are not identical
错误?它们应该是相同的,因为proj4string
和spTransform
是相同的代码?! - 为什么当我尝试将 分配
proj4string
给 SpatialPoints 时会出现此错误,但在 Polygon 上执行时不会出现此错误?