как объединить полигоны с nettopologysuite?

Мне нужно объединить набор полигонов, создав новый полигон.
Иногда бывает так, что у меня есть небольшие дыры между полигонами, поэтому при попытке их объединить я получаю сообщение об ошибке.
Как это обнаружить и решить?

Обновление с некоторыми примерами ошибок

side location conflict [ (12.235768128349596, 44.387249570104892, NaN) ]
   at NetTopologySuite.Operation.Overlay.Snap.SnapIfNeededOverlayOp.GetResultGeometry(SpatialFunction opCode)
   at NetTopologySuite.Geometries.Geometry.Union(IGeometry other)
   at NetTopologySuite.Operation.Union.CascadedPolygonUnion.UnionOptimized(IGeometry g0, IGeometry g1)
   at NetTopologySuite.Operation.Union.CascadedPolygonUnion.Union()
   at NetTopologySuite.Operation.Union.UnaryUnionOp.Union()

or

found non-noded intersection between LINESTRING(12.448591764796777 41.972860890341124, 12.448731325430401 41.972841479998927) and LINESTRING(12.449 41.973, 12.448695198462875 41.972831837041554) [ (12.448716431340822, 41.972843551495508, NaN) ]
   at NetTopologySuite.Noding.FastNodingValidator.CheckValid()
   at NetTopologySuite.Operation.Overlay.OverlayOp.ComputeOverlay(SpatialFunction opCode)
   at NetTopologySuite.Operation.Overlay.OverlayOp.Overlay(IGeometry geom0, IGeometry geom1, SpatialFunction opCode)

or

Invalid number of points in LineString (found 1 - must be 0 or >= 2)
   at NetTopologySuite.Geometries.LineString..ctor(ICoordinateSequence points, IGeometryFactory factory)
   at NetTopologySuite.Geometries.GeometryFactory.CreatePolygon(ICoordinateSequence coordinates)

person Luca Morelli    schedule 14.04.2018    source источник
comment
Какую ошибку вы получаете?   -  person tval    schedule 23.04.2018


Ответы (1)


Большинство ошибок, которые вы получаете, связаны с недопустимой геометрией. Вы можете проверить правильность геометрии с помощью geometry.IsValid или с помощью класса NetTopologySuite.Operation.Valid.IsValidOp. Чтобы исправить эти ошибки, вы обычно можете обойтись без буфера смещения 0: geometry = geometry.Buffer(0).

person tval    schedule 21.11.2018