亚洲动漫在线观看-亚洲动漫第一页-亚洲丁香婷婷-亚洲丶国产丶欧美一区二区三区-亚洲第一综合网站-亚洲第一永久色

  百度離線地圖 教程

添加點標注

編輯時間:2017-03-02

3.jpg

標注

標注表示地圖上的點。API提供了默認圖標樣式,您也可以通過Icon類來指定自定義圖標。Marker的構造函數的參數為Point和MarkerOptions(可選)。注意:當您使用自定義圖標時,標注的地理坐標點將位于標注所用圖標的中心位置,您可通過Icon的offset屬性修改標定位置。

下面的示例向地圖中心點添加了一個標注,并使用默認的標注樣式。

var map = new BMap.Map("container");   

var point = new BMap.Point(116.404, 39.915);   

map.centerAndZoom(point, 15);   

var marker = new BMap.Marker(point);        // 創建標注   

map.addOverlay(marker);                     // 將標注添加到地圖中

定義標注圖標

通過Icon類可實現自定義標注的圖標,下面示例通過參數MarkerOptions的icon屬性進行設置,您也可以使用marker.setIcon()方法。

var map = new BMap.Map("container");   

var point = new BMap.Point(116.404, 39.915);   

map.centerAndZoom(point, 15);  // 編寫自定義函數,創建標注  

function addMarker(point, index){  // 創建圖標對象  

var myIcon = new BMap.Icon("markers.png", new BMap.Size(23, 25), {   

// 指定定位位置。  

// 當標注顯示在地圖上時,其所指向的地理位置距離圖標左上   

// 角各偏移10像素和25像素。您可以看到在本例中該位置即是  

   // 圖標中央下端的尖角位置。   

   offset: new BMap.Size(10, 25),   

   // 設置圖片偏移。  

   // 當您需要從一幅較大的圖片中截取某部分作為標注圖標時,您  

   // 需要指定大圖的偏移位置,此做法與css sprites技術類似。   

   imageOffset: new BMap.Size(0, 0 - index * 25)   // 設置圖片偏移   

 });     

// 創建標注對象并添加到地圖  

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

 map.addOverlay(marker);    

}   

// 隨機向地圖添加10個標注   

var bounds = map.getBounds();   

var lngSpan = bounds.maxX - bounds.minX;   

var latSpan = bounds.maxY - bounds.minY;   

for (var i = 0; i < 10; i ++) {   

 var point = new BMap.Point(bounds.minX + lngSpan * (Math.random() * 0.7 + 0.15),   

                            bounds.minY + latSpan * (Math.random() * 0.7 + 0.15));   

 addMarker(point, i);   

}

監聽標注事件

事件方法與Map事件機制相同。可參考事件部分。

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

 alert("您點擊了標注");   

});

可托拽的標注

marker的enableDragging和disableDragging方法可用來開啟和關閉標注的拖拽功能。默認情況下標注不支持拖拽,您需要調用marker.enableDragging()方法來開啟拖拽功能。在標注開啟拖拽功能后,您可以監聽標注的dragend事件來捕獲拖拽后標注的最新位置。

marker.enableDragging();   

marker.addEventListener("dragend", function(e){   

 alert("當前位置:" + e.point.lng + ", " + e.point.lat);   

})


標注彈跳動畫

<script type="text/javascript">
       
// 百度地圖API功能
    
var map = new BMap.Map("allmap");
       
var point = new BMap.Point(116.404, 39.915);
       
map.centerAndZoom(point, 15);
       
var marker = new BMap.Marker(point)// 創建標注
    
map.addOverlay(marker);               // 將標注添加到地圖中
    
marker.setAnimation(BMAP_ANIMATION_BOUNCE); //跳動的動畫
</script>


設置標注是否可以拖拽

<script type="text/javascript">
    //
百度地圖API功能
   
var map = new BMap.Map("allmap");
    var point = new BMap.Point(116.404, 39.915);
    map.centerAndZoom(point, 15);
    var marker = new BMap.Marker(point);  //
創建標注
   
map.addOverlay(marker);               // 將標注添加到地圖中
   
marker.disableDragging();           // 默認不可拖拽
   
// marker.enableDragging(); // 設置可拖拽
</script>


內存釋放

在API 1.0版本中,如果您需要在地圖中反復添加大量的標注,這可能會占用較多的內存資源。如果您的標注在移除后不再使用,可調用Overlay.dispose()方法來釋放內存。注意在1.0版本中,調用此方法后標注將不能再次添加到地圖上。自1.1版本開始,您不在需要使用此方法來釋放內存資源,API會自動幫助您完成此工作。

例如,您可以在標注被移除后調用此方法:

map.removeOverlay(marker);   

marker.dispose(); // 1.1 版本不需要這樣調用


主站蜘蛛池模板: 日本三级s级在线播放 | 成年人视频免费在线播放 | 香蕉eeww99国产精品 | 99久久综合精品免费 | 男人的天堂久久 | 国产第一自拍 | 欧美日韩专区国产精品 | 国产综合社区 | 国产精视频 | 男人天堂2023 | 日本伦理动漫在线观看 | 久热这里只有精品99国产6 | 999热在线精品观看全部 | 毛片99| 饭冈加奈子在线播放观看 | 91aaa在线观看 | 亚洲aⅴ天堂 | 涩涩成人 | 四虎现在的网址入口2022 | 国产精品久久久天天影视香蕉 | 欧美大奶艳星 | 调教老师肉色丝袜的故事 | 国产一久久香蕉国产线看观看 | 亚洲高清国产品国语在线观看 | 国产欧美日韩综合二区三区 | fistingvideos头交尿眼 | 粉嫩国产14xxxxx0000 | 国产一久久香蕉国产线看观看 | 日本特级大片 | 无敌在线视频观看免费 | 女子校生下媚药在线观看 | 我和子伦系列小说 | 狠狠干快播 | 奶茶视频官网免费 | www.福利| 2018亚洲男人天堂 | 狠狠久久久久综合网 | 国内精品九一在线播放 | 欧美日韩国产在线一区 | 国产精品一区二区在线观看完整版 | 亚洲国产第一区二区三区 |