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

相关文章

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

SpringSecurity显示用户账号已被锁定的原因及解决方案

《SpringSecurity显示用户账号已被锁定的原因及解决方案》SpringSecurity中用户账号被锁定问题源于UserDetails接口方法返回值错误,解决方案是修正isAccountNon... 目录SpringSecurity显示用户账号已被锁定的解决方案1.问题出现前的工作2.问题出现原因各

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Java死锁问题解决方案及示例详解

《Java死锁问题解决方案及示例详解》死锁是指两个或多个线程因争夺资源而相互等待,导致所有线程都无法继续执行的一种状态,本文给大家详细介绍了Java死锁问题解决方案详解及实践样例,需要的朋友可以参考下... 目录1、简述死锁的四个必要条件:2、死锁示例代码3、如何检测死锁?3.1 使用 jstack3.2