GCJ-02(火星,高德) 和BD-09(百度) 坐标转换(PHP)

本文提供了一种PHP实现的火星坐标(GCJ-02)与百度坐标(BD-09)之间的相互转换方法。介绍了两个坐标系统的背景,并通过具体函数实现了坐标转换,包括从火星坐标到百度坐标及反向转换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原网页:http://www.tuicool.com/articles/ZjmuQbr

<?php
//GCJ-02(火星,高德) 坐标转换成 BD-09(百度) 坐标//@param gg_lon 火星经度//@param gg_lat 火星纬度
functionbd_encrypt($gg_lon,$gg_lat)
{
    $x_pi = 3.14159265358979324 * 3000.0 / 180.0;
    $x = $gg_lon;
    $y = $gg_lat;
    $z = sqrt($x * $x + $y * $y) - 0.00002 * sin($y * $x_pi);
    $theta = atan2($y, $x) - 0.000003 * cos($x * $x_pi);
    $data['bd_lon'] = $z * cos($theta) + 0.0065;
    $data['bd_lat'] = $z * sin($theta) + 0.006;
    return$data;
}
//BD-09(百度) 坐标转换成  GCJ-02(火星,高德) 坐标//@param bd_lon 百度经度//@param bd_lat 百度纬度
functionbd_decrypt($bd_lon,$bd_lat)
{
    $x_pi = 3.14159265358979324 * 3000.0 / 180.0;
    $x = $bd_lon - 0.0065;
    $y = $bd_lat - 0.006;
    $z = sqrt($x * $x + $y * $y) - 0.00002 * sin($y * $x_pi);
    $theta = atan2($y, $x) - 0.000003 * cos($x * $x_pi);
    $data['gg_lon'] = $z * cos($theta);
    $data['gg_lat'] = $z * sin($theta);
    return$data;
}
//测试$bd = bd_encrypt(108.947903,34.231966);
//输出:array(2) { ["bd_lon"]=> float(108.954466795) ["bd_lat"]=> float(34.2376965936) }$gg = bd_decrypt(108.95434,34.238235);
//输出:array(2) { ["gg_lon"]=> float(108.947903625) ["gg_lat"]=> float(34.2319662425) }?>
坐标解释:
1、GCJ-02,国测局02年发布的 坐标 体系。又称“火星坐标”。 谷歌 ,腾讯,高德都在用这个坐标体系。
2、BD-09, 百度 坐标系。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值