本文主要是介绍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错误的解决方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!