Maison > base de données > tutoriel mysql > Comment déterminer si un point se trouve à l'intérieur d'un polygone en utilisant PHP ?

Comment déterminer si un point se trouve à l'intérieur d'un polygone en utilisant PHP ?

Mary-Kate Olsen
Libérer: 2024-10-25 01:07:02
original
382 Les gens l'ont consulté

How to Determine if a Point Lies Inside a Polygon Using PHP?

Rechercher des points dans un polygone à l'aide de PHP

Déterminer si un point se trouve à l'intérieur d'un polygone peut être une tâche courante dans les calculs géométriques. Voici comment y parvenir en PHP :

Nous commençons par un polygone représenté comme un tableau de sommets avec des coordonnées de latitude et de longitude. De plus, nous avons un point avec des coordonnées similaires dont nous voulons vérifier s'il se trouve dans le polygone.

Pour effectuer cette vérification, nous utilisons une fonction écrite à l'origine dans un autre langage et convertie en PHP :

<code class="php">$isInside = is_in_polygon(
    count($vertices_x) - 1,
    $vertices_x,
    $vertices_y,
    $longitude_x,
    $latitude_y
);</code>
Copier après la connexion

La fonction is_in_polygon implémente l'algorithme suivant :

<code class="php">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)) &amp;&amp;
         ($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;
}</code>
Copier après la connexion

Si la variable $isInside est définie sur true, le point se trouve dans le polygone ; sinon, il se trouve à l'extérieur.

Ressources supplémentaires :

Pour d'autres fonctions liées aux polygones, envisagez d'utiliser la classe polygon.php. Initialisez-le avec les sommets de votre polygone et appelez la fonction isInside avec votre point de test pour obtenir une autre solution au problème.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal