百度地图js api控件方法怎么用

JavaScript018

百度地图js api控件方法怎么用,第1张

获取代码如下:(注意:通常我们在网页中只要插入以下代码,小虫标注出来,其余的可不用。)

1.在<head></head>间插入下面代码:这是样式和JS脚本。

<!--引用百度地图API-->

<style type="text/css">

html,body{margin:0padding:0}

.iw_poi_title {color:#CC5522font-size:14pxfont-weight:boldoverflow:hiddenpadding-right:13pxwhite-space:nowrap}

.iw_poi_content {font:12px arial,sans-serifoverflow:visiblepadding-top:4pxwhite-space:-moz-pre-wrapword-wrap:break-word}

</style>

<script type="text/javascript" src=""></script>

2.在<body></body>间需要显示地图的位置放入以下代码:(该代码调用地图)

<!--百度地图容器-->

<div style="width:697pxheight:550pxborder:#ccc solid 1px" id="dituContent"></div>

3.以下代码放在页面最底端(其实可放在页面任意位置。)

<script type="text/javascript">

//创建和初始化地图函数:

function initMap(){

createMap()//创建地图

setMapEvent()//设置地图事件

addMapControl()//向地图添加控件

addMarker()//向地图中添加marker

}

//创建地图函数:

function createMap(){

var map = new BMap.Map("dituContent")//在百度地图容器中创建一个地图

var point = new BMap.Point(115.949652,28.693851)//定义一个中心点坐标

map.centerAndZoom(point,18)//设定地图的中心点和坐标并将地图显示在地图容器中

window.map = map//将map变量存储在全局

}

//地图事件设置函数:

function setMapEvent(){

map.enableDragging()//启用地图拖拽事件,默认启用(可不写)

map.enableScrollWheelZoom()//启用地图滚轮放大缩小

map.enableDoubleClickZoom()//启用鼠标双击放大,默认启用(可不写)

map.enableKeyboard()//启用键盘上下左右键移动地图

}

//地图控件添加函数:

function addMapControl(){

//向地图中添加缩放控件

var ctrl_nav = new BMap.NavigationControl({anchor:BMAP_ANCHOR_TOP_LEFT,type:BMAP_NAVIGATION_CONTROL_LARGE})

map.addControl(ctrl_nav)

//向地图中添加缩略图控件

var ctrl_ove = new BMap.OverviewMapControl({anchor:BMAP_ANCHOR_BOTTOM_RIGHT,isOpen:1})

map.addControl(ctrl_ove)

//向地图中添加比例尺控件

var ctrl_sca = new BMap.ScaleControl({anchor:BMAP_ANCHOR_BOTTOM_LEFT})

map.addControl(ctrl_sca)

}

//标注点数组

var markerArr = [{title:"百恒网络",content:"电话:0791-88117053<br/>手机:15079002975",point:"115.950312|28.693447",isOpen:1,icon:{w:23,h:25,l:46,t:21,x:9,lb:12}}

]

//创建marker

function addMarker(){

for(var i=0i<markerArr.lengthi++){

var json = markerArr[i]

var p0 = json.point.split("|")[0]

var p1 = json.point.split("|")[1]

var point = new BMap.Point(p0,p1)

var iconImg = createIcon(json.icon)

var marker = new BMap.Marker(point,{icon:iconImg})

var iw = createInfoWindow(i)

var label = new BMap.Label(json.title,{"offset":new BMap.Size(json.icon.lb-json.icon.x+10,-20)})

marker.setLabel(label)

map.addOverlay(marker)

label.setStyle({

borderColor:"#808080",

color:"#333",

cursor:"pointer"

})

(function(){

var index = i

var _iw = createInfoWindow(i)

var _marker = marker

_marker.addEventListener("click",function(){

this.openInfoWindow(_iw)

})

_iw.addEventListener("open",function(){

_marker.getLabel().hide()

})

_iw.addEventListener("close",function(){

_marker.getLabel().show()

})

label.addEventListener("click",function(){

_marker.openInfoWindow(_iw)

})

if(!!json.isOpen){

label.hide()

_marker.openInfoWindow(_iw)

}

})()

}

}

//创建InfoWindow

function createInfoWindow(i){

var json = markerArr[i]

var iw = new BMap.InfoWindow("<b class='iw_poi_title' title='" + json.title + "'>" + json.title + "</b><div class='iw_poi_content'>"+json.content+"</div>")

return iw

}

//创建一个Icon

function createIcon(json){

var icon = new BMap.Icon("", new BMap.Size(json.w,json.h),{imageOffset: new BMap.Size(-json.l,-json.t),infoWindowOffset:new BMap.Size(json.lb+5,1),offset:new BMap.Size(json.x,json.h)})

return icon

}

initMap()//创建和初始化地图

</script>

当然,如果你想偷懒,将以上对应代码全放在<body></body>间也是没问题的,呵呵。

1~坐标点击就是直接点击某个点,这个点是固定的,所以在不同分辨率兼容性差,所以不推荐使用,不详说,主要说说其他几个

2~控件点击是autojs左右特点的一项功能,它是基于安卓的无障碍功能的,在软件上有很好的支持,但是游戏就不行了。具体的教程很多,不多说了,就说说我在使用时踩得一些坑。

①有些控件能用autojs的工具找到,但是写出来后却识别不出来,手动滑动一下屏幕就能找到了,不知道是不是BUG,所以加个判断,防止找不到脚本出错

②寻找控件建议不要用findOne()、waitFor()、exists()等一些会阻塞的方法,不然稍微出现一点其他事件就会阻塞,导致脚本莫名其妙的卡死,使用findOne(timeout)、findonce()时可以加个判断在不为null的时候再点击或其他操作,因为没找到返回null,直接click就会报错,脚本停止运行,要是是找的父或者子控件也写到判断里

③找图找色特别消耗内存,所以在能用控件就用控件,找图找色在找到后要用recycle()来对创建的图像对象回收,提高脚本稳定,让脚本能持续运行更长时间,截图也需要一定的时间

④如果脚本有悬浮窗,使用找图要注意不要将要找的图遮挡

⑤控件中使用text比id要靠谱一些,在一些软件中id是会改变的

ps:如果有问题可以在评论区评论,会的我会解答,不定时更新,可以点点关注和小心心哦