项目作者: kudm761

项目描述 :
Martinez algorithm for polygon Boolean operations, PHP library.
高级语言: PHP
项目地址: git://github.com/kudm761/martinez-rueda-php.git
创建时间: 2017-03-04T19:39:43Z
项目社区:https://github.com/kudm761/martinez-rueda-php

开源协议:

下载


Martinez-Rueda polygon boolean operations algorithm

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.

    1. $data = [[[-1, 4], [-3, 4], [-3, 0], [-3, -1], [-1, -1], [-1, -2], [2, -2], [2, 1], [-1, 1], [-1, 4]]];
    2. $subject = new \MartinezRueda\Polygon($data);
    3. $data = [[[-2, 5], [-2, 0], [3, 0], [3, 3], [2, 3], [2, 2], [0, 2], [0, 5], [-2, 5]]];
    4. $clipping = new \MartinezRueda\Polygon($data);
    5. $result = (new \MartinezRueda\Algorithm())->getUnion($subject, $clipping);
    6. echo json_encode($result->toArray()), PHP_EOL;
    7. // Result is:
    8. // [[[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.

Union

Difference (green NOT yellow)

Intersection

Xor