问题 百度地图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不在中心点处的主要内容,如果未能解决你的问题,请参考以下文章

ViewPager 不在超过 1 个片段中显示地图 v2

如何在腾讯地图一边导航一边在拐弯处做标记?

借助百度地图API制作企业百度地图

如何在android中的地图片段内中心线性布局?

如何在不在 android 的 Activity 上添加地图片段的情况下获取我的位置?

百度android地图如何获取地图中心点的经纬坐标