2012-10-12 42 views
0

因此,我試圖將兩個Google Maps API教程合併到一個地圖中。這一個: https://google-developers.appspot.com/maps/documentation/javascript/examples/map-geolocation 這一個:https://developers.google.com/maps/articles/phpsqlajax_v3Document.getElementById在Google地圖信息窗口中不起作用

我用有兩張地圖爲每個樣本頁面上顯示的,現在我想有一個。除了當我嘗試將內容保存到數據庫時,一切都可以使用。 Document.getElementbyId不會從信息窗口中的表單返回任何東西只是座標。

它在地圖分離時起作用,但當它們在一起時不起作用。

這是我結合代碼:

var customIcons = { 
    blue: { 
    icon: 'http://labs.google.com/ridefinder/images/mm_20_blue.png', 
    shadow: 'http://labs.google.com/ridefinder/images/mm_20_shadow.png' 
    }, 
    red: { 
    icon: 'http://labs.google.com/ridefinder/images/mm_20_red.png', 
    shadow: 'http://labs.google.com/ridefinder/images/mm_20_shadow.png' 
    } 
}; 

var locationInfowindow; 
var locationMarker; 

function initialize() { 
//get the html from the water 
    var waterHTML = "Why is water important in your community?" + 
      "<table>" + 
      "<tr><td>Name:</td> <td><input type='text' id='watername'/> </td> </tr>" + 
      "<tr><td>School:</td> <td><input type='text' id='wateraddress'/></td> </tr>" + 
      "<tr><td>Reason:</td> <td><input type='text' id='waterreason'/> </td></tr>" + 
      "<tr><td></td><td><input type='button' value='Save & Close' onclick='saveData()'/></td></tr>"; 


//setup Map 
    var map = new google.maps.Map(document.getElementById("map"), { 
    center: new google.maps.LatLng(37.926868, -104.501953), 
    zoom: 5, 
    mapTypeId: 'roadmap' 
    }); 

    //start the markers from the database 
    var infoWindow = new google.maps.InfoWindow; 

    // Change this depending on the name of your PHP file 
    downloadXMLUrl('mapxml.php', function(data) { 
    var xml = data.responseXML; 
    var markers = xml.documentElement.getElementsByTagName("marker"); 
    for (var i = 0; i < markers.length; i++) { 
     var name = markers[i].getAttribute("name"); 
     var address = markers[i].getAttribute("school"); 
     var math = markers[i].getAttribute("reason"); 
     var point = new google.maps.LatLng(
      parseFloat(markers[i].getAttribute("lat")), 
      parseFloat(markers[i].getAttribute("lng"))); 
     var html = "<b>" + name + "</b> <br/> <i>" + address + "</i><br/>" +math ; 
     var icon = customIcons['blue'] || {}; 
     var marker = new google.maps.Marker({ 
     map: map, 
     position: point, 
     icon: icon.icon, 
     shadow: icon.shadow 
     }); 
     bindInfoWindow(marker, map, infoWindow, html); 
    } 
    }); 

     //Try HTML5 geolocation 
    if(navigator.geolocation) { 
     navigator.geolocation.getCurrentPosition(function(position) { 
     var pos = new google.maps.LatLng(position.coords.latitude, 
             position.coords.longitude); 

    locationInfowindow = new google.maps.InfoWindow({ 
     content: waterHTML 
    }); 

    locationMarker = new google.maps.Marker({ 
     draggable: true, 
     position: pos, 
     map: map, 
     title: 'Water Event' 
    }); 

    locationInfowindow.open(map,locationMarker); 
      map.setCenter(pos); 
     }, function() { 
     handleNoGeolocation(true); 
     }); 

    } else { 
     // Browser doesn't support Geolocation 
     handleNoGeolocation(false); 
    } 

} 

function bindInfoWindow(marker, map, infoWindow, html) { 
    google.maps.event.addListener(marker, 'click', function() { 
    infoWindow.setContent(html); 
    infoWindow.open(map, marker); 
    }); 
} 


