R语言terra包,erase删除对象的部分

image.png
# Wed Dec 16 13:37:54 2020 -

# 字符编码:UTF-8
# R 版本:R x64 4.0.3 for window 10
# cgh163email@163.com
# 个人笔记不负责任
# —— 拎了个梨🍐
.rs.restartR()
require(terra)
# erase删除SpatialPolygons*或SpatialLines*对象的部分。
rm(list=ls());gc()

require(rgeos)

p <- shapefile(system.file("external/lux.shp", package="raster"))
b <- as(extent(6, 6.4, 49.75, 50), 'SpatialPolygons')
crs(b) <- crs(p)
e <- erase(p, b)
plot(e)

r <- raster(extent(p) +c(-.1,.1,-.1,.1), crs=crs(p))
start <- xyFromCell(r, cellFromCol(r, 1))
end <- xyFromCell(r, cellFromCol(r, ncol(r)))
lines <- do.call(spLines, lapply(1:10, function(i)rbind(start[i,], end[i,])))
crs(lines) <- crs(p)

e2 <- erase(lines, p)
plot(p)
lines(lines, col='blue', lwd=4, lty=3)
lines(e2, col='red', lwd=2)
# Wed Dec 16 13:39:23 2020 --end
dev.copy(png,'erase切走,切割.jpg');dev.off()


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。