- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用爱尔兰共和国各县的 map 执行此操作,找到 here (直接下载)。
我想做的是将每个县的海岸向海延伸 1500 米,但不移动县与县之间的边界。
编辑:我还需要将沿海县的县界向大海延伸,以满足新的、延伸的“海岸线”(根据 mrhellmann 问题添加)
到目前为止我的代码:
加载包和数据
library(tidyverse)
library(sf)
library(ggplot2)
ireland <- st_read("~Census2011_Admin_Counties_generalised20m.shp")
st_crs(ireland) # units are m
缓冲区
ireland_buf <- ireland %>%
st_buffer(1500)
检查边界如何移动
ggplot() +
geom_sf(data = ireland_buf, col = "red", fill = "lightgray") +
geom_sf(data = ireland, col = "black", fill = NA) +
theme_bw()
所以,基本上,红线对应于缓冲 map ,黑线对应于原始 map 。我已经在海岸线上获得了预期的效果,但是县边界会根据县向内或向外移动
最佳答案
使用基础 shapefile,您可以通过组合、缓冲、空间采样和创建 voronoi 多边形来创建一些其他对象。通过连接和交叉这些,您可以到达那里的大部分路径。
以下示例的问题在于它缓冲到北部边界的相邻陆地,一些靠得很近的岛屿可能会导致非常小的问题。
library(sf)
library(ggplot2)
library(dplyr)
library(tmap) # for "MAP_COLORS"
path <- 'Census2011_Admin_Counties_generalised20m.shp'
ireland <- read_sf(path)
base_crs <- st_crs(ireland)
#remove county lines, keeps only an outline of the area
ireland_combined <- st_combine(ireland)
# add buffer, fortunately the base CRS is in meters
ireland_buffered <- st_buffer(ireland_combined, 1500)
# polygon(s) of only the buffer
buffer_only <- st_difference(ireland_buffered, ireland_combined)
# sample points inside the buffer for voronoi polygons
# type can be random, hexagonal, or regular.
# increase size for accuracy, decrease for speed.
sampled_points <- st_sample(buffer_only, size = 5000, type = 'hexagonal')
#Create voronoi polygons from sampled points
voronoi <- sampled_points %>%
st_union() %>%
st_voronoi() %>%
st_cast()
# Crop voronoi polygons to buffer area only
# plot 2 below shows voronoi polygons extend much too far for this case
voronoi_buffer <-
st_intersection(
st_make_valid(voronoi),
buffer_only
) %>%
st_as_sf()
# Join polygons by proximity to counties in base shapefile
voronoi_joined <- st_join(
voronoi_buffer,
ireland,
join = st_nearest_feature
)
# join voronoi polygons by countyname
vj_summarized <- voronoi_joined %>%
group_by(COUNTYNAME) %>%
summarize()
#mapview was having trouble with this county name
vj_summarized$COUNTYNAME[6] <- 'Dun Laoghaire-Rathdown'
ireland$COUNTYNAME[20] <- 'Dun Laoghaire-Rathdown'
#rbind sea buffer & land, then join with group_by & summarize
buffer_and_land <- rbind(ireland %>% select(COUNTYNAME), vj_summarized) %>%
group_by(COUNTYNAME) %>%
summarise()
#plots
p1 <- ggplot() +
geom_sf(data = ireland, fill = NA) +
geom_sf(data = ireland_buffered, fill = NA, alpha = .4, color = 'green') +
ggtitle(label = "Ireland counties & 1500m buffer")
p2 <- ggplot() +
geom_sf(data = voronoi, alpha = .2) +
geom_sf(data = voronoi_buffer, alpha = .2, fill = NA, color = 'turquoise') +
ggtitle(label = 'Voronoi & buffer')
# Counties & buffers joined & colored
p4 <- tm_shape(st_geometry(buffer_and_land)) +
tm_polygons(col = "MAP_COLORS") +
tm_shape(st_geometry(ireland)) +
tm_polygons(border.col = 'black', col = NA, alpha = 0)
p1
绿色区域显示缓冲区和缓冲到边界土地的问题。您可以通过使用整个岛屿的 shapefile 来避免这种情况。
p2
显示完整的 voronoi。绿松石感兴趣的领域。
p4
Buffer 与县相连,由县名填充。县边界以黑色覆盖。
其中一个较困惑区域的特写,增加采样点的数量可能会有所帮助。 由 reprex package 创建于 2021-03-22 (v1.0.0)
关于r - 如何仅向外缓冲一组具有公共(public)边的多边形(从边缘,而不是内部 "frontiers"),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66641381/
我正在使用 MediaPlayer 在我的应用程序中播放在线 mp3 文件中的一些声音。 但是,即使在播放完成后,我也会在控制台中收到一行又一行的回调和缓冲。 10-24 08:08:48.467
我有一个简单的多边形。 dfr p = st_polygon(list(as.matrix(dfr))) > pbuf = st_buffer(p, .4) > plot(pbuf) > plot(
这可能又是一些愚蠢的问题,也许这确实是我所缺少的东西,但我很难让 glMultiDrawArrays 在 OpenGL4 中工作。 我发现了很多这样的解释: for (int i = 0; i #i
这仅仅是根据网络速度调整预缓冲内容量的问题吗?你是否在一开始就为此调整一次,每秒......? 或者它更复杂 - 对您的网络速度记录历史进行采样并取平均值/中值并对其进行调整? 最佳答案 您的第二段总
嗨,我正在使用 FFmpeg Autogen C#。当我使用 mkv 输出作为文件并使用 h264 rtsp 流作为输入时,一切正常。编解码器是 libx264 ffmpeg.avio_open(
我需要多次遍历几个文本文件的行。目前这是通过多个 with open("file.txt") as f: for line in f: # do something 虽然性能还
昨天给同学们写了一个xinetd小练习:做一个反向回显程序。 为了学习新东西,我尝试实现一个 Haskell 解决方案。琐碎的main = forever $ interact reverse不起作用
我正在阅读《实时渲染第三版》中的遮挡剔除部分,但我无法理解它是如何工作的。一些问题: “Z 金字塔”有何贡献?为什么我们需要多种分辨率的 Z 缓冲区?在书中,它的显示如下(左侧): 八叉树结构与用于一
我通过串行端口与设备通信。 我已成功获取 InputStream 并读取设备发送的内容。 但问题是,我根本不知道何时停止阅读并继续执行另一项任务。 这是简化的代码: inputStream = ser
我有以下代码: func (q *Queue) GetStreams(qi *QueueInfo) { channel := make(chan error, len(qi.AudioChun
在我调用 -play 之前,有没有办法让 MPMusicPlayerController 缓冲内容?还是在您设置队列时默认执行此操作? AVAudioPlayer 有 -prepareToPlay 方
我正在编写一个数据库 备份函数,从System.Diagnostics.Process 对象 读取StandardOutput (StreamReader) 属性。我已成功写入普通文件。 //This
我有一个 wpf 应用程序,其中所有 viewModel 都继承自实现 INotifyPropertyChanged 的类 NotifyPropertyChangeClass(见下文)。 我想限制
我需要类似于 withLatestFrom 的东西,对应于下图: ---------A-----------------B-- -1-2-3------4------5-6-7-8---- -----
有没有办法缓冲 OutputStream,在返回之前修改它?这是我的代码片段: public ServletOutputStream getOutputStream() throws IOExcept
目前我们有实现服务器通信协议(protocol)缓冲的需求。如果有人对此有任何意见,他们可以向我提供任何意见吗。 最佳答案 请查看以下 Protocol Buffer 链接。 http://code.
所以我目前正在开发一个 Java 应用程序,该应用程序应该将特定事件记录到数据库中。我希望每分钟最多有 15 到 20 次插入,基本上我想知道我是否应该为每个插入语句建立一个新连接,或者只要应用程序正
请考虑以下代码,包括两个线程 buffering_thread(用一条消息填充缓冲区指针)和 sending_thread(清空缓冲区): #include "msg.cpp" msg * buffe
是否可以在线播放由两个或多个视频文件组成的视频? 由于我原来的帖子不够清楚,这里有扩展的解释和问题。 我的站点托管在 Linux/Apache/PHP 服务器上。我有 FLV/F4V 格式的视频文件。
这是我用于缓冲和转换传入事件的代码: public Publisher> logs(String eventId) { ConnectableObservable connectableObs
我是一名优秀的程序员,十分优秀!