Comment convertir la longitude et la latitude de Baidu en longitude et latitude de Tencent en utilisant PHP

PHPz
Libérer: 2023-04-19 09:36:39
original
1069 Les gens l'ont consulté

Pendant le processus de développement, nous devons généralement traiter certaines informations de localisation géographique, et les formats de longitude et de latitude des différentes plates-formes sont différents, ce qui nécessite une conversion. Cet article explique comment convertir la longitude et la latitude de Baidu en longitude et latitude de Tencent, et utiliser le code PHP pour l'implémenter.

1. La différence entre la longitude et la latitude de Baidu et la longitude et la latitude de Tencent

La latitude et la longitude sont des symboles de la position à la surface de la Terre, et elles sont exprimées de différentes manières dans différents systèmes de positionnement. : WGS84, GCJ02 et BD09. Parmi eux, WGS84 est le système de coordonnées utilisé par le système de positionnement GPS, GCJ02 est le système de coordonnées du système d'information géographique formulé par le Bureau national chinois d'arpentage et de cartographie, et est également le système de coordonnées qui doit être utilisé par les principales cartes nationales. logiciel, tandis que Baidu Maps utilise BD09.

Lors de l'utilisation de différents systèmes de positionnement, les performances de longitude et de latitude seront également différentes. Par exemple, la longitude et la latitude de Baidu et la longitude et la latitude de Tencent d'un emplacement sont les suivantes :

Longitude et latitude de Baidu : 116.404,39.915
. Longitude et latitude de Tencent : 116.397428,39.908697

II. Méthode de conversion

Étant donné que Baidu et Tencent utilisent des systèmes de positionnement différents, un certain algorithme est nécessaire pour convertir entre la longitude et la latitude.

  1. Convertir le système de coordonnées Baidu en système de coordonnées terrestres (WGS84)

Vous devez d'abord convertir le système de coordonnées Baidu en système de coordonnées terrestres (WGS84). Cela peut être réalisé via l'API fournie par Baidu.

$lng, 'lat'=>$lat); } ?>
Copier après la connexion
  1. Convertissez le système de coordonnées terrestres (WGS84) en système de coordonnées de Mars (GCJ02)

Après avoir utilisé la fonction dans la première étape pour obtenir le résultat du système de coordonnées terrestres (WGS84), vous devez le convertir en le système de coordonnées de Mars. Cela peut être réalisé grâce au code suivant :

transformLat($lng - 105.0, $lat - 35.0); $dLng = $this->transformLng($lng - 105.0, $lat - 35.0); $radLat = $lat / 180.0 * pi(); $magic = sin($radLat); $magic = 1 - $ee * $magic * $magic; $sqrtMagic = sqrt($magic); $dLat = ($dLat * 180.0) / (($a * (1 - $ee)) / ($magic * $sqrtMagic) * pi()); $dLng = ($dLng * 180.0) / ($a / $sqrtMagic * cos($radLat) * pi()); $mgLat = $lat + $dLat; $mgLng = $lng + $dLng; return array('lng'=>$mgLng, 'lat'=>$mgLat); } function transformLat($lng, $lat) { $ret = -100.0 + 2.0 * $lng + 3.0 * $lat + 0.2 * $lat * $lat + 0.1 * $lng * $lat + 0.2 * sqrt(abs($lng)); $ret += (20.0 * sin(6.0 * $lng * pi()) + 20.0 * sin(2.0 * $lng * pi())) * 2.0 / 3.0; $ret += (20.0 * sin($lat * pi()) + 40.0 * sin($lat / 3.0 * pi())) * 2.0 / 3.0; $ret += (160.0 * sin($lat / 12.0 * pi()) + 320 * sin($lat * pi() / 30.0)) * 2.0 / 3.0; return $ret; } function transformLng($lng, $lat) { $ret = 300.0 + $lng + 2.0 * $lat + 0.1 * $lng * $lng + 0.1 * $lng * $lat + 0.1 * sqrt(abs($lng)); $ret += (20.0 * sin(6.0 * $lng * pi()) + 20.0 * sin(2.0 * $lng * pi())) * 2.0 / 3.0; $ret += (20.0 * sin($lng * pi()) + 40.0 * sin($lng / 3.0 * pi())) * 2.0 / 3.0; $ret += (150.0 * sin($lng / 12.0 * pi()) + 300.0 * sin($lng / 30.0 * pi())) * 2.0 / 3.0; return $ret; } ?>
Copier après la connexion
  1. Convertir le système de coordonnées de Mars (GCJ02) en système de coordonnées Tencent

