百度API地图的标注不是居中显示,而是显示在左上角是怎么回事?已解决!

在项目中引入了百度地图,运行是发现标注的位置发生了偏移?

按道理是按照坐标定位的,为啥跑到左上角去了,刚开始百思不得其解。

废话不多说,直接上能够处理的代码。

加入这一行就可以了:map.panBy(580, 150);

//map.panBy(580, 150);
//第一个参数是宽度
//第二个参数是高度
//基本设置为你放 id = "allmap" 的div的一半,就居中了。


<script type="text/javascript">

    // 百度地图API功能
    var map = new BMap.Map("allmap");
    var point = new BMap.Point(114.236412,22.691258);
    map.centerAndZoom(point, 18);
    map.enableScrollWheelZoom(true);     //开启鼠标滚轮缩放
    var marker = new BMap.Marker(point);  // 创建标注
    map.addOverlay(marker);               // 将标注添加到地图中
    marker.setAnimation(BMAP_ANIMATION_BOUNCE); //跳动的动画
    // 添加带有定位的导航控件
    var navigationControl = new BMap.NavigationControl({
        // 靠左上角位置
        anchor: BMAP_ANCHOR_TOP_LEFT,
        // LARGE类型
        type: BMAP_NAVIGATION_CONTROL_LARGE,
        // 启用显示定位
        enableGeolocation: true
    });
    map.addControl(navigationControl);
    //解决标注点不居中的问题
    map.panBy(580, 150);//中心点偏移多少像素(width,height)为div 宽高的1/2;

</script>

 

 

完美解决!敬礼,撒花。

 

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值