test_lgq/niucloud/vendor/mjaschen/phpgeo/tests/Location/PolygonTest.php

570 lines
29 KiB
PHP
Raw Permalink Normal View History

2024-01-24 17:36:08 +08:00
<?php
declare(strict_types=1);
namespace Location;
use Location\Distance\Vincenty;
use PHPUnit\Framework\TestCase;
class PolygonTest extends TestCase
{
public function testIfAddPointsWorksAsExpected(): void
{
$polygon = new Polygon();
$this->assertEquals([], $polygon->getPoints());
$point1 = new Coordinate(10, 10);
$polygon->addPoint($point1);
$this->assertEquals([$point1], $polygon->getPoints());
$point2 = new Coordinate(10, 20);
$polygon->addPoint($point2);
$this->assertEquals([$point1, $point2], $polygon->getPoints());
}
public function testIfGetNumberOfPointsWorksAsExpected(): void
{
$polygon = new Polygon();
$this->assertEquals(0, $polygon->getNumberOfPoints());
$polygon->addPoint(new Coordinate(10, 10));
$this->assertEquals(1, $polygon->getNumberOfPoints());
$polygon->addPoint(new Coordinate(10, 20));
$this->assertEquals(2, $polygon->getNumberOfPoints());
}
public function testIfGetSegmentsWorksAsExpected(): void
{
$polygon = new Polygon();
$point1 = new Coordinate(10, 20);
$point2 = new Coordinate(10, 40);
$point3 = new Coordinate(30, 40);
$point4 = new Coordinate(30, 20);
$polygon->addPoint($point1);
$polygon->addPoint($point2);
$polygon->addPoint($point3);
$polygon->addPoint($point4);
$expected = [
new Line($point1, $point2),
new Line($point2, $point3),
new Line($point3, $point4),
new Line($point4, $point1),
];
$this->assertEquals($expected, $polygon->getSegments());
}
public function testIfGetLatsWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(10, 20));
$polygon->addPoint(new Coordinate(10, 40));
$polygon->addPoint(new Coordinate(30, 40));
$polygon->addPoint(new Coordinate(30, 20));
$expected = [10, 10, 30, 30];
$this->assertEquals($expected, $polygon->getLats());
}
public function testIfGetLngsWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(10, 20));
$polygon->addPoint(new Coordinate(10, 40));
$polygon->addPoint(new Coordinate(30, 40));
$polygon->addPoint(new Coordinate(30, 20));
$expected = [20, 40, 40, 20];
$this->assertEquals($expected, $polygon->getLngs());
}
public function testIfContainsPointCheckWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(10, 20));
$polygon->addPoint(new Coordinate(10, 40));
$polygon->addPoint(new Coordinate(30, 40));
$polygon->addPoint(new Coordinate(30, 20));
$point = new Coordinate(20, 30);
$this->assertTrue($polygon->contains($point));
}
public function testIfContainsPointCheckWithLatitudeSignSwitchWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(- 30, 20));
$polygon->addPoint(new Coordinate(- 30, 40));
$polygon->addPoint(new Coordinate(30, 40));
$polygon->addPoint(new Coordinate(30, 20));
$point = new Coordinate(0, 30);
$this->assertTrue($polygon->contains($point));
$point = new Coordinate(- 10, 30);
$this->assertTrue($polygon->contains($point));
$point = new Coordinate(10, 30);
$this->assertTrue($polygon->contains($point));
}
public function testIfContainsPointCheckWithLongitudeSignSwitchWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(10, - 20));
$polygon->addPoint(new Coordinate(10, 40));
$polygon->addPoint(new Coordinate(30, 40));
$polygon->addPoint(new Coordinate(30, - 20));
$point = new Coordinate(20, 0);
$this->assertTrue($polygon->contains($point));
$point = new Coordinate(20, - 10);
$this->assertTrue($polygon->contains($point));
$point = new Coordinate(20, 10);
$this->assertTrue($polygon->contains($point));
}
public function testIfNotContainsPointCheckWithWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(10, 20));
$polygon->addPoint(new Coordinate(10, 40));
$polygon->addPoint(new Coordinate(30, 40));
$polygon->addPoint(new Coordinate(30, 20));
$point = new Coordinate(20, 10);
$this->assertFalse($polygon->contains($point));
$point = new Coordinate(20, 50);
$this->assertFalse($polygon->contains($point));
$point = new Coordinate(0, 30);
$this->assertFalse($polygon->contains($point));
$point = new Coordinate(40, 30);
$this->assertFalse($polygon->contains($point));
}
/*
public function testIfContainsPointCheckWithLongitudesCrossingThe180thMeridianWorksAsExpected()
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(10, 150));
$polygon->addPoint(new Coordinate(10, -150));
$polygon->addPoint(new Coordinate(30, -150));
$polygon->addPoint(new Coordinate(30, 150));
$point = new Coordinate(20, 160);
$this->assertTrue($polygon->contains($point));
$point = new Coordinate(20, -160);
$this->assertTrue($polygon->contains($point));
}
*/
public function testIfPerimeterCalculationWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(10, 10));
$polygon->addPoint(new Coordinate(10, 20));
$polygon->addPoint(new Coordinate(20, 20));
$polygon->addPoint(new Coordinate(20, 10));
// http://geographiclib.sourceforge.net/cgi-bin/Planimeter?type=polygon&rhumb=geodesic&input=10+10%0D%0A10+20%0D%0A20+20%0D%0A20+10&norm=decdegrees&option=Submit
$this->assertEqualsWithDelta(4355689.472548, $polygon->getPerimeter(new Vincenty()), 0.01, '');
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52, 13));
$polygon->addPoint(new Coordinate(53, 13));
$polygon->addPoint(new Coordinate(53, 12));
$polygon->addPoint(new Coordinate(52, 12));
// http://geographiclib.sourceforge.net/cgi-bin/Planimeter?type=polygon&rhumb=geodesic&input=52+13%0D%0A53+13%0D%0A53+12%0D%0A52+12&norm=decdegrees&option=Submit
$this->assertEqualsWithDelta(358367.809428, $polygon->getPerimeter(new Vincenty()), 0.01, '');
}
public function testIfAreaCalculationWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(0.0000000000, 0.0000000000));
$polygon->addPoint(new Coordinate(0.0000000000, 0.0008983153));
$polygon->addPoint(new Coordinate(0.0009043695, 0.0008983153));
$polygon->addPoint(new Coordinate(0.0009043695, 0.0000000000));
// https://geographiclib.sourceforge.io/cgi-bin/Planimeter?type=polygon&rhumb=geodesic&input=0.0000000000+0.0000000000%0D%0A0.0000000000+0.0008983153%0D%0A0.0009043695+0.0008983153%0D%0A0.0009043695+0.0000000000&norm=decdegrees&option=Submit
//$this->assertEquals(10000.0, $polygon->getArea(), '', 1.0);
}
public function testIfPolygonContainsGeometryWithPolygonInsideWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.221651719883084, 13.661613101139665));
$polygon->addPoint(new Coordinate(52.215716242790222, 13.662988655269146));
$polygon->addPoint(new Coordinate(52.211922844871879, 13.662990247830749));
$polygon->addPoint(new Coordinate(52.208002796396613, 13.664533020928502));
$polygon->addPoint(new Coordinate(52.203469779342413, 13.664621533825994));
$polygon->addPoint(new Coordinate(52.199896154925227, 13.665583860129118));
$polygon->addPoint(new Coordinate(52.199177406728268, 13.665664242580533));
$polygon->addPoint(new Coordinate(52.197426510974765, 13.664221465587616));
$polygon->addPoint(new Coordinate(52.196468207985163, 13.674150248989463));
$polygon->addPoint(new Coordinate(52.200047867372632, 13.674412602558732));
$polygon->addPoint(new Coordinate(52.203508755192161, 13.676183195784688));
$polygon->addPoint(new Coordinate(52.206863863393664, 13.678688379004598));
$polygon->addPoint(new Coordinate(52.213457236066461, 13.67043505422771));
$polygon->addPoint(new Coordinate(52.217430174350739, 13.66775787435472));
$polygon->addPoint(new Coordinate(52.221683654934168, 13.661622740328312));
$insidePolygon = new Polygon();
$insidePolygon->addPoint(new Coordinate(52.206110581755638, 13.674710914492607));
$insidePolygon->addPoint(new Coordinate(52.202216433361173, 13.673997698351741));
$insidePolygon->addPoint(new Coordinate(52.20279042609036, 13.666518358513713));
$insidePolygon->addPoint(new Coordinate(52.209159163758159, 13.667042898014188));
$insidePolygon->addPoint(new Coordinate(52.215381134301424, 13.664670567959547));
$insidePolygon->addPoint(new Coordinate(52.209875900298357, 13.672981224954128));
$this->assertTrue($polygon->containsGeometry($insidePolygon));
}
public function testIfPolygonContainsGeometryWithPolygonInsideAndOutsideWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.221651719883084, 13.661613101139665));
$polygon->addPoint(new Coordinate(52.215716242790222, 13.662988655269146));
$polygon->addPoint(new Coordinate(52.211922844871879, 13.662990247830749));
$polygon->addPoint(new Coordinate(52.208002796396613, 13.664533020928502));
$polygon->addPoint(new Coordinate(52.203469779342413, 13.664621533825994));
$polygon->addPoint(new Coordinate(52.199896154925227, 13.665583860129118));
$polygon->addPoint(new Coordinate(52.199177406728268, 13.665664242580533));
$polygon->addPoint(new Coordinate(52.197426510974765, 13.664221465587616));
$polygon->addPoint(new Coordinate(52.196468207985163, 13.674150248989463));
$polygon->addPoint(new Coordinate(52.200047867372632, 13.674412602558732));
$polygon->addPoint(new Coordinate(52.203508755192161, 13.676183195784688));
$polygon->addPoint(new Coordinate(52.206863863393664, 13.678688379004598));
$polygon->addPoint(new Coordinate(52.213457236066461, 13.67043505422771));
$polygon->addPoint(new Coordinate(52.217430174350739, 13.66775787435472));
$polygon->addPoint(new Coordinate(52.221683654934168, 13.661622740328312));
$inAndOutSidePolygon = new Polygon();
$inAndOutSidePolygon->addPoint(new Coordinate(52.206110581755638, 13.674710914492607));
$inAndOutSidePolygon->addPoint(new Coordinate(52.202216433361173, 13.673997698351741));
$inAndOutSidePolygon->addPoint(new Coordinate(52.20279042609036, 13.666518358513713));
$inAndOutSidePolygon->addPoint(new Coordinate(52.209159163758159, 13.667042898014188));
$inAndOutSidePolygon->addPoint(new Coordinate(52.215381134301424, 13.664670567959547));
$inAndOutSidePolygon->addPoint(new Coordinate(52.209875900298357, 13.672981224954128));
$inAndOutSidePolygon->addPoint(new Coordinate(52.211303086951375, 13.676270367577672));
$inAndOutSidePolygon->addPoint(new Coordinate(52.20556978136301, 13.688599476590753));
$inAndOutSidePolygon->addPoint(new Coordinate(52.205583276227117, 13.688599476590753));
$inAndOutSidePolygon->addPoint(new Coordinate(52.204232113435864, 13.683774350211024));
$this->assertFalse($polygon->containsGeometry($inAndOutSidePolygon));
}
public function testIfPolygonContainsGeometryWithPolygonOutsideWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.221651719883084, 13.661613101139665));
$polygon->addPoint(new Coordinate(52.215716242790222, 13.662988655269146));
$polygon->addPoint(new Coordinate(52.211922844871879, 13.662990247830749));
$polygon->addPoint(new Coordinate(52.208002796396613, 13.664533020928502));
$polygon->addPoint(new Coordinate(52.203469779342413, 13.664621533825994));
$polygon->addPoint(new Coordinate(52.199896154925227, 13.665583860129118));
$polygon->addPoint(new Coordinate(52.199177406728268, 13.665664242580533));
$polygon->addPoint(new Coordinate(52.197426510974765, 13.664221465587616));
$polygon->addPoint(new Coordinate(52.196468207985163, 13.674150248989463));
$polygon->addPoint(new Coordinate(52.200047867372632, 13.674412602558732));
$polygon->addPoint(new Coordinate(52.203508755192161, 13.676183195784688));
$polygon->addPoint(new Coordinate(52.206863863393664, 13.678688379004598));
$polygon->addPoint(new Coordinate(52.213457236066461, 13.67043505422771));
$polygon->addPoint(new Coordinate(52.217430174350739, 13.66775787435472));
$polygon->addPoint(new Coordinate(52.221683654934168, 13.661622740328312));
$outsidePolygon = new Polygon();
$outsidePolygon->addPoint(new Coordinate(52.2123983502388, 13.677485324442387));
$outsidePolygon->addPoint(new Coordinate(52.215186841785908, 13.683912232518196));
$outsidePolygon->addPoint(new Coordinate(52.207024795934558, 13.685344364494085));
$this->assertFalse($polygon->containsGeometry($outsidePolygon));
}
public function testIfPolygonContainsGeometryWithPolylineInsideWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.221651719883084, 13.661613101139665));
$polygon->addPoint(new Coordinate(52.215716242790222, 13.662988655269146));
$polygon->addPoint(new Coordinate(52.211922844871879, 13.662990247830749));
$polygon->addPoint(new Coordinate(52.208002796396613, 13.664533020928502));
$polygon->addPoint(new Coordinate(52.203469779342413, 13.664621533825994));
$polygon->addPoint(new Coordinate(52.199896154925227, 13.665583860129118));
$polygon->addPoint(new Coordinate(52.199177406728268, 13.665664242580533));
$polygon->addPoint(new Coordinate(52.197426510974765, 13.664221465587616));
$polygon->addPoint(new Coordinate(52.196468207985163, 13.674150248989463));
$polygon->addPoint(new Coordinate(52.200047867372632, 13.674412602558732));
$polygon->addPoint(new Coordinate(52.203508755192161, 13.676183195784688));
$polygon->addPoint(new Coordinate(52.206863863393664, 13.678688379004598));
$polygon->addPoint(new Coordinate(52.213457236066461, 13.67043505422771));
$polygon->addPoint(new Coordinate(52.217430174350739, 13.66775787435472));
$polygon->addPoint(new Coordinate(52.221683654934168, 13.661622740328312));
$insidePolyline = new Polyline();
$insidePolyline->addPoint(new Coordinate(52.206110581755638, 13.674710914492607));
$insidePolyline->addPoint(new Coordinate(52.202216433361173, 13.673997698351741));
$insidePolyline->addPoint(new Coordinate(52.20279042609036, 13.666518358513713));
$insidePolyline->addPoint(new Coordinate(52.209159163758159, 13.667042898014188));
$insidePolyline->addPoint(new Coordinate(52.215381134301424, 13.664670567959547));
$insidePolyline->addPoint(new Coordinate(52.209875900298357, 13.672981224954128));
$this->assertTrue($polygon->containsGeometry($insidePolyline));
}
public function testIfPolygonContainsGeometryWithPolylineInsideAndOutsideWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.221651719883084, 13.661613101139665));
$polygon->addPoint(new Coordinate(52.215716242790222, 13.662988655269146));
$polygon->addPoint(new Coordinate(52.211922844871879, 13.662990247830749));
$polygon->addPoint(new Coordinate(52.208002796396613, 13.664533020928502));
$polygon->addPoint(new Coordinate(52.203469779342413, 13.664621533825994));
$polygon->addPoint(new Coordinate(52.199896154925227, 13.665583860129118));
$polygon->addPoint(new Coordinate(52.199177406728268, 13.665664242580533));
$polygon->addPoint(new Coordinate(52.197426510974765, 13.664221465587616));
$polygon->addPoint(new Coordinate(52.196468207985163, 13.674150248989463));
$polygon->addPoint(new Coordinate(52.200047867372632, 13.674412602558732));
$polygon->addPoint(new Coordinate(52.203508755192161, 13.676183195784688));
$polygon->addPoint(new Coordinate(52.206863863393664, 13.678688379004598));
$polygon->addPoint(new Coordinate(52.213457236066461, 13.67043505422771));
$polygon->addPoint(new Coordinate(52.217430174350739, 13.66775787435472));
$polygon->addPoint(new Coordinate(52.221683654934168, 13.661622740328312));
$inAndOutSidePolyline = new Polyline();
$inAndOutSidePolyline->addPoint(new Coordinate(52.206110581755638, 13.674710914492607));
$inAndOutSidePolyline->addPoint(new Coordinate(52.202216433361173, 13.673997698351741));
$inAndOutSidePolyline->addPoint(new Coordinate(52.20279042609036, 13.666518358513713));
$inAndOutSidePolyline->addPoint(new Coordinate(52.209159163758159, 13.667042898014188));
$inAndOutSidePolyline->addPoint(new Coordinate(52.215381134301424, 13.664670567959547));
$inAndOutSidePolyline->addPoint(new Coordinate(52.209875900298357, 13.672981224954128));
$inAndOutSidePolyline->addPoint(new Coordinate(52.211303086951375, 13.676270367577672));
$inAndOutSidePolyline->addPoint(new Coordinate(52.20556978136301, 13.688599476590753));
$inAndOutSidePolyline->addPoint(new Coordinate(52.205583276227117, 13.688599476590753));
$inAndOutSidePolyline->addPoint(new Coordinate(52.204232113435864, 13.683774350211024));
$this->assertFalse($polygon->containsGeometry($inAndOutSidePolyline));
}
public function testIfPolygonContainsGeometryWithPolylineOutsideWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.221651719883084, 13.661613101139665));
$polygon->addPoint(new Coordinate(52.215716242790222, 13.662988655269146));
$polygon->addPoint(new Coordinate(52.211922844871879, 13.662990247830749));
$polygon->addPoint(new Coordinate(52.208002796396613, 13.664533020928502));
$polygon->addPoint(new Coordinate(52.203469779342413, 13.664621533825994));
$polygon->addPoint(new Coordinate(52.199896154925227, 13.665583860129118));
$polygon->addPoint(new Coordinate(52.199177406728268, 13.665664242580533));
$polygon->addPoint(new Coordinate(52.197426510974765, 13.664221465587616));
$polygon->addPoint(new Coordinate(52.196468207985163, 13.674150248989463));
$polygon->addPoint(new Coordinate(52.200047867372632, 13.674412602558732));
$polygon->addPoint(new Coordinate(52.203508755192161, 13.676183195784688));
$polygon->addPoint(new Coordinate(52.206863863393664, 13.678688379004598));
$polygon->addPoint(new Coordinate(52.213457236066461, 13.67043505422771));
$polygon->addPoint(new Coordinate(52.217430174350739, 13.66775787435472));
$polygon->addPoint(new Coordinate(52.221683654934168, 13.661622740328312));
$outsidePolyline = new Polyline();
$outsidePolyline->addPoint(new Coordinate(52.2123983502388, 13.677485324442387));
$outsidePolyline->addPoint(new Coordinate(52.215186841785908, 13.683912232518196));
$outsidePolyline->addPoint(new Coordinate(52.207024795934558, 13.685344364494085));
$this->assertFalse($polygon->containsGeometry($outsidePolyline));
}
public function testIfPolygonContainsGeometryWithLineInsideWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.221651719883084, 13.661613101139665));
$polygon->addPoint(new Coordinate(52.215716242790222, 13.662988655269146));
$polygon->addPoint(new Coordinate(52.211922844871879, 13.662990247830749));
$polygon->addPoint(new Coordinate(52.208002796396613, 13.664533020928502));
$polygon->addPoint(new Coordinate(52.203469779342413, 13.664621533825994));
$polygon->addPoint(new Coordinate(52.199896154925227, 13.665583860129118));
$polygon->addPoint(new Coordinate(52.199177406728268, 13.665664242580533));
$polygon->addPoint(new Coordinate(52.197426510974765, 13.664221465587616));
$polygon->addPoint(new Coordinate(52.196468207985163, 13.674150248989463));
$polygon->addPoint(new Coordinate(52.200047867372632, 13.674412602558732));
$polygon->addPoint(new Coordinate(52.203508755192161, 13.676183195784688));
$polygon->addPoint(new Coordinate(52.206863863393664, 13.678688379004598));
$polygon->addPoint(new Coordinate(52.213457236066461, 13.67043505422771));
$polygon->addPoint(new Coordinate(52.217430174350739, 13.66775787435472));
$polygon->addPoint(new Coordinate(52.221683654934168, 13.661622740328312));
$insideLine = new Line(
new Coordinate(52.206110581755638, 13.674710914492607),
new Coordinate(52.202216433361173, 13.673997698351741)
);
$this->assertTrue($polygon->containsGeometry($insideLine));
}
public function testIfPolygonContainsGeometryWithLineInsideAndOutsideWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.221651719883084, 13.661613101139665));
$polygon->addPoint(new Coordinate(52.215716242790222, 13.662988655269146));
$polygon->addPoint(new Coordinate(52.211922844871879, 13.662990247830749));
$polygon->addPoint(new Coordinate(52.208002796396613, 13.664533020928502));
$polygon->addPoint(new Coordinate(52.203469779342413, 13.664621533825994));
$polygon->addPoint(new Coordinate(52.199896154925227, 13.665583860129118));
$polygon->addPoint(new Coordinate(52.199177406728268, 13.665664242580533));
$polygon->addPoint(new Coordinate(52.197426510974765, 13.664221465587616));
$polygon->addPoint(new Coordinate(52.196468207985163, 13.674150248989463));
$polygon->addPoint(new Coordinate(52.200047867372632, 13.674412602558732));
$polygon->addPoint(new Coordinate(52.203508755192161, 13.676183195784688));
$polygon->addPoint(new Coordinate(52.206863863393664, 13.678688379004598));
$polygon->addPoint(new Coordinate(52.213457236066461, 13.67043505422771));
$polygon->addPoint(new Coordinate(52.217430174350739, 13.66775787435472));
$polygon->addPoint(new Coordinate(52.221683654934168, 13.661622740328312));
$inAndOutSidePolyline = new Line(
new Coordinate(52.207389576360583, 13.670525830239058),
new Coordinate(52.210680730640888, 13.687128368765116)
);
$this->assertFalse($polygon->containsGeometry($inAndOutSidePolyline));
}
public function testIfPolygonContainsGeometryWithLineOutsideWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.221651719883084, 13.661613101139665));
$polygon->addPoint(new Coordinate(52.215716242790222, 13.662988655269146));
$polygon->addPoint(new Coordinate(52.211922844871879, 13.662990247830749));
$polygon->addPoint(new Coordinate(52.208002796396613, 13.664533020928502));
$polygon->addPoint(new Coordinate(52.203469779342413, 13.664621533825994));
$polygon->addPoint(new Coordinate(52.199896154925227, 13.665583860129118));
$polygon->addPoint(new Coordinate(52.199177406728268, 13.665664242580533));
$polygon->addPoint(new Coordinate(52.197426510974765, 13.664221465587616));
$polygon->addPoint(new Coordinate(52.196468207985163, 13.674150248989463));
$polygon->addPoint(new Coordinate(52.200047867372632, 13.674412602558732));
$polygon->addPoint(new Coordinate(52.203508755192161, 13.676183195784688));
$polygon->addPoint(new Coordinate(52.206863863393664, 13.678688379004598));
$polygon->addPoint(new Coordinate(52.213457236066461, 13.67043505422771));
$polygon->addPoint(new Coordinate(52.217430174350739, 13.66775787435472));
$polygon->addPoint(new Coordinate(52.221683654934168, 13.661622740328312));
$outsidePolyline = new Line(
new Coordinate(52.215186841785908, 13.683912232518196),
new Coordinate(52.207024795934558, 13.685344364494085)
);
$this->assertFalse($polygon->containsGeometry($outsidePolyline));
}
public function testIfPolygonContainsGeometryWithPointInsideWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.221651719883084, 13.661613101139665));
$polygon->addPoint(new Coordinate(52.215716242790222, 13.662988655269146));
$polygon->addPoint(new Coordinate(52.211922844871879, 13.662990247830749));
$polygon->addPoint(new Coordinate(52.208002796396613, 13.664533020928502));
$polygon->addPoint(new Coordinate(52.203469779342413, 13.664621533825994));
$polygon->addPoint(new Coordinate(52.199896154925227, 13.665583860129118));
$polygon->addPoint(new Coordinate(52.199177406728268, 13.665664242580533));
$polygon->addPoint(new Coordinate(52.197426510974765, 13.664221465587616));
$polygon->addPoint(new Coordinate(52.196468207985163, 13.674150248989463));
$polygon->addPoint(new Coordinate(52.200047867372632, 13.674412602558732));
$polygon->addPoint(new Coordinate(52.203508755192161, 13.676183195784688));
$polygon->addPoint(new Coordinate(52.206863863393664, 13.678688379004598));
$polygon->addPoint(new Coordinate(52.213457236066461, 13.67043505422771));
$polygon->addPoint(new Coordinate(52.217430174350739, 13.66775787435472));
$polygon->addPoint(new Coordinate(52.221683654934168, 13.661622740328312));
$this->assertTrue($polygon->containsGeometry(new Coordinate(52.206110581755638, 13.674710914492607)));
}
public function testIfPolygonContainsGeometryWithPointOutsideWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.221651719883084, 13.661613101139665));
$polygon->addPoint(new Coordinate(52.215716242790222, 13.662988655269146));
$polygon->addPoint(new Coordinate(52.211922844871879, 13.662990247830749));
$polygon->addPoint(new Coordinate(52.208002796396613, 13.664533020928502));
$polygon->addPoint(new Coordinate(52.203469779342413, 13.664621533825994));
$polygon->addPoint(new Coordinate(52.199896154925227, 13.665583860129118));
$polygon->addPoint(new Coordinate(52.199177406728268, 13.665664242580533));
$polygon->addPoint(new Coordinate(52.197426510974765, 13.664221465587616));
$polygon->addPoint(new Coordinate(52.196468207985163, 13.674150248989463));
$polygon->addPoint(new Coordinate(52.200047867372632, 13.674412602558732));
$polygon->addPoint(new Coordinate(52.203508755192161, 13.676183195784688));
$polygon->addPoint(new Coordinate(52.206863863393664, 13.678688379004598));
$polygon->addPoint(new Coordinate(52.213457236066461, 13.67043505422771));
$polygon->addPoint(new Coordinate(52.217430174350739, 13.66775787435472));
$polygon->addPoint(new Coordinate(52.221683654934168, 13.661622740328312));
$this->assertFalse($polygon->containsGeometry(new Coordinate(52.2123983502388, 13.677485324442387)));
}
public function testGetReverseWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.5, 13.5));
$polygon->addPoint(new Coordinate(64.1, - 21.9));
$polygon->addPoint(new Coordinate(40.7, - 74.0));
$polygon->addPoint(new Coordinate(33.9, - 118.4));
$reversed = $polygon->getReverse();
$expected = new Polygon();
$expected->addPoint(new Coordinate(33.9, - 118.4));
$expected->addPoint(new Coordinate(40.7, - 74.0));
$expected->addPoint(new Coordinate(64.1, - 21.9));
$expected->addPoint(new Coordinate(52.5, 13.5));
$this->assertEquals($expected, $reversed);
}
public function testReverseTwiceWorksAsExpected(): void
{
$polygon = new Polygon();
$polygon->addPoint(new Coordinate(52.5, 13.5));
$polygon->addPoint(new Coordinate(64.1, - 21.9));
$polygon->addPoint(new Coordinate(40.7, - 74.0));
$polygon->addPoint(new Coordinate(33.9, - 118.4));
$doubleReversed = $polygon->getReverse()->getReverse();
$this->assertEquals($polygon, $doubleReversed);
}
public function testIfGetBoundsWorksAsExpected(): void
{
$polygon = new Polygon();
$point1 = new Coordinate(10.0, -20.0);
$point2 = new Coordinate(-10.0, 40.0);
$point3 = new Coordinate(30.0, 50.0);
$point4 = new Coordinate(40.0, 20.0);
$polygon->addPoint($point1);
$polygon->addPoint($point2);
$polygon->addPoint($point3);
$polygon->addPoint($point4);
$expected = new Bounds(new Coordinate(40.0, -20.0), new Coordinate(-10.0, 50.0));
$this->assertEquals($expected, $polygon->getBounds());
}
}