2011-08-09 19 views
0

私はJavascriptとGoogle Maps APIをかなり使い慣れているので、どんな助けでも大歓迎です。google maps API v3がIEで動作していない

境界線の位置をマークするためのポリゴンマップと、アドレスを検索してアドレスがどのポリゴンであるかを確認する機能を備えています。コードはFirefoxとChromeの両方で動作しますが、 IEのアドレスでは、マーカを適切な場所に置くのではなく、マップをリロードするだけです。

私が使用しているすべての機能が含まれています。 microajax Javascript関数は、すべての多角形の座標の座標を含むxmlファイルを読み込むために使用されます。ポリゴンはIEでレンダリングされているので、これが問題の原因だとは思わないので、それを含めていません。私は問題が何であるかについては迷っています。前もって感謝します。

<script type="text/javascript" src="http://maps.googleapis.com/maps/api/js?sensor=false"></script> 
<script type="text/javascript" src="microajax.js"></script> 


<style type="text/css"> 
html { height: 100% } 
body { height: 100%; margin: 30px; padding: 0px } 
#map_canvas { height: 100% } 
</style> 

<div id="map_canvas" style="width:800px; height:600px" text="If map is not present, this browser does not support Google Maps"></div>   

<div id="message"></div>  

<form onsubmit="showAddress()" action="#"> 
    <input id="search" size="60" type="text" value="" /> 
    <input type="submit" value="Go!" /> 
    <input type="button" onclick="clearmarkers();" value="Clear markers" /> 
</form> 

</head> 

<body onload="initialize()"> 

<noscript><b>JavaScript must be enabled in order for you to use Google Maps.</b> 
    However, it seems JavaScript is either disabled or not supported by your browser. 
    To view Google Maps, enable JavaScript by changing your browser options, and then 
    try again. 
</noscript> 


<script type="text/javascript"> 

var gmarkers = []; 
var polys = []; 
var labels = []; 
var glob; 
var geo = new google.maps.Geocoder(); 
var map; 

