Heim >Datenbank >MySQL-Tutorial >## Wie stellt man mit PHP fest, ob ein Punkt innerhalb eines Polygons liegt?
Bestimmen, ob ein Punkt innerhalb eines Polygons liegt
Im Bereich der räumlichen Analyse stößt man häufig auf das Problem, festzustellen, ob ein bestimmter Punkt vorliegt liegt innerhalb der Grenzen eines Polygons. Dies kann besonders schwierig sein, wenn es um komplexe geometrische Formen geht, die durch mehrere Eckpunkte definiert sind. Der Geometry-Datentyp von MySQL enthält einen Polygontyp zur Darstellung solcher Formen.
Stellen Sie sich das Szenario vor, in dem wir ein Array von Breiten- und Längengraden haben, die die Eckpunkte eines Polygons darstellen, wie unten gezeigt:
[{"x":37.628134, "y":-77.458334}, {"x":37.629867, "y":-77.449021}, {"x":37.62324, "y":-77.445416}, {"x":37.622424, "y":-77.457819}]
Zusätzlich haben wir einen Punkt mit eigenen Breiten- und Längenkoordinaten:
$location = new vertex($_GET["longitude"], $_GET["latitude"]);
Die Aufgabe besteht darin, festzustellen, ob dieser Punkt innerhalb des angegebenen Polygons liegt. Um dies in PHP zu erreichen, können wir die folgende Funktion verwenden:
<?php $vertices_x = array(37.628134, 37.629867, 37.62324, 37.622424); // x-coordinates of the vertices of the polygon $vertices_y = array(-77.458334,-77.449021,-77.445416,-77.457819); // y-coordinates of the vertices of the polygon $points_polygon = count($vertices_x) - 1; // number vertices - zero-based array $longitude_x = $_GET["longitude"]; // x-coordinate of the point to test $latitude_y = $_GET["latitude"]; // y-coordinate of the point to test if (is_in_polygon($points_polygon, $vertices_x, $vertices_y, $longitude_x, $latitude_y)){ echo "Is in polygon!"; } else echo "Is not in polygon"; function is_in_polygon($points_polygon, $vertices_x, $vertices_y, $longitude_x, $latitude_y) { $i = $j = $c = 0; for ($i = 0, $j = $points_polygon ; $i < $points_polygon; $j = $i++) { if ( (($vertices_y[$i] > $latitude_y != ($vertices_y[$j] > $latitude_y)) && ($longitude_x < ($vertices_x[$j] - $vertices_x[$i]) * ($latitude_y - $vertices_y[$i]) / ($vertices_y[$j] - $vertices_y[$i]) + $vertices_x[$i]) ) ) $c = !$c; } return $c; } ?>
Diese Funktion iteriert über die Eckpunkte des Polygons und verwendet geometrische Berechnungen, um zu bestimmen, ob der Punkt innerhalb seiner Grenzen liegt. Basierend auf dem Ergebnis wird ein Flag zurückgegeben, das angibt, ob der Punkt innerhalb oder außerhalb des Polygons liegt.
Für eine umfassendere Funktionalität sollten Sie die Verwendung der Klasse polygon.php in Betracht ziehen. Indem Sie eine Instanz dieser Klasse mit den Eckpunkten Ihres Polygons erstellen und die Methode isInside() mit Ihrem Punkt als Eingabe aufrufen, können Sie einen alternativen Ansatz zur Lösung dieses Problems nutzen.
Das obige ist der detaillierte Inhalt von## Wie stellt man mit PHP fest, ob ein Punkt innerhalb eines Polygons liegt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!