简单的百度地图点击获取当前地理坐标

在很多的时候我们需要在地图上点击一个地方,然后获取当前地点的经度和纬度值,代码如下:

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>百度地图API地点搜索-获取经纬度DEMO</title>
  <meta name="description" content="百度地图地点搜索和鼠标点击地点获取经纬度,这些都是地图比较基本和实用的代码,其中还包括了根据用户IP进行地图的显示、改变地图上的鼠标样式、启用滚轮缩放" /> 
  <meta name="keywords" content="百度地图,地点搜索,获取经纬度,改变地图鼠标样式,启用滚轮缩放" /> 
<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.2"></script>
</head>
<body>
<form action="" method="get">
  <label >地点:</label>
  <input id="where" name="where" type="text" >
  <input type="button" value="地图上找" onClick="sear(document.getElementById('where').value);" />
  

  <div style="520px;height:340px;border:1px solid gray" id="container"></div>
  

  经纬度:
  <input id="lonlat" name="lonlat" type="text">
</form>
<script type="text/javascript">
//在指定的容器内创建地图实例
var map = new BMap.Map("container");

map.setDefaultCursor("crosshair");//设置地图默认的鼠标指针样式
map.enableScrollWheelZoom();//启用滚轮放大缩小,默认禁用。
//创建点坐标
var point = new BMap.Point(120.386266, 30.307407);
//初始化地图,设置中心点坐标和地图级别
map.centerAndZoom(point, 13);
//panTo()方法 等待两秒钟后-让地图平滑移动至新中心点
/**window.setTimeout(function(){ 
map.panTo(new BMap.Point(120.386266, 30.307407)); }, 2000);**/
//***********************地址解析类  
var gc = new BMap.Geocoder();
//向map中添加--------------------------------------控件
/**地图API中提供的控件有:
Control:控件的抽象基类,所有控件均继承此类的方法、属性。通过此类您可实现自定义控件。
NavigationControl:地图平移缩放控件,默认位于地图左上方,它包含控制地图的平移和缩放的功能。
OverviewMapControl:缩略地图控件,默认位于地图右下方,是一个可折叠的缩略地图。
ScaleControl:比例尺控件,默认位于地图左下方,显示地图的比例关系。
MapTypeControl:地图类型控件,默认位于地图右上方。
CopyrightControl:版权控件,默认位于地图左下方。
**/
//NavigationControl 地图平移缩放控件,默认位于地图左上方 它包含控制地图的平移和缩放的功能。
map.addControl(new BMap.NavigationControl()); 
//OverviewMapControl 缩略地图控件,默认位于地图右下方,是一个可折叠的缩略地图
map.addControl(new BMap.OverviewMapControl());
//ScaleControl:比例尺控件,默认位于地图左下方,显示地图的比例关系。
map.addControl(new BMap.ScaleControl());
//MapTypeControl:地图类型控件,默认位于地图右上方。
map.addControl(new BMap.MapTypeControl());
//CopyrightControl:版权控件,默认位于地图左下方
map.addControl(new BMap.CopyrightControl());

//----------------------------------------------地图覆盖物
/**地图API提供了如下几种覆盖物:
Overlay:覆盖物的抽象基类,所有的覆盖物均继承此类的方法。
Marker:标注表示地图上的点,可自定义标注的图标。
Label:表示地图上的文本标注,您可以自定义标注的文本内容。
Polyline:表示地图上的折线。
Polygon:表示地图上的多边形。多边形类似于闭合的折线,另外您也可以为其添加填充颜色。
Circle: 表示地图上的圆。
InfoWindow:信息窗口也是一种特殊的覆盖物,它可以展示更为丰富的文字和多媒体信息。注意:同一时刻只能有一个信息窗口在地图上打开。
可以使用map.addOverlay方法向地图添加覆盖物,使用map.removeOverlay方法移除覆盖物,注意此方法不适用于InfoWindow。
**/
// 创建标注  
var marker = new BMap.Marker(point);   
// 将标注添加到地图中
map.addOverlay(marker);
//********************************************监听标注事件
//点击事件
marker.addEventListener("click", function(e){  
 document.getElementById("lonlat").value = e.point.lng + ", " + e.point.lat; 
}); 
//*******************************************可托拽的标注
//marker的enableDragging和disableDragging方法可用来开启和关闭标注的拖拽功能。
marker.enableDragging();
//监听标注的dragend事件来捕获拖拽后标注的最新位置
marker.addEventListener("dragend",function(e){
  gc.getLocation(e.point, function(rs){  
            showLocationInfo(e.point, rs);  
        });  
});

//*****************************信息窗口
//显示地址信息窗口  
function showLocationInfo(pt, rs){  
    var opts = {  
      width : 250,     //信息窗口宽度  
      height: 150,     //信息窗口高度  
      title : "当前位置"  //信息窗口标题  
    }  
    
    var addComp = rs.addressComponents;  
    var addr = "当前位置:" + addComp.province + ", " + addComp.city + ", " + addComp.district + ", " + addComp.street + ", " + addComp.streetNumber + "<br/>";  
    addr += "纬度: " + pt.lat + ", " + "经度:" + pt.lng;  
      
    var infoWindow = new BMap.InfoWindow(addr, opts);  //创建信息窗口对象  
    marker.openInfoWindow(infoWindow);  
} 

map.addEventListener("click", function(e){//地图单击事件
  document.getElementById("lonlat").value = e.point.lng + ", " + e.point.lat;
});

//**************************** 目前百度地图提供的图层包括:
//TrafficLayer:交通流量图层
// 创建交通流量图层实例  
var traffic = new BMap.TrafficLayer();     
// 将图层添加到地图上  
map.addTileLayer(traffic);                    
/**
百度地图提供了交互功能更为复杂的“工具”,它包括:
PushpinTool:标注工具。通过此工具用户可在地图任意区域添加标注。
DistanceTool:测距工具。通过此工具用户可测量地图上任意位置之间的距离。
DragAndZoomTool:区域缩放工具。此工具将根据用户拖拽绘制的矩形区域大小对地图进行放大或缩小操作。
**/
// 创建标注工具实例  
//var myPushpin = new BMap.PushpinTool(map);
// 监听事件,提示标注点坐标信息
//myPushpin.addEventListener("markend",function(e){
//    alert("你标注的位置:"+e.point.lng+","+e.point.lat);
//});
// 开启标注工具  
//myPushpin.open();


function iploac(result){//根据IP设置地图中心
    var cityName = result.name;
    //map.setCenter(cityName);
}
var myCity = new BMap.LocalCity();
myCity.get(iploac);
function sear(result){//地图搜索
  var local = new BMap.LocalSearch(map, {
          renderOptions:{map: map}
  });
  local.search(result);
}
</script>
  <h2 >教程:[url=http://blog.yourtion.com/baidu-maps-search-get-lonlat.html]百度地图API地点搜索-获取经纬度[/url]</h2>
  <h3>输入地点然后点击“地图上找”搜索,点击地图地点获取相应经纬度</h3>
<script type="text/javascript">
  var _gaq = _gaq || [];
  _gaq.push(['_setAccount', 'UA-12599330-14']);
  _gaq.push(['_trackPageview']);

  (function() {
    var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
    ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
    var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
  })();
</script>
</body>
</html>
原文地址:https://www.cnblogs.com/LoveQin/p/5206544.html