问题 百度地图marker不在中心点处

Posted 进击的前端狗

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了问题 百度地图marker不在中心点处相关的知识,希望对你有一定的参考价值。

问题:

 var map = new BMap.Map("mapshow");				    
 map.centerAndZoom(point, 15);	

  

显示百度地图时,map.centerAndZoom使用point作为参数时,标点不出现在中心处。

 

原因:

我是隐藏状态下(display:none)创建的地图
这样会导致地图容器宽高为0,在宽高为0的容器上,中心点自然也是0了
这算是BMap的缺陷吧,只能在可视的情况下或者display:visibile下创建地图。

 

解决办法:

我使用的是bootstrap的模态框作为地图的容器的。使用模态框的打开箭头事件 show.bs.modal。将地图容器设置为 display","visibile

$("#publish").on("show.bs.modal",function() {
        $(".map-container").css("display","visibile");//地图容器设置为不可见,取代了none。等待地图创建
}    

 

等待地图创建完成后,需要将display的参数visibile变成none,这样不会占位置。

1  $(".map-container").css("display","none");

效果:标注出现在了中间

 

以上是关于问题 百度地图marker不在中心点处的主要内容,如果未能解决你的问题,请参考以下文章

android 百度地图上marker点移动要怎么处理

地图移动的时候,怎样实时改变marker的经纬度坐标为地图中心点坐标 我用的是百度api的js版本 求解答!

vue中实现百度地图拖拽地图定位功能

百度地图 弹窗效果,标注总显示在左上角

百度地图的坐标怎么添加啊?

android 高德地图sdk,在地图上我点击了某个marker,然后这个被点击的marker就被自动定位