function downloadXMLUrl(url, callback) { 
    var request = window.ActiveXObject ? 
     new ActiveXObject('Microsoft.XMLHTTP') : 
     new XMLHttpRequest; 

    request.onreadystatechange = function() { 
    if (request.readyState == 4) { 
     request.onreadystatechange = doNothing; 
     callback(request, request.status); 
    } 
    }; 

    request.open('GET', url, true); 
    request.send(null); 
} 



function handleNoGeolocation(errorFlag) { 
    if (errorFlag) { 
     var content = 'Your browser doesn\'t support geolocation.' + '</br>'+ 
      "Why is water important in your community?」 " + 
      "<table>" + 
      "<tr><td>Name:</td> <td><input type='text' id='watername'/> </td> </tr>" + 
      "<tr><td>School:</td> <td><input type='text' id='wateraddress'/></td> </tr>" + 
      "<tr><td>Reason:</td> <td><input type='text' id='waterreason'/> </td></tr>" + 
      "<tr><td></td><td><input type='button' value='Save & Close' onclick='saveData()'/></td></tr>"; 
    } else { 
     var content = 'Error: Your browser doesn\'t support geolocation.' + '</br>' + html; 
    } 

    var options = { 
     map: map, 
     position: new google.maps.LatLng(37.926868, -104.501953), 
     content: content 
    }; 

    locationInfowindow = new google.maps.InfoWindow(options); 
    map.setCenter(options.position); 
    } 

    google.maps.event.addDomListener(window, 'load', initialize); 

function saveData() { 

    var watername = escape(document.getElementById("watername").value); 

    console.log(watername); 
    var wateraddress = escape(document.getElementById("wateraddress").value); 

    console.log(wateraddress); 
    var waterreason = document.getElementById("waterreason").value; 
    console.log(waterreason); 

    var latlng = locationMarker.getPosition(); 

    var url = "phpsqlinfo_addrow.php?name=" + watername + "&school=" + wateraddress + "&reason=" + waterreason + "&lat=" + latlng.lat() + "&lng=" + latlng.lng(); 

    console.log(url); 

    downloadUrl(url, function(data, responseCode) { 

    console.log("inurl"); 
    // if (responseCode == 200 && data.length <= 1) { 
     locationInfowindow.close(); 
     document.getElementById("message").innerHTML = "Location added. Refresh to see your addition!"; 
    // } 
    }); 
} 


function downloadUrl(url, callback) { 
    var request = window.ActiveXObject ? 
     new ActiveXObject('Microsoft.XMLHTTP') : 
     new XMLHttpRequest; 

    request.onreadystatechange = function() { 
    if (request.readyState == 4) { 
     request.onreadystatechange = doNothing; 
     callback(request.responseText, request.status); 
    } 
    }; 

    request.open('GET', url, true); 
    request.send(null); 
} 




function doNothing() {} 
+0

你真的有'ID =「地圖」'元素? – meagar

+0

你是什麼意思的「Document.getElementbyId不返回信息窗口中的任何形式只是座標。」? – geocodezip

+0

我認爲你需要提供更多信息。如果地理位置不受支持,我在信息窗口中看不到任何表單。 – geocodezip

回答

1

我不能告訴你到底爲什麼發生這種情況,但該文檔時,waterHTML的隱藏節點副本里面的一些垃圾。

getElementById()檢索文檔中給定ID的第一個元素,因此您總是得到此副本的值而不是所需的值。第一次點擊按鈕後,該副本將以某種方式被刪除。

建議:與其標識使用名稱的屬性,你就可以檢索返回的節點列表中的最後一項:

var waternames = document.getElementsByName("watername"); 
    var watername = escape(waternames[waternames.length-1].value); 
    //the same for waterreason and wateraddress 
+0

非常感謝您的幫助!這解決了我的問題! – user1741992

+0

現在我在拖動標記後遇到了問題。它並不總是得到更新,但我想這需要一個新的問題。 – user1741992

+0

這個問題的演示很好,對我來說它適用於你的代碼(url總是包含更新後的lat&lng-values) –

相關問題