У меня есть один вопрос, касающийся топологии и отношений между полигонами в открытых слоях.
Ситуация такова:
Использование https://turfjs.org/ I 'Я использую два метода, чтобы проверить, перекрываются ли многоугольники, https://turfjs.org/docs/#booleanOverlap и https://turfjs.org/docs/#booleanWithin, но я получаю какое-то странное взаимодействие.
Как видите, в синем прямоугольнике многоугольник привязан к красному многоугольнику, и это нормально, но проблема в том, что для них многоугольники в желтом прямоугольнике, я получаю true и автоматически перекрывающийся красный стиль .Многоугольники в синем и многоугольники в желтом прямоугольнике привязываются только к границе красного многоугольника.
Итак, мой вопрос таков;Можно ли как-то игнорировать границу ограничительного многоугольника (красный) или я должен найти другой подход.
Пример кода, который я проверяю, перекрывают ли многоугольники:
vectorLayer.getSource().on(OpenLayersEvents.AddFeature, (evt: any) => {
let feature = evt.feature;
// clip area function with return geometry value
let polygon = clipFieldArea(feature, this.myRestrictionVectorLayer);
let isFeatureOverlappingFlag = false;
//red polygons
if (this.restrictiveLayer.getSource().getFeatures().length > 0) {
isFeatureOverlappingFlag = arePolygonsOverlapping(feature, this.restrictiveLayer);
}
// checks if features are overlapping then set new style
feature.getGeometry().setCoordinates(polygon.getCoordinates());
if (isFeatureOverlappingFlag) {
feature.setStyle(this.featureOverlappingStyle);
} else {
feature.setStyle(this.fieldStyle);
}....
И здесьis arePolygonsOverlapping () метод, который проверяет топологию
let geojsonFormat = new GeoJSON();
let areOverlapping: boolean = false;
let flagCheck: boolean = false;
let restrictionFeatures = restrictionLayer.getSource().getFeatures();
// create GeoJSON object and transform it in WGS84 for intersect method
let firstGeometryObject = geojsonFormat.writeFeatureObject(feature, { dataProjection: 'EPSG:4326', featureProjection: 'EPSG:3857' });
for (let featureRestrict of restrictionFeatures) {
let secondGeometryObject = geojsonFormat.writeFeatureObject(featureRestrict,
{ dataProjection: 'EPSG:4326', featureProjection: 'EPSG:3857' });
areOverlapping = booleanOverlap(firstGeometryObject as unknown as TurfPolygon, secondGeometryObject as unknown as TurfPolygon);
if (areOverlapping) {
flagCheck = true;
break;
}
}
return flagCheck;