La dernière étape consiste à convertir le système de coordonnées de Mars (GCJ02) en système de coordonnées Tencent :

$lng, 'lat'=>$lat); } ?>
Copier après la connexion

3. Implémentation complète du code

Combinez les trois étapes ci-dessus et obtenez le code complet pour convertir la longitude et la latitude de Baidu en longitude et latitude de Tencent en PHP comme suit :

$lng, 'lat'=>$lat); } function wgs84_to_gcj02($lng, $lat) { $a = 6378245.0; $ee = 0.00669342162296594323; $dLat = $this->transformLat($lng - 105.0, $lat - 35.0); $dLng = $this->transformLng($lng - 105.0, $lat - 35.0); $radLat = $lat / 180.0 * pi(); $magic = sin($radLat); $magic = 1 - $ee * $magic * $magic; $sqrtMagic = sqrt($magic); $dLat = ($dLat * 180.0) / (($a * (1 - $ee)) / ($magic * $sqrtMagic) * pi()); $dLng = ($dLng * 180.0) / ($a / $sqrtMagic * cos($radLat) * pi()); $mgLat = $lat + $dLat; $mgLng = $lng + $dLng; return array('lng'=>$mgLng, 'lat'=>$mgLat); } function transformLat($lng, $lat) { $ret = -100.0 + 2.0 * $lng + 3.0 * $lat + 0.2 * $lat * $lat + 0.1 * $lng * $lat + 0.2 * sqrt(abs($lng)); $ret += (20.0 * sin(6.0 * $lng * pi()) + 20.0 * sin(2.0 * $lng * pi())) * 2.0 / 3.0; $ret += (20.0 * sin($lat * pi()) + 40.0 * sin($lat / 3.0 * pi())) * 2.0 / 3.0; $ret += (160.0 * sin($lat / 12.0 * pi()) + 320 * sin($lat * pi() / 30.0)) * 2.0 / 3.0; return $ret; } function transformLng($lng, $lat) { $ret = 300.0 + $lng + 2.0 * $lat + 0.1 * $lng * $lng + 0.1 * $lng * $lat + 0.1 * sqrt(abs($lng)); $ret += (20.0 * sin(6.0 * $lng * pi()) + 20.0 * sin(2.0 * $lng * pi())) * 2.0 / 3.0; $ret += (20.0 * sin($lng * pi()) + 40.0 * sin($lng / 3.0 * pi())) * 2.0 / 3.0; $ret += (150.0 * sin($lng / 12.0 * pi()) + 300.0 * sin($lng / 30.0 * pi())) * 2.0 / 3.0; return $ret; } function gcj02_to_tx($lng, $lat) { $x = $lng; $y = $lat; $z = sqrt($x * $x + $y * $y) + 0.00002 * sin($y * pi()); $theta = atan2($y, $x) + 0.000003 * cos($x * pi()); $lng = $z * cos($theta) + 0.0065; $lat = $z * sin($theta) + 0.006; return array('lng'=>$lng, 'lat'=>$lat); } function bd09_to_tx($bd_lon, $bd_lat) { $point_wgs84 = $this->bd09_to_wgs84($bd_lon, $bd_lat); $point_gcj02 = $this->wgs84_to_gcj02($point_wgs84['lng'], $point_wgs84['lat']); $point_tx = $this->gcj02_to_tx($point_gcj02['lng'], $point_gcj02['lat']); return $point_tx; } ?>
Copier après la connexion

Enregistrez le code ci-dessus dans un fichier PHP et vous pourrez l'utiliser .

IV.Résumé

Grâce à l'introduction de cet article, nous avons découvert les différences entre la latitude et la longitude de Baidu et la latitude et la longitude de Tencent, et maîtrisé la méthode d'utilisation du code PHP pour convertir la latitude et la longitude de Baidu en latitude et longitude de Tencent. . Dans les projets réels, cette méthode de conversion peut nous fournir des fonctions de traitement des informations cartographiques plus pratiques et plus précises.

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 téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!