- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我想在 javascript 中合并相邻的多边形,这就是我的代码实际拥有的内容:
我想删除内部笔划但保留边框笔划。
所以我想从这里开始:
对此:
我想保留巴黎的洞 - 我可以定义必须对哪些多边形进行分组,但我无法将它们与此代码合并:
var map = L.map('map', {
center: [46.52863469527167, 2.43896484375],
zoom: 6,
maxZoom: 18,
minZoom: 7
});
$http.get("france.json").then(function (response) {
$scope.communeFr = response.data.features
$http.get(apiult).then(function (response) {
$scope.showCommune = response.data.Liste
$scope.communeFr.map(x => {
x.show = false
for (let i = 0; i < $scope.showCommune .length; i++) {
if (x.properties.insee == $scope.showCommune[i].insee) {
x.show = true
return
}
}
})
L.geoJson($scope.communeFr, {
filter: function (feature, latlng) {
return feature.show
}
}).addTo(map);
});
});
更新 - 我尝试使用 turf.union
但输出不正确:
这是我的代码
var GroupPolygons = [];
$scope.communeFr.map(x => {
x.show = false
for (let i = 0; i < $scope.showCommune .length; i++) {
if (x.properties.insee == $scope.showCommune[i].insee) {
GroupPolygons.push(x)
}
}
})
var union = turf.union(...GroupPolygons)
L.geoJson(union).addTo(map)
最佳答案
关于 union
的 turf 文档中关于可以作为参数传递的多边形数量似乎存在歧义。参见 here和 here .看起来它必须一次是两个 - 所以这会起作用:
// feature ids to remove e.g. central Paris
var removeIds = [868, 869, 870, 871, 872, 873, 874, 875, 876, 877, 878, 879, 880, 881, 882, 883, 884, 885, 886, 887];
// filter features to remove central Paris
var hole = fc.features.filter(f => !removeIds.includes(f.properties.ID_APUR))
// do the union over each feature
var union = hole[0];
for (let i=1; i<hole.length; i++) {
union = turf.union(union, hole[i]);
}
我选择了巴黎市中心的一堆要删除,然后从剩余的功能中我从功能 0 开始,然后 turf.join
所有其他功能(从索引 1 开始)到这个。看起来效率低下但有效...
这里的小陷阱:
// new Feature collection with unioned features
var fc2 = {
"type": "FeatureCollection",
"features": [union] // note features has to be an array
}
请记住将 FeatureCollection 传递给 L.geoJson
并且 features
属性需要是一个数组 - 即使在这种情况下它包含合并的单个特征地区。
工作示例:
// center map on Paris
var map = L.map('mapid', {
center: [48.856, 2.352],
zoom: 9,
maxZoom: 18,
minZoom: 1
});
// add tiles
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
attribution: '© <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors'
}).addTo(map);
var url = "https://gist.githubusercontent.com/robinmackenzie/937e5bd42a0412c21281f69b8f0c8614/raw/fbed7c2783366463a250e4bb0ebcf3c5f6d54dfe/greaterParis.geo.json";
// get greater Paris definition
fetch(url)
.then(response => response.json())
.then(fc => {
// feature ids to remove e.g. central Paris
var removeIds = [868, 869, 870, 871, 872, 873, 874, 875, 876, 877, 878, 879, 880, 881, 882, 883, 884, 885, 886, 887];
// filter features to remove central Paris
var hole = fc.features.filter(f => !removeIds.includes(f.properties.ID_APUR))
// do the union over each feature
var union = hole[0];
for (let i=1; i<hole.length; i++) {
union = turf.union(union, hole[i]);
}
// new Feature collection with unioned features
var fc2 = {
"type": "FeatureCollection",
"features": [union] // note features has to be an array
}
// add to map
L.geoJson(fc2).addTo(map);
});
#mapid { height: 200px; }
<link rel="stylesheet" href="https://unpkg.com/leaflet@1.7.1/dist/leaflet.css"/>
<script src="https://unpkg.com/leaflet@1.7.1/dist/leaflet.js"></script>
<script src='https://unpkg.com/@turf/turf@6.3.0/turf.min.js'></script>
<div id="mapid"></div>
关于leaflet - Geojson/草坪 : merge multiple polygons to one polygon keeping hole,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68005988/
HTTP Keep Alive是如何实现的?它在内部使用 TCP Keep Alive 吗?如果不是,服务器如何检测客户端是死是活? 最佳答案 我知道这是一个老问题,但仍然: HTTP Keep-Al
我需要在每次连接到我的网站和获取数据时节省时间。 这是我的工作。 ESP 模块连接到家庭 WiFi。 AT+CIPMUX=0 --> 响应OK AT+CWMODE=1 --> 响应OK AT+CIPS
我尝试添加新标题的方法: request.Headers.GetType().InvokeMember("ChangeInternal", BindingFlags.Instance | Bi
我听说 Connection:Keep-Alive header 会告诉服务器将客户端和服务器之间的连接保持一段时间,以防止每次客户端向服务器建立请求时都要付出努力。我尝试将其添加到请求的 heade
我遇到了一种我一直在研究的垂直 slider 的问题。问题是,当我更改显示分辨率时,右侧缩略图的高度与左侧图片的高度不同。很难用文字来解释,所以我做了一个代码笔来帮助我更好地理解它。是这样的: htt
我在 apache 服务器上使用 http keep-alive, 比方说我要求它保持连接打开最多 2 分钟... 现在,如果连接被创建并闲置一分钟,php 持有的资源, 像 mysql 连接、文件句
我看到一些 proguard 配置有这样的行: -keep class a.b.** {} 我对 {} 的使用感到困惑。这个我知道 -keep class a.b.**表示保留包a.b及其子包中的所有
keep-alive的设计初衷 有些业务场景需要根据不同的判断条件,动态地在多个组件之间切换。频繁的组件切换会导致组件反复渲染,如果组件包含有大量的逻辑和dom节点,极易造成性能问题。其次,切换后组件
我知道有一个 DELETE FROM WHERE mysql 中的命令,如果表达式有效,则从指定表中删除元组。 然而,在取keep only表达式的补码时总是使用德摩根定律成为一种负担。 我的问题
我已经尝试了 2 个小时让我的页脚留在底部。 我一直在尝试“Matthew James Taylors”技术,但没有成功。 有人看到我遗漏了什么或做错了什么吗? 这是一个活生生的例子:http://g
是否有工具或流程可以让您的函数、选择器和“for 循环”方便且可搜索以供将来使用?我什么也没用,偶尔会重新学习我已经解决的类似问题。 背景:我正在学习 jQuery 和 Javascript,并开始看
所以根据haproxy作者的说法,谁知道关于http的一两件事: Keep-alive was invented to reduce CPU usage on servers when CPUs we
我正在尝试确定客户端是否已关闭来自 netty 的套接字连接。有办法做到这一点吗? 最佳答案 在客户端通过 close() 关闭套接字并且 TCP 关闭握手已成功完成的通常情况下,channelIna
我已经在本地主题分支 上工作了一段时间,偶尔只做一些更改。 与此同时,master 分支有了显着的发展。我决定将 master 分支中的新更改 merge 到我的本地主题分支中(与我从中分支出来的
1、作用 主要用于保留组件状态或避免重新渲染。 2、用法 <keep-alive> 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。 <ke
HTTP 长连接,也称为 HTTP 持久连接(HTTP Persistent Connection)或 HTTP 连接重用,是一种在 HTTP 协议中实现的机制。 在传统的 HTTP
我需要合并一些 dll,文件名和程序集名称都需要与我的主 dll (mydll.dll) 相同。我还需要 pdb 文件。我如何完成这项工作? 以下是我尝试过的一些方法: 只需使用 ILMerge my
我有一个在其他字段中具有FileField的表单。假设用户选择了一个文件,然后按Submit(提交),另一个字段触发了ValidationError。 当我取回表单时,页面上出现错误,用户为文件字段选
我正在学习 akka 流,在代码中遇到了 Keep.left 和 Keep.right: implicit val system = ActorSystem("KafkaProducer") impl
我正在一个项目中,有人检查了一些文件夹和文件,这些文件夹和文件不应该位于存储库中,并且应该位于我们本地,我尝试通过以下命令删除它们,这给了我这个错误 svn delete filename --kee
我是一名优秀的程序员,十分优秀!