我编译并调整此演示脚本,以便使用其他脚本的部分地理位置进行学习跟踪。到目前为止一切都很好......但是停止搜索或跟踪的函数clearWatch()没有响应,因为它后面的alert()没有显示。
我忘了什么?
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<style type="text/css">
html { height: 100% }
body { height: 100%; margin: 0px; padding: 0px }
#map_canvas { height: 100% ; width:100%;}
</style>
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script>
<script type="text/javascript">
var previousPosition = null;
var startId;
var trackId;
function initialize() {
document.getElementById("info").innerHTML = "Je positie aan het zoeken...";
if (navigator.geolocation) {
startId = navigator.geolocation.watchPosition(function(position) {
var startPos = position;
var startAccuracy = startPos.coords.accuracy;
document.getElementById("info").innerHTML = "In de buurt... ca." + startAccuracy + " meter...";
if(startAccuracy < 3) {
document.getElementById("info").innerHTML = "Gevonden... binnen " + startAccuracy + " meter...";
map = new google.maps.Map(document.getElementById("map_canvas"), {
zoom: 18,
center: new google.maps.LatLng(startPos.coords.latitude, startPos.coords.longitude),
mapTypeId: google.maps.MapTypeId.ROADMAP
});
var marker = new google.maps.Marker({
position: new google.maps.LatLng(startPos.coords.latitude, startPos.coords.longitude),
map: map
});
navigator.geolocation.clearWatch(startId);
document.getElementById("info").innerHTML = "Tracking start over 5 seconden...";
setTimeout(function(){startTracking()},5000);
}
}, function(error) {
alert("Error code: " + error.code);
// error.code can be:
// 0: unknown error
// 1: permission denied
// 2: position unavailable (error response from locaton provider)
// 3: timed out
}, {maximumAge:1000, enableHighAccuracy: true});
}
else {
alert("GeoLocatie wordt niet ondersteund!");
}
}
function startTracking() {
document.getElementById("info").innerHTML = "Tracking is gestart...";
trackId = navigator.geolocation.watchPosition(successCallback, null, {maximumAge:1000, timeout:60000, enableHighAccuracy:true});
function successCallback(position){
map.panTo(new google.maps.LatLng(position.coords.latitude, position.coords.longitude));
if (previousPosition){
var newLineCoordinates = [
new google.maps.LatLng(previousPosition.coords.latitude, previousPosition.coords.longitude),
new google.maps.LatLng(position.coords.latitude, position.coords.longitude)];
var newLine = new google.maps.Polyline({
path: newLineCoordinates,
strokeColor: "#FF0000",
strokeOpacity: 1.0,
strokeWeight: 2
});
newLine.setMap(map);
}
previousPosition = position;
};
}
function stopZoeken() {
navigator.geolocation.clearWatch(startId);
alert("Zoeken gestopt!");
}
function stopTracking() {
navigator.geolocation.clearWatch(trackId);
alert("Tracking gestopt!");
}
</script>
</head>
<body onload="initialize()">
<div id="info"></div>
<div><input type="button" onclick="stopZoeken()" value="Stop Zoeken" /> <input type="button" onclick="stopTracking()" value="Stop Tracking" /></div>
<div id="map_canvas"></div>
</body>
</html>
答案 0 :(得分:1)
Grrr,愚蠢的我,我最关注的是地理位置调用,忘了查看javascript问题。因此,clearWatch()没有响应的原因是:vars startId和trackId未在JS中声明为顶部。我把声明放在调用中:var startId = ....所以我调整了脚本,现在没问题了!
随意使用和/或编辑此脚本作为项目的基础。