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.
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); } ?>
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; } ?>
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); } ?>
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; } ?>
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!