咨询电话:186 7916 6165 咨询电话:186 7916 6165 (微信同号)    在线QQ:181796286
NEWS BLOG ·
学无止境
关注开优网络 关注前沿
ASP.NET Web 开发之静态页
AspNetPager 伪静态设置

ASP.NET百度地图API使用

发表日期:2016-10-07    文章编辑:南昌开优网络    浏览次数:4257    标签:ASP.NET应用

1、点击选择弹出百度地图,在地图中点击并获取座标  html页面
<!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> 
    <script type="text/javascript">  //获取父级页面的 座标 文件框 
        var xz = window.parent.document.getElementById("ctl00_ContentBody_txtxz"); 
        var yz = window.parent.document.getElementById("ctl00_ContentBody_txtyz");       
    </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="width: 520px; height: 340px; border: 1px solid gray" id="container"> 
</div> 
经度: 
<input id="txtxz" name="lonlat" type="text" /> 
纬度:<input id="txtyz" 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(115.907721, 28.667952); 
//初始化地图,设置中心点坐标和地图级别 
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("txtxz").value = e.point.lng; 
document.getElementById("txtyz").value = e.point.lat; 
//xz.value = e.point.lng;  //父级窗口中  座标 文本框的值 
//yz.value = e.point.lat;            
//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("txtxz").value = e.point.lng; 
document.getElementById("txtyz").value = e.point.lat; 
// xz.value = e.point.lng;  //父级窗口中  座标 文本框的值 
// yz.value = e.point.lat;            
// 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> 
<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> 
2、获取座标保存至数据库中,在前台显示出来 aspx页面

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="baiduMap.aspx.cs" Inherits="XiaobinManage.Web.baiduMap" %> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head runat="server"> 
<title></title> 
<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.2"></script> 
<script type="text/javascript" src="http://api.map.baidu.com/library/CityList/1.2/src/CityList_min.js"></script> 
<style> 
.lll{color: #000; 
text-decoration: none;} 
.cityList{height: 320px; 
width: 372px; 
overflow-y: auto;} 
.sel_container{position: absolute; 
top: 0; 
font-size: 12px;} 
.map_popup{position: absolute; 
z-index: 200000; 
width: 382px; 
height: 344px; 
top: 20px;} 
.map_popup .popup_main{background: #fff; 
border: 1px solid #8BA4D8; 
height: 100%; 
overflow: hidden; 
position: absolute; 
width: 100%; 
z-index: 2;} 
.map_popup .title{background: url("http://map.baidu.com/img/popup_title.gif") repeat scroll 0 0 transparent; 
color: #6688CC; 
font-size: 12px; 
font-weight: bold; 
height: 24px; 
line-height: 25px; 
padding-left: 7px;} 
.map_popup button{background: url("http://map.baidu.com/img/popup_close.gif") no-repeat scroll 0 0 transparent; 
border: 0 none; 
cursor: pointer; 
height: 12px; 
position: absolute; 
right: 4px; 
top: 6px; 
width: 12px;}
</style> 
</head> 
<body> 
<form id="form1" runat="server"> 
<div style="width:230px; height:275px; border: 1px solid gray" id="container"> 
</div> 
<script type="text/javascript"> 
// 标注点数组 
var BASEDATA = [ 
<%=BaiduMap()%> 
// { url: "javascript:void(0)", title: "南昌三星大厦", content: "站前西路", point: "115.905744|28.668096" } ,
// { url: "javascript:void(0)", title: "南昌三星大厦", content: "站前西路", point: "115.905744|28.668096" } 
] 
var map = new BMap.Map("container"); // 创建Map实例 
for (var i = 0; i < BASEDATA.length; i++) { 
var p = BASEDATA[i].point; 
var p_x = p.split('|')[0]; 
var p_y = p.split('|')[1]; 
if (i == 0) { 
var point = new BMap.Point(p_x, p_y); // 创建点坐标 
map.centerAndZoom(point, 14); // 初始化地图,设置中心点坐标和地图级别。 
} 
var label = new BMap.Label("<a target='_blank' class='lll' href='" + BASEDATA[i].url + "'><b>" + BASEDATA[i].title + "</b></a><br/>" + BASEDATA[i].content, { "offset": new BMap.Size(-70, -40) }); //设置label 
var point1 = new BMap.Point(p_x, p_y); 
addMarker(point1, label); 
} 
map.enableScrollWheelZoom(); // 启用滚轮放大缩小。 
//map.enableKeyboard(); // 启用键盘操作。 
map.addControl(new BMap.NavigationControl()); //增加缩略 

// 编写自定义函数,创建标注 
function addMarker(p, l) { 
var marker = new BMap.Marker(p); // 创建标注 
marker.setLabel(l); //添加label 

map.addOverlay(marker); // 将标注添加到地图中 
l.setStyle({//设置lable样式 
borderColor: "#808080", 
color: "#333", 
cursor: "pointer", 
padding: "2px" 
}); 
} 
</script> 
</form> 
</body> 
</html> 


public string BaiduMap()
 {
            string str = "";
            string id = Request.QueryString["id"];
            int x;
            if (int.TryParse(id, out x))
            {
                Model.Cases c = cdal.GetModel(x);
                str = "{ url: \"javascript:void(0)\", title: \""+c.title+"\", content: \""+c.address+"\", point: \"" + c.xz + "|" + c.yz + "\" }";
            }
            return str;
}