ホームページ  >  記事  >  バックエンド開発  >  PHPで座標が特定の座標領域内にあるかどうかを確認する方法

PHPで座標が特定の座標領域内にあるかどうかを確認する方法

*文
*文オリジナル
2018-01-02 13:58:002747ブラウズ

PHP で座標が特定の座標領域内にあるかどうかを確認するにはどうすればよいですか?この記事では主に、特定の座標領域内の座標を検証するための PHP コードを詳しく紹介します。興味のある方は参照してください。お役に立てれば幸いです。

以前、自社のサービスを地図上に表示し、ユーザーの毎日のアクセス座標をカウントして、サービス到達範囲内に何人のユーザーがいるのかを確認したいというニーズに遭遇しました。

以下は PHP コードの実装です (座標が特定の座標領域内にあることのみを確認します)

<?php
/**
 * 验证坐标点是否在某区域内
 * 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));

マップで使用:

関連する推奨事項:

php プロセスロックとマルチプロセスを実装する方法

PHPがMySQLのデッド接続を処理する方法

PHPがIPアドレスマスクを計算する方法

以上がPHPで座標が特定の座標領域内にあるかどうかを確認する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。