vaderlab / geometry_utils
This package is abandoned and no longer maintained.
No replacement package was suggested.
There is no license information available for the latest version (dev-master) of this package.
Martinez-Rueda algorithm for polygon boolean operations
dev-master
2017-11-29 12:44 UTC
Requires
- php: >=7.0
Requires (Dev)
- phpunit/phpunit: 5.5.*
This package is auto-updated.
Last update: 2022-12-28 23:57:25 UTC
README
PHP implementation of original algorithm http://www4.ujaen.es/~fmartin/bool_op.html
Algorithm is used for computing Boolean operations on polygons:
- union
- difference
- intersection
- xor
Usage
Input parameter is a multipolygon - an array of polygons. And each polygon is an array of points x,y.
$data = [[[-1, 4], [-3, 4], [-3, 0], [-3, -1], [-1, -1], [-1, -2], [2, -2], [2, 1], [-1, 1], [-1, 4]]];
$subject = new \MartinezRueda\Polygon($data);
$data = [[[-2, 5], [-2, 0], [3, 0], [3, 3], [2, 3], [2, 2], [0, 2], [0, 5], [-2, 5]]];
$clipping = new \MartinezRueda\Polygon($data);
$result = (new \MartinezRueda\Algorithm())->getUnion($subject, $clipping);
echo json_encode($result->toArray()), PHP_EOL;
// Result is:
// [[[2,3],[2,2],[0,2],[0,5],[-2,5],[-2,4],[-3,4],[-3,0],[-3,-1],[-1,-1],[-1,-2],[2,-2],[2,0],[3,0],[3,3],[2,3]]]
Some visual examples
Let's consider two polygons: green multipolygon of two polygons and yellow polygon.
Snow-white polygon is result of Boolean operation on two polygons.