Heim >php教程 >PHP开发 >Stellen Sie sicher, dass die Koordinaten innerhalb eines bestimmten Koordinatenbereichs im PHP-Code liegen

Stellen Sie sicher, dass die Koordinaten innerhalb eines bestimmten Koordinatenbereichs im PHP-Code liegen

高洛峰
高洛峰Original
2016-12-20 16:35:081204Durchsuche

Eine Anforderung, auf die ich zuvor gestoßen bin, bestand darin, die Dienste des Unternehmens auf einer Karte anzuzeigen und die täglichen Zugriffskoordinaten der Benutzer zu zählen, um zu sehen, wie viele Benutzer sich im erreichbaren Serviceradius befinden.

Das Folgende ist die Implementierung des PHP-Codes (nur Überprüfung, ob die Koordinaten innerhalb eines bestimmten Koordinatenbereichs liegen)

<?php
/**
 * 验证坐标点是否在某区域内
 * @author xiaoliang <1058436713@qq.com>
 * Class validationMap
 */
class validationMap{
 private static $coordArray;
 private static $vertx = [];
 private static $verty = [];
 /**
  * 设置坐标区域
  * @param mixed $coordArray
  */
 public static function setCoordArray(array $coordArray)
 {
  self::$coordArray = $coordArray;
 }
 /**
  * 验证区域范围
  * @param array $coordArray
  * @return bool
  */
 public static function isCityCenter(array $coordArray){
  if(!self::vaildatePoint($coordArray)){
   return false;
  }
  return self::pnpoly(count(self::$coordArray), $coordArray[&#39;lng&#39;], $coordArray[&#39;lat&#39;]);
 }
 /**
  * 比较区域坐标
  * @param $nvert
  * @param $testx
  * @param $testy
  * @return bool
  */
 private static function pnpoly($nvert,$testx, $testy)
 {
  $c = false;
  for ($i = 0, $j = $nvert-1; $i < $nvert; $j = $i++) {
   if ( ( (self::$verty[$i]>$testy) != (self::$verty[$j]>$testy) ) && ($testx < (self::$vertx[$j]-self::$vertx[$i]) * ($testy-self::$verty[$i]) / (self::$verty[$j]-self::$verty[$i]) + self::$vertx[$i]) )
    $c = !$c;
  }
  return $c;
 }
 /**
  * 验证坐标
  * @param array $pointArray
  * @return bool
  */
 private static function vaildatePoint(array $pointArray){
  $maxY = $maxX = 0;
  $minY = $minX = 9999;
  foreach (self::$coordArray as $item){
   if($item[&#39;lng&#39;]>$maxX) $maxX = $item[&#39;lng&#39;];
   if($item[&#39;lng&#39;] < $minX) $minX = $item[&#39;lng&#39;];
   if($item[&#39;lat&#39;]>$maxY) $maxY = $item[&#39;lat&#39;];
   if($item[&#39;lat&#39;] < $minY) $minY = $item[&#39;lat&#39;];
   self::$vertx[] = $item[&#39;lng&#39;];
   self::$verty[] = $item[&#39;lat&#39;];
  }
  if ($pointArray[&#39;lng&#39;] < $minX || $pointArray[&#39;lng&#39;] > $maxX || $pointArray[&#39;lat&#39;] < $minY || $pointArray[&#39;lat&#39;] > $maxY) {
   return false;
  }
  return true;
 }
}
/**************************** test *************************************/
$map = [ //上海
 ["lng" => 121.488286, "lat" => 31.420147],
 ["lng" => 121.702154, "lat" => 31.294828],
 ["lng" => 121.780918, "lat" => 31.141157],
 ["lng" => 121.782068, "lat" => 30.941157],
 ["lng" => 121.492885, "lat" => 30.909931],
 ["lng" => 121.22325, "lat" => 30.890099],
 ["lng" => 121.161482, "lat" => 31.015526],
 ["lng" => 121.076395, "lat" => 31.226239],
 ["lng" => 121.189873, "lat" => 31.339688],
 ["lng" => 121.459509, "lat" => 31.41368],
];
$array = ["lat"=>31.218681,"lng"=>121.08604];//进行验证的区域
validationMap::setCoordArray($map);
var_dump(validationMap::isCityCenter($array));

Anwendung in der Karte:

Stellen Sie sicher, dass die Koordinaten innerhalb eines bestimmten Koordinatenbereichs im PHP-Code liegen

Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, dass er zum Lernen aller beiträgt. Ich hoffe auch, dass jeder die PHP-Chinesisch-Website unterstützt.

Weitere Artikel zum Überprüfen, ob Koordinaten innerhalb eines bestimmten Koordinatenbereichs liegen, finden Sie auf der chinesischen PHP-Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn