Feeling a bit overwhelmed with the project I'm working on, but hoping for some guidance.
We're aiming to create a form where users input a starting point and an ending point, similar to the examples on Google Maps (http://code.google.com/apis/maps/documentation/examples/directions-advanced.html). This form should then output a map displaying the route, along with the total number of kilometers between the two points.
The challenge here is converting those kilometers into dollars.
While this seems feasible, there are additional variables to consider, such as the number of passengers (to be selected from a dropdown menu).
I'm unsure about merging all these components together. Should I create a custom form or utilize PHP? I'm feeling lost. Any suggestions on how to proceed?
For context: assume 1 km = $100, and each additional person beyond the first will add $100 to the total cost.
So, for example, 20 km with 2 persons would amount to $300.
Questions:
- Is it possible to embed variables within the Google code?
- What would be the ideal format for calling upon the form?
Thank you in advance for your assistance.
Google Code
var map; var gdir; var geocoder = null; var addressMarker; function initialize() { if (GBrowserIsCompatible()) { map = new GMap2(document.getElementById("map_canvas")); gdir = new GDirections(map, document.getElementById("directions")); GEvent.addListener(gdir, "load", onGDirectionsLoad); GEvent.addListener(gdir, "error", handleErrors); setDirections("San Francisco", "Mountain View", "en_US"); } } function setDirections(fromAddress, toAddress,
locale) { gdir.load("from: " + fromAddress + " to: " + toAddress, { "locale": locale }); }
function handleErrors(){ if (gdir.getStatus().code == G_GEO_UNKNOWN_ADDRESS) alert("No corresponding geographic location could be found for
one of the specified addresses. This may be due to the fact that the address is relatively new, or it may be incorrect.\nError code: " + gdir.getStatus().code); else if (gdir.getStatus().code == G_GEO_SERVER_ERROR) alert("A geocoding or directions request could not be successfully processed, yet the exact reason for the failure is not known.\n Error code: " + gdir.getStatus().code);
else if (gdir.getStatus().code == G_GEO_MISSING_QUERY) alert("The HTTP q parameter was either missing or had no value. For
geocoder requests, this means that an empty address was specified as input. For directions requests, this means that no query was specified in the input.\n Error code: " + gdir.getStatus().code);
// else if (gdir.getStatus().code == G_UNAVAILABLE_ADDRESS) <--- Doc bug... this is either not defined, or Doc is wrong // alert("The geocode for the given address or the route for the given directions query cannot be returned due to legal or contractual reasons.\n Error code: " + gdir.getStatus().code);
else if (gdir.getStatus().code == G_GEO_BAD_KEY) alert("The given key is either invalid or does not match the domain
for which it was given. \n Error code: " + gdir.getStatus().code);
else if (gdir.getStatus().code == G_GEO_BAD_REQUEST) alert("A directions request could not be successfully parsed.\n
Error code: " + gdir.getStatus().code);
else alert("An unknown error occurred."); }
function onGDirectionsLoad(){ // Use this function to access information about the latest load() // results.
// e.g. // document.getElementById("getStatus").innerHTML
= gdir.getStatus().code; // and yada yada yada...