高德地图坐标系(GCJ-02)与百度坐标系(BD-09)互相转换

一:代码段(高德转百度)
@Slf4j
public class CoordinatesConvertUtil {

    private  static double x_pi = 3.14159265358979324 * 3000.0 / 180.0;

    /**
     * 高德地图坐标转化为百度坐标
     * @param cordinatesVo
     */
    public static MapCordinatesVo bd_encrypt(MapCordinatesVo cordinatesVo)

    {
        if(cordinatesVo.getLat() == null || cordinatesVo.getLon() == null) {
            log.info("地图坐标不能为空,{}", JSON.toJSONString(cordinatesVo));
            return cordinatesVo;
        }

        log.info("地图坐标转化开始---》{}", JSON.toJSONString(cordinatesVo));
        double x = cordinatesVo.getLon().doubleValue(), y = cordinatesVo.getLat().doubleValue();

        double z = sqrt(x * x + y * y) + 0.00002 * sin(y * x_pi);

        double theta = atan2(y, x) + 0.000003 * cos(x * x_pi);

        double bd_lon = z * cos(theta) + 0.0065;

        double bd_lat = z * sin(theta) + 0.006;

        MapCordinatesVo mapCordinatesVo = new MapCordinatesVo();
        BigDecimal lat = new BigDecimal(bd_lat);
        BigDecimal lon = new BigDecimal(bd_lon);

        mapCordinatesVo.setLat(lat.setScale(6,   BigDecimal.ROUND_HALF_DOWN));
        mapCordinatesVo.setLon(lon.setScale(6,   BigDecimal.ROUND_HALF_DOWN));

        log.info("地图坐标转换结束----》转化之前:{};转化之后:{}", JSON.toJSONString(cordinatesVo), 
                 JSON.toJSONString(mapCordinatesVo));
        return mapCordinatesVo;
    }
}
二:vo模型
@Data
public class MapCordinatesVo extends BasePo {

    /**
     * 纬度
     */
    private BigDecimal lat;

    /**
     * 经度
     */
    private BigDecimal lon;
}

三:百度坐标系转高德

public static void bd_decrypt(double bd_lat, double bd_lon)
{
    double x = bd_lon - 0.0065, y = bd_lat - 0.006;
    double z = sqrt(x * x + y * y) - 0.00002 * sin(y * x_pi);
    double theta = atan2(y, x) - 0.000003 * cos(x * x_pi);
    double gg_lon = z * cos(theta);
    double gg_lat = z * sin(theta);

    BigDecimal lat = new BigDecimal(gg_lat);
    BigDecimal lon = new BigDecimal(gg_lon);
    System.out.println(bd_lat+","+bd_lon);
    System.out.println(gg_lat+","+gg_lon);
    System.out.println(lat.setScale(6,   BigDecimal.ROUND_HALF_DOWN)+","+lon.setScale(6,   
                       BigDecimal.ROUND_HALF_DOWN));
}

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值