0

我想使用asp.net c#在我的网站上的谷歌地图上显示用户当前位置或大致位置。这可能吗???如果它是善意的帮助我。我看了很多教程但失败了。

4

1 回答 1

4

首先,您需要获取本地主机的 google maps API 密钥,此链接提供了有关如何执行此操作的详细信息: http ://www.aspdotnet-suresh.com/2013/01/generate-google-maps-api-key-for .html

第二个在你的 default.aspx 页面中执行以下操作:

脚本标签:

<script type="text/javascript"
src="https://maps.googleapis.com/maps/api/js?key=AIzaSyC6v5-2uaq_wusHDktM9ILcqIrlPtnZgEk&sensor=false">
</script>
<script type="text/javascript" src="http://maps.googleapis.com/maps/api/js?sensor=false&libraries=places">
</script>
<script type="text/javascript">
if (navigator.geolocation) {
navigator.geolocation.getCurrentPosition(success);
} else {
alert("Geo Location is not supported on your current browser!");
}
function success(position) {
var lat = position.coords.latitude;
var long = position.coords.longitude;
var city=position.coords.locality;
var myLatlng = new google.maps.LatLng(lat, long);
var myOptions = {
center: myLatlng,
zoom: 12,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
var marker = new google.maps.Marker({
position: myLatlng,
title: "lat: " + lat + " long: " + long
});

marker.setMap(map);
var infowindow = new google.maps.InfoWindow({ content: "<b>User Address</b><br/> Latitude:"+lat+"<br /> Longitude:"+long+"" });
infowindow.open(map, marker);
}
</script>

body 标签中只包含一个空的 div:

<div id="map_canvas" style="width: 800px; height: 500px"></div>

CSS:

html { height: 100% }
body { height: 100%; margin: 0; padding: 0 }
#map_canvas { height: 100% }

这是你应该得到的结果:

在此处输入图像描述

教程: http ://www.aspdotnet-suresh.com/2013/01/show-user-current-location-on-google.html

于 2013-04-09T17:37:47.833 回答