bg_overlay_polygon - ObjectVision/GeoDMS GitHub Wiki
Geometric functions bg_overlay_polygon
- bg_overlay_polygon (first_polygon_data_item, second_polygon_data_item)
bg_overlay_polygon(first_polygon_data_item, second_polygon_data_item) results in a new uint32 domain unit with an entry for each intersecting part of the first_polygon_data_item and the second_polygon_data_item.
The function generates three subitems for the new domain unit:
- geometry: the geometry of the resulting polygons (in the figure the yellow polygons). This attribute has the same values unit as the first_polygon_data_item and second_polygon_data_item attributes.
- first_rel: a relation for the new domain unit towards the domain of the first_polygon_data_item.
- second_rel: a relation for the new domain unit towards the domain of the second_polygon_data_item.
In QGIS, this operation is known as intersect
.
It is similar to:
unit<uint32> CartesianProduct := combine(DomainUnit(first_polygon_data_item), DomainUnit(second_polygon_data_item))
{
attribute<ValuesUnit(first_polygon_data_item)> Geometry(poly) := first_polygon_data_item[first_rel] * second_polygon_data_item[second_rel];
attribute<bool> IsIntersecting := area(Geometry, Float64) > 0.0;
}
unit<uint32> result := select(CartesianProduct/IsIntersecting)
{
attribute<DomainUnit(first_polygon_data_item)> first_rel := collect_by_cond(., CartesianProduct/first_rel);
attribute<DomainUnit(second_polygon_data_item)> second_rel := collect_by_cond(., CartesianProduct/second_rel);
attribute<ValuesUnit(first_polygon_data_item)> Geometry(poly) := collect_by_cond(., CartesianProduct/Geometry);
}
- The composition type of the first_polygon_data_item and second_polygon_data arguments needs to be a polygon with an ipoint, spoint, fpoint, or dpoint value type.
- The values unit of the first_polygon_data_item and second_polygon_data arguments items must match.
- The order of the points in the first_polygon_data_item and second_polygon_data needs to be clockwise for exterior bounds and counterclockwise for holes in polygons (right-hand-rule).
15.6.0
unit<uint32> intersect := bg_overlay_polygon(Building/geometry, District/geometry);