You need to sign in to do that
Don't have an account?
pixelriese
Calculate the exact distance between a lead and an list of accounts.
Hello, i have the problem that i would like to calucute exact distance between a lead and a list of accounts. I'm currently use a visual force page with a map component and i am use a standard function distance() to calculate the distance. Has someone an idea how to solve this issue? I would like to use a JavaScript-FrameWork or google Maps API.
This below code will work.As here me calculating distance between source and destination using javscript.You try out the below code
<apex:page >
<style>
span, input {
margin: 5px;
padding-right:10px;
}
</style>
<script type="text/javascript" src="https://maps.googleapis.com/maps/api/js?sensor=false&libraries=places"></script>
<script type="text/javascript">
var source, destination;
var directionsDisplay;
var directionsService = new google.maps.DirectionsService();
var geocoder = new google.maps.Geocoder();
google.maps.event.addDomListener(window, 'load', function () {
new google.maps.places.SearchBox(document.getElementById('txtSource'));
new google.maps.places.SearchBox(document.getElementById('txtDestination'));
directionsDisplay = new google.maps.DirectionsRenderer({ 'draggable': true });
});
function GetRoute() {
var india = new google.maps.LatLng(20.5937, 78.9629);
var mapOptions = {
zoom: 7,
center: india
};
map = new google.maps.Map(document.getElementById('dvMap'), mapOptions);
directionsDisplay.setMap(map);
directionsDisplay.setPanel(document.getElementById('dvPanel'));
//*********DIRECTIONS AND ROUTE**********************//
source = document.getElementById("txtSource").value;
destination = document.getElementById("txtDestination").value;
var request = {
origin: source,
destination: destination,
travelMode: google.maps.TravelMode.DRIVING
};
directionsService.route(request, function (response, status) {
if (status == google.maps.DirectionsStatus.OK) {
directionsDisplay.setDirections(response);
}
});
//*********DISTANCE AND DURATION**********************//
var service = new google.maps.DistanceMatrixService();
service.getDistanceMatrix({
origins: [source],
destinations: [destination],
travelMode: google.maps.TravelMode.DRIVING,
unitSystem: google.maps.UnitSystem.METRIC,
avoidHighways: false,
avoidTolls: false
}, function (response, status) {
if (status == google.maps.DistanceMatrixStatus.OK && response.rows[0].elements[0].status != "ZERO_RESULTS") {
var distance = response.rows[0].elements[0].distance.text;
var duration = response.rows[0].elements[0].duration.text;
var dvDistance = document.getElementById("dvDistance");
dvDistance.innerHTML = "";
dvDistance.innerHTML += "Distance: " + distance + "<br />";
dvDistance.innerHTML += "Duration:" + duration;
} else {
alert("Unable to find the distance via road.");
}
});
}
function GetLocation() {
var address = document.getElementById("txtSource").value;
geocoder.geocode({ 'address': address }, function (results, status) {
if (status == google.maps.GeocoderStatus.OK) {
var latitude = results[0].geometry.location.lat();
var longitude = results[0].geometry.location.lng();
document.getElementById("latitude1").value=latitude;
document.getElementById("longitude1").value=longitude;
alert("Latitude: " + latitude + "\nLongitude: " + longitude);
} else {
alert("Request failed.")
}
});
};
function GetLocation1() {
var address = document.getElementById("txtDestination").value;
geocoder.geocode({ 'address': address }, function (results, status) {
if (status == google.maps.GeocoderStatus.OK) {
var latitude = results[0].geometry.location.lat();
var longitude = results[0].geometry.location.lng();
document.getElementById("latitude2").value=latitude;
document.getElementById("longitude2").value=longitude;
alert("Latitude: " + latitude + "\nLongitude: " + longitude);
} else {
alert("Request failed.")
}
});
};
</script>
<table border="0" cellpadding="0" cellspacing="3">
<tr>
<td colspan="3">
Source
<input type="text" id="txtSource" value="" style="width: 200px" onChange="GetLocation();"/>
Destination
<input type="text" id="txtDestination" value="" style="width: 200px" onChange="GetLocation1();"/>
<input type="button" value="Get Route" onclick="GetRoute()" />
<hr />
</td>
</tr>
<tr>
<td colspan="2">
<div id="dvDistance">
</div>
</td>
</tr>
<tr>
<td>
<div id="dvMap" style="width: 500px; height: 200px">
</div>
</td>
<!-- <td>
<div id="dvPanel" style="width: 200px; height: 200px">
</div>
</td> -->
</tr>
</table>
</apex:page>
If you get solved with issues please mark it as best answer So others can use it