function addMarkers(){
mySelect = document.getElementById('selection');
Greenwood = [];Franklin = [];Edinburgh = [];mySelect.options[mySelect.options.length] = new Option("Edinburgh schools",'all=Edinburgh');
mySelect.options[mySelect.options.length] = new Option("Franklin schools",'all=Franklin');
mySelect.options[mySelect.options.length] = new Option("Greenwood schools",'all=Greenwood');
mySelect.options[mySelect.options.length] = new Option("---------------------------",'');
Greenwood[Greenwood.length] = createMarker(new GPoint(-86.21160100,39.61837700),"
",iconGr);
mySelect.options[mySelect.options.length] = new Option("Adventures Child Care & Learning",'Greenwood=' + Greenwood.length);
Franklin[Franklin.length] = createMarker(new GPoint(-86.07797000,39.48090900),"",iconGr);
mySelect.options[mySelect.options.length] = new Option("Discovery Child Development Center",'Franklin=' + Franklin.length);
Greenwood[Greenwood.length] = createMarker(new GPoint(-86.08307800,39.61019600),"",iconGr);
mySelect.options[mySelect.options.length] = new Option("Especially Kids Inc",'Greenwood=' + Greenwood.length);
Greenwood[Greenwood.length] = createMarker(new GPoint(-86.15500200,39.62135800),"",iconGr);
mySelect.options[mySelect.options.length] = new Option("Greenwood Christian Academy",'Greenwood=' + Greenwood.length);
Greenwood[Greenwood.length] = createMarker(new GPoint(-86.12062100,39.58719600),"",iconGr);
mySelect.options[mySelect.options.length] = new Option("Greenwood Christian School",'Greenwood=' + Greenwood.length);
Greenwood[Greenwood.length] = createMarker(new GPoint(-86.11402000,39.62609600),"",iconGr);
mySelect.options[mySelect.options.length] = new Option("Greenwood Montessori Primary",'Greenwood=' + Greenwood.length);
Greenwood[Greenwood.length] = createMarker(new GPoint(-86.13694000,39.62810000),"",iconGr);
mySelect.options[mySelect.options.length] = new Option("Meridian Academy Of Arts",'Greenwood=' + Greenwood.length);
Greenwood[Greenwood.length] = createMarker(new GPoint(-86.10612100,39.60663700),"",iconGr);
mySelect.options[mySelect.options.length] = new Option("Our Lady Of Greenwood School",'Greenwood=' + Greenwood.length);
Franklin[Franklin.length] = createMarker(new GPoint(-86.08022000,39.48263700),"",iconGr);
mySelect.options[mySelect.options.length] = new Option("St. Rose Of Lima School",'Franklin=' + Franklin.length);
Edinburgh[Edinburgh.length] = createMarker(new GPoint(-85.96758400,39.34801600),"",iconGr);
mySelect.options[mySelect.options.length] = new Option("Tabernacle Christian School",'Edinburgh=' + Edinburgh.length);
} // End addStateMarkers JavaScript Function
// Takes an array of markers and centers/zooms map based on marker range
function centerByArray(myArray, recenter, newMaxMin)
{
if (newMaxMin == true)
reMaxMin(myArray);
for (var i = 0; i < myArray.length; i++)
{
var markLng = myArray[i].getPoint().x;
var markLat = myArray[i].getPoint().y;
if (markLat > maxLat) maxLat = markLat;
if (markLng > maxLng) maxLng = markLng;
if (markLat < minLat) minLat = markLat;
if (markLng < minLng) minLng = markLng;
}
if (recenter)
reCenterMap();
}
// Reinit max/mins
function reMaxMin(myArray)
{
maxLng = myArray[0].getPoint().x;
maxLat = myArray[0].getPoint().y;
minLng = myArray[0].getPoint().x;
minLat = myArray[0].getPoint().y;
}
// Recenter map based on global max/mins
function reCenterMap()
{
var bounds = new GLatLngBounds();
bounds.extend(new GLatLng(minLat, minLng));
bounds.extend(new GLatLng(maxLat, maxLng));
var center_lat = (bounds.getNorthEast().lat() + bounds.getSouthWest().lat()) / 2.0;
var center_lng = (bounds.getNorthEast().lng() + bounds.getSouthWest().lng()) / 2.0;
var center = new GLatLng(center_lat, center_lng);
var zoom = map.getBoundsZoomLevel(bounds);
map.setCenter(center,zoom);
//map.setCenter(center,11);
/*
var center = new GPoint( (maxLng + minLng)/2, (maxLat+minLat)/2 );
var delta = new GSize(maxLng - minLng, maxLat - minLat);
var minZoom = map.spec.getLowestZoomLevel(center, delta, map.viewSize);
if (minZoom < 4) minZoom = 4; // Lowest possible zoom is 4
map.centerAndZoom(center, minZoom);
*/
}
// Fires when drop down list of schools changes
function selectChange(selection)
{
var myVal = selection.options[selection.selectedIndex].value;
map.closeInfoWindow();
// Add entire array based on variable type
if (myVal.indexOf('all') != -1 && myVal != 'all')
{
var temp = myVal.split('=');
var showArray = temp[1];
// If Array is > X amount of markers, then open in a new page
if (eval(showArray).length > 20)
// New window depends on whether or not we're on the search page
if (location.href.indexOf('nearby_schools.php') == -1)
window.open(location.href + '/map/' + showArray);
else
window.open('/search/////1/' + showArray);
map.removeOverlays(Edinburgh);
map.removeOverlays(Franklin);
map.removeOverlays(Greenwood);
map.addOverlays(eval(showArray));
centerByArray(eval(showArray), true, true); // Center and zoom on set of markers
}
// Add individual markers
if (myVal.indexOf('all') == -1 && myVal != 'all' && myVal.length)
{
var temp = myVal.split('=');
var myArray = temp[0];
var myIndex = parseInt(temp[1]) - 1;
document.getElementById('map').width = "750";
map.removeOverlay(eval(myArray)[myIndex]);
map.addOverlay(eval(myArray)[myIndex]);
GEvent.trigger(eval(myArray)[myIndex],'click');
}
// Show all markers
if (myVal == 'all')
{
cntMarker = 0;
reMaxMin(Greenwood);map.removeOverlays(Edinburgh);
map.removeOverlays(Franklin);
map.removeOverlays(Greenwood);
map.addOverlays(Edinburgh);
centerByArray(Edinburgh, false, false);
cntMarker += Edinburgh.length;
map.addOverlays(Franklin);
centerByArray(Franklin, false, false);
cntMarker += Franklin.length;
map.addOverlays(Greenwood);
centerByArray(Greenwood, false, false);
cntMarker += Greenwood.length;
centerByArray(Greenwood,true, false);
if (cntMarker > 20)
// New window depends on whether or not we're on the search page
if (location.href.indexOf('schools-by-distance') == -1)
window.open(location.href + '/map/all');
else
window.open('/search////all');
//window.open('/map.php?type=1&schools=&school_level=1&radius=&zipcode=&school_type_search=&school_type_code=');
}
}
function createMarker(point, label, icon)
{
var marker = new GMarker(point, icon);
var html = label;
GEvent.addListener(marker, "click", function() {
marker.openInfoWindowHtml(html);
});
return marker;
}