Turf.js多边形合并(union)报non-noded intersection between错误的解决方案

本文主要是介绍Turf.js多边形合并(union)报non-noded intersection between错误的解决方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题

turf.js 是由Mapbox提供的一个控件分析库,非常适合WebGIS开发者使用,里面有丰富的空间分析与计算函数、数据转换函数。

最近在使用turf.js 进行多边形合并时,遇到一个问题如下,意思时多边形的两条线之间没有交点,但是后面跟的坐标全是在同一个多边形里面,自己怎么会跟自己没有交点呢?Polygon的数据格式肯定是没有问题的。

found non-noded intersection between LINESTRING ( 121.54630780220032 49.532520238303505, 121.54630780220032 49.53251675670836 ) and LINESTRING ( 121.54638290405273 49.532485  message: 'found non-noded intersection between LINESTRING ( 121.54630780220032 49.532520238303505, 121.54630780220032 49.53251675670836 ) and LINESTRING ( 121.54638290405273 49.532485
42234107, 121.54629707336426 49.532523719898364 )

在这里插入图片描述

解决方案

最后偶然发现,这个是turf.js版本的问题,出问题的版本是5.1.6 ,后台改为6.4.0 正常运行代码,没有任何问题

测试数据

[{"geometry": {"type": "Polygon","coordinates": [[[121.52645945549011,49.53755088417881],[121.52645945549011,49.53755436541536],[121.52678668498993,49.53835156205173],[121.52767717838287,49.53995287844299],[121.52849793434143,49.54112250247121],[121.52906656265259,49.54094149105984],[121.52907192707062,49.54094149105984],[121.53052568435669,49.54079180804007],[121.5311050415039,49.54068737775475],[121.53159320354462,49.54061427642222],[121.53287529945374,49.54048547857025],[121.53287529945374,49.54048199754254],[121.53288066387177,49.54048199754254],[121.53288066387177,49.54048547857025],[121.53371214866638,49.54055858009545],[121.53392136096954,49.540565542139774],[121.5351551771164,49.54060731438486],[121.5352463722229,49.5405968713269],[121.53635144233704,49.54043674415939],[121.5371721982956,49.540213957662075],[121.53717756271362,49.540213957662075],[121.53793931007385,49.53980667347096],[121.53793931007385,49.539803192394885],[121.53814852237701,49.53971616541196],[121.53815388679504,49.53971616541196],[121.53815388679504,49.53971268432943],[121.53851866722107,49.539709203246616],[121.53881907463074,49.5397057221636],[121.54213428497314,49.53985192743764],[121.54213964939117,49.53985192743764],[121.54344320297241,49.53972660865807],[121.54362559318542,49.53956995973175],[121.54370069503784,49.53932628262595],[121.54381334781647,49.5386335367879],[121.54381334781647,49.53863005562823],[121.5438187122345,49.53863005562823],[121.54425323009491,49.53858828169294],[121.5448272228241,49.53851517722023],[121.54483258724213,49.53851517722023],[121.5452241897583,49.53850473371523],[121.54522955417633,49.53850473371523],[121.54523491859436,49.53850473371523],[121.54546022415161,49.538595244017955],[121.5458357334137,49.53852213955571],[121.54618442058563,49.53837941148083],[121.54618978500366,49.53837941148083],[121.54645264148712,49.53819142752661],[121.54645800590515,49.53819142752661],[121.54680132865906,49.53806610448876],[121.54680669307709,49.53806610448876],[121.5470802783966,49.538003442849316],[121.54708564281464,49.538003442849316],[121.54708564281464,49.53799996164477],[121.54712855815887,49.53787463811588],[121.54712855815887,49.537871156902185],[121.5471339225769,49.537871156902185],[121.5471875667572,49.5377841264785],[121.54719293117523,49.5377841264785],[121.54719293117523,49.53778064525832],[121.54757916927338,49.5376205088624],[121.54842674732208,49.53733156577701],[121.54842674732208,49.5373280845246],[121.54842674732208,49.53730023449643],[121.54842674732208,49.537296753241776],[121.54843211174011,49.5372932719869],[121.5490597486496,49.5371157276588],[121.54906511306763,49.5371157276588],[121.54924213886261,49.536687529860814],[121.54923141002655,49.536022597388666],[121.54913485050201,49.53562920376095],[121.54913485050201,49.535625722387266],[121.54877543449402,49.535002552504835],[121.54877543449402,49.5349990710865],[121.54858231544495,49.53467181665809],[121.54823362827301,49.53401381973916],[121.54823362827301,49.534010338250425],[121.54823362827301,49.53401381973916],[121.54762744903564,49.53433063417626],[121.54762208461761,49.53433063417626],[121.54761672019958,49.53433063417626],[121.54732167720795,49.53412174576704],[121.54732167720795,49.53411826428601],[121.54717147350311,49.533933745435405],[121.54717147350311,49.53393026394096],[121.54716610908508,49.53393026394096],[121.5470963716507,49.53378404095045],[121.54705345630646,49.53373529985643],[121.54705345630646,49.53373181834786],[121.54695153236389,49.53346374144266],[121.54690325260162,49.53334188781787],[121.54681742191315,49.533115587423055],[121.54676377773285,49.533028548530666],[121.54668867588043,49.53290321225336],[121.54668867588043,49.53289973068547],[121.5466296672821,49.532791801959235],[121.54651701450348,49.5326107596897],[121.54651701450348,49.53260727810104],[121.54630780220032,49.532527201493],[121.54630780220032,49.532523719898364],[121.54630780220032,49.532520238303505],[121.54630780220032,49.53251675670836],[121.54638290405273,49.53248542234107],[121.54629707336426,49.532523719898364],[121.54195189476013,49.534553447495426],[121.53644263744354,49.53208851861672],[121.53643727302551,49.53208851861672],[121.53617441654205,49.53220689374896],[121.53598666191101,49.532297415715476],[121.52946352958679,49.5354377278407],[121.52766644954681,49.5368093751446],[121.52755916118622,49.53689292602073],[121.52645945549011,49.53755088417881],[121.52645945549011,49.53755088417881]]]},"type": "Feature","properties": {"zwdm": "54","zwmc": "旱地小麦"},"tile": {"z": 14,"x": 13723,"y": 5589}},{"geometry": {"type": "Polygon","coordinates": [[[121.54676377773285,49.53230437893674],[121.54676914215088,49.53230437893674],[121.54662430286407,49.53213377973054],[121.54662430286407,49.53213029810789],[121.5463238954544,49.531893547185746],[121.5463238954544,49.53189006554595],[121.54620587825775,49.53098134908848],[121.5463238954544,49.531893547185746],[121.54661893844604,49.53213726135294],[121.54676377773285,49.53230437893674]]]},"type": "Feature","properties": {"zwdm": "54","zwmc": "旱地小麦"},"tile": {"z": 14,"x": 13723,"y": 5589}}
]

测试代码

let fs = require('fs');
let  turf =require ('@turf/turf');let rawData = fs.readFileSync('data.json');
let polygons = JSON.parse(rawData);
let polygon=polygons[0]
for (let i = 1; i < polygons.length; i++) {console.log("循环"+i)polygon=turf.union(polygon,polygons[i])
}
console.log(polygon)

这篇关于Turf.js多边形合并(union)报non-noded intersection between错误的解决方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/284897

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

C#文件复制异常:"未能找到文件"的解决方案与预防措施

《C#文件复制异常:未能找到文件的解决方案与预防措施》在C#开发中,文件操作是基础中的基础,但有时最基础的File.Copy()方法也会抛出令人困惑的异常,当targetFilePath设置为D:2... 目录一个看似简单的文件操作问题问题重现与错误分析错误代码示例错误信息根本原因分析全面解决方案1. 确保

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

SpringBoot3匹配Mybatis3的错误与解决方案

《SpringBoot3匹配Mybatis3的错误与解决方案》文章指出SpringBoot3与MyBatis3兼容性问题,因未更新MyBatis-Plus依赖至SpringBoot3专用坐标,导致类冲... 目录SpringBoot3匹配MyBATis3的错误与解决mybatis在SpringBoot3如果