function initialize() {   

    var ontario = new google.maps.LatLng(50.397, -85.644); 
    var myOptions = { 
    zoom: 5, 
    center: ontario, 
    mapTypeId: google.maps.MapTypeId.ROADMAP 
    } 
    map = new google.maps.Map(document.getElementById("map_canvas"), myOptions); 

    microAjax("xmloutput2.xml", function(data) { 
    // ========= processing the polylines =========== 
    var xmlDoc = xmlParse(data) 
    var lhins = xmlDoc.documentElement.getElementsByTagName("lhin"); 
    // read each line   
    for (var a = 0; a < lhins.length; a++) {   
    var label = lhins[a].getAttribute("name"); 
    var colour = lhins[a].getAttribute("colour"); 
    // read each point on that line 
    var points = lhins[a].getElementsByTagName("point"); 
    var pts = []; 
    for (var i = 0; i < points.length; i++) { 
     pts[i] = new google.maps.LatLng(parseFloat(points[i].getAttribute("lat")), parseFloat(points[i].getAttribute("lng")));     
    } 
    var poly = new google.maps.Polygon({ 
     paths:pts, 
     strokeColor:"#000000", 
     strokeOpacity: 1, 
     strokeWeight: 2, 
     fillColor: colour, 
     fillOpacity: 0 
    }); 
    poly.setMap(map); 
    polys.push(poly); 
    labels.push(label); 
    } 


function showAddress() { 
    var search = document.getElementById("search").value; 
    geo.geocode({ 'address': search}, function(results, status) { 
    if (status == google.maps.GeocoderStatus.OK) { 
    // How many results were found 
     document.getElementById("message").innerHTML = "Found " +results.length +" results"; 
     // Loop through the results, placing markers   
     for (var i=0; i<results.length; i++) {           
     var marker = new google.maps.Marker({ 
      map: map, 
      position: results[i].geometry.location 
     }); 
     gmarkers.push(marker); 
     glob=checkpoint(marker);      
     if (glob == 99) { 
      var infowindowoptions = { 
      content: 'This address is not within a LHIN boundary' 
      } 
      infowindow = new google.maps.InfoWindow(infowindowoptions); 

      google.maps.event.addListener(marker, 'click', function() { 
      infowindow.open(map, this); 
      });       
      document.getElementById("message").innerHTML += "<br>"+(i+1)+": "+ results[i].formatted_address +" "+ results[i].geometry.location +    "Outside of Bounds"; 
     } 
     else { 
      var infowindowoptions = { 
      content: 'This address is in LHIN '+labels[glob] 
      } 
      infowindow = new google.maps.InfoWindow(infowindowoptions); 

      google.maps.event.addListener(marker, 'click', function() { 
      infowindow.open(map, this); 
      });       
      document.getElementById("message").innerHTML += "<br>"+(i+1)+": "+ results[i].formatted_address +" "+ results[i].geometry.location + 
      " - LHIN "+(glob+1)+" "+labels[glob]; 
     }    
     } 
     map.setCenter(results[0].geometry.location); 
     map.setZoom(17)     
    } 
    else { 
     alert("Geocode was not successful for the following reason: " + status); 
    } 
    }); 
} 

function clearmarkers() { 
    if (gmarkers) { 
    for (i in gmarkers) { 
     gmarkers[i].setMap(null); 
    } 
    gmarkers.length = 0; 
    } 
} 


function checkpoint(marker) { 
    var LNum; 
    var point = marker.getPosition(); 
    for (var i=0; i<polys.length; i++) {   
    if (polys[i].containsLatLng(point)) { 
      Lnum = i; 
      i = 999; // Jump out of loop 
      } 
     else { 
      Lnum = 99 
     } 
    } 
    return Lnum 
}; 

// Polygon getBounds extension - google-maps-extensions 
// http://code.google.com/p/google-maps-extensions/source/browse/google.maps.Polygon.getBounds.js 
if (!google.maps.Polygon.prototype.getBounds) { 
    google.maps.Polygon.prototype.getBounds = function(latLng) { 
    var bounds = new google.maps.LatLngBounds(); 
    var paths = this.getPaths(); 
    var path; 

    for (var p = 0; p < paths.getLength(); p++) { 
    path = paths.getAt(p); 
    for (var i = 0; i < path.getLength(); i++) { 
     bounds.extend(path.getAt(i)); 
    } 
    } 

    return bounds; 
    } 
} 

// Polygon containsLatLng - method to determine if a latLng is within a polygon 
google.maps.Polygon.prototype.containsLatLng = function(latLng) { 
// Exclude points outside of bounds as there is no way they are in the poly 
var bounds = this.getBounds(); 

if(bounds != null && !bounds.contains(latLng)) { 
    return false; 
} 

// Raycast point in polygon method 
var inPoly = false; 

var numPaths = this.getPaths().getLength(); 
for(var p = 0; p < numPaths; p++) { 
    var path = this.getPaths().getAt(p); 
    var numPoints = path.getLength(); 
    var j = numPoints-1; 

    for(var i=0; i < numPoints; i++) { 
    var vertex1 = path.getAt(i); 
    var vertex2 = path.getAt(j); 

    if (vertex1.lng() < latLng.lng() && vertex2.lng() >= latLng.lng() || vertex2.lng() < latLng.lng() && vertex1.lng() >= latLng.lng()) { 
     if (vertex1.lat() + (latLng.lng() - vertex1.lng())/(vertex2.lng() - vertex1.lng()) * (vertex2.lat() - vertex1.lat()) < latLng.lat()) { 
     inPoly = !inPoly; 
     } 
    } 

    j = i; 
    } 
} 

return inPoly; 
} 

答えて

0

試しは形を退治し、代わりのonClickの設定 '行くには!'ボタンを押してshowAddress()を呼び出します。 IE7、Chrome、Firefoxでこれをテストしたところ、うまくいきました。

+0

お返事ありがとうございます。私はフォームからonsubmitとaction要素を削除し、あなたが言ったようにonclickを設定しましたが、それは仕事をしませんでした。私は最終的にフォームを完全に削除し、入力フィールドを "div"タグに入れました。乾杯。 – Dayo

0

jQueryを使用して初期化コードを実行し、ajaxを試してみてください。代わりにbody.onloadを使用しての、この使用:問題は、フォームをサーバーに送信し、ページのリロードを引き起こしているということであるならば、あなたは返す必要が

$.ajax({ 
    url: "xmloutput2.xml", 
    success: function(data){ 
    // handle result 
    } 
}); 

$(function(){ 
    initialize(); 
}) ; 

とAJAXのために")(showAddressを返す;" showAddress()関数からfalseを、とのonSubmit =使用:

<form onsubmit="return showAddress();" action="#"> 
    <input id="search" size="60" type="text" value="" /> 
    <input type="submit" value="Go!" /> 
    <input type="button" onclick="clearmarkers();" value="Clear markers" /> 
</form> 

... 

function showAddress() { 
    .... 
    return false ; 
} 
+0

こんにちは、私はJqueryライブラリを読み込んでbody.onload関数を削除し、上記の提案で初期化関数とmicroajaxスクリプトを置き換えましたが、これは問題を解決しませんでした。 Jqueryはブラウザ間のスクリプトですか?とにかく助けてくれてありがとうございます。 – Dayo

+0

はい、jQueryはクロスブラウザです。あなたの最新のコードと多分サンプルのxmloutput2.xmlファイルを投稿して問題を再現することができますか?また、IE開発ツールを使用して、コンソールにjavascriptエラーが発生していないかどうか確認してください。 – RussSchick

+0

フォームをサーバーに送信しないようにするには、showAddress()からfalseを返す必要があり、ページをリロードする必要があると思います。 – RussSchick

0

はバージョン

<script type="text/javascript" src="http://maps.google.com/maps/api/js?v=3.19"></script> 

バージョンを指定しない場合はあなたが実験バージョンを取得を指定してみてください。私は実験版にIE11で問題があることを発見しました

関連する問題