2009-08-29 23 views
5

Korzystam z interfejsu Google Maps API, aby uzyskać odległość między dwoma brytyjskimi kodami pocztowymi.odległość między 2 kodami pocztowymi

var yourPostcode = $("#YourPostcode").val(); 
     var restaurantPostcode = $("#Postcode").val(); 

     var point1 = GetPointFromPostcode(yourPostcode); 
     var point2 = GetPointFromPostcode(restaurantPostcode); 

     var distance = point1.distanceFrom(point2, 3959).toFixed(1); 

Jednak funkcja GetPoint wzywa Google API asynchronicznie i tak przez odległości czasowej oblicza punkt 1 i 2 nie zostały ustalone (Wierzę, że to, co się dzieje?)

ja również umieścić powiadomienia po każdym oświadczenie, aby sprawdzić wartość zmiennych i robi to dostałem odległość, aby być prawidłową wartością, czekając na mnie, aby kliknąć OK musi mieć wystarczająco dużo czasu, aby uzyskać wyniki? Choć nie ma tego robić :(

Tutaj jest funkcja punktu get

function GetPointFromPostcode(postcode) { 
    var point; 
    localSearch.execute(postcode + ", UK"); 
    if (localSearch.results[0]) { 
     var resultLat = localSearch.results[0].lat; 
     var resultLng = localSearch.results[0].lng; 

     point = new GLatLng(resultLat, resultLng); 

    } else { 
     $(".PostcodeError").append("Postcode Invalid"); 
    } 
    return point; 
} 

wiem, że mogę ustawić zwrotnego na lokalnym poszukiwaniu nazywać kiedy wyniki wrócić, ale problemem jest to, istnieją 2 wyszukiwań.

Co chcę jest tylko zadzwonić do linii oblicz odległość po obu wyszukiwań wrócili wyników.

Czy wiesz, w jaki sposób mogę to zrobić?

Dzięki

Odpowiedz

4

Jeśli jesteś w stanie uzyskać współrzędne GPS (szerokość i długość geograficzna) dla każdego kodu pocztowego, zbuduj funkcję odległości Javascript.

Znajdź go jako here w języku C#, ale koncepcja jest taka sama, jeśli chcesz ją odtworzyć w JS.

0

To może zadziałać - zasadniczo zmieniając ustawienie setSearchCompleteCallback na inne, w zależności od tego, czy szuka pierwszego, czy drugiego kodu pocztowego.

var searchControl= new google.search.SearchControl(); 
var distanceSearch = new google.search.LocalSearch(); 
searchControl.addSearcher(distanceSearch); 

distanceSearch.setSearchCompleteCallback(null, function() { 
    if(distanceSearch.results.length > 0 && distanceSearch.postcode2) 
    { 
     distanceSearch.point1 = new GLatLng(distanceSearch.results[0].lat, distanceSearch.results[0].lng) 
     var postcode2 = distanceSearch.postcode2; 
     distanceSearch.postcode2 = null;    
     distanceSearch.execute(postcode2 + ", UK"); 
    } else if (distanceSearch.results.length > 0 && !distanceSearch.postcode2) { 
     distanceSearch.point2 = new GLatLng(distanceSearch.results[0].lat, distanceSearch.results[0].lng) 
     //some code to calculate distance and write it to somewhere 
    } else { 
     //no search results 
    } 
}); 

function measureDistance(postcode1, postcode2) { 
    distanceSearch.postcode2 = postcode2; 
    distanceSearch.execute(postcode1 + ", UK"); 
} 
Powiązane problemy