Google Maps API v3: события кликов, не запускаемые в Firefox для пользовательского маркера - PullRequest
10 голосов
/ 20 августа 2010

создали карту, которую я пытаюсь использовать, как в «Моих картах». У меня есть два выпадающих списка на правой стороне, в зависимости от выбора в этих ddl, вы можете добавить собственный маркер / значок. Вы выбираете тип маркера, затем нажимаете кнопку «+» в верхнем правом углу карты и затем нажимаете место, куда вы хотите добавить маркер. Моя проблема в том, что это нормально работает в IE, Safari и Chrome, но не в Firefox. Событие щелчка, похоже, не срабатывает.

Вот местоположение карты: https://ait.saultcollege.ca/Michael.Armstrong/Index.html

Кнопка добавления маркера в правом верхнем углу имеет событие onclick, указывающее на мою функцию placeMarker (). Вот код для placeMarker (), createMarker () ...

function placeMarker() {

    select("placeMarker");

    var infowindow = new google.maps.InfoWindow({}); 
    var catID = document.getElementById('category');
    var typeID = document.getElementById('ddlType');
    var category = catID.options[catID.selectedIndex].value;
    var markerType = typeID.options[typeID.selectedIndex].value;

    if (!markerType) {
        alert("You must select an icon type.");
    } 
    else {
        var moveListener = google.maps.event.addListener(customMap, 'mousemove', function(event) {
            if (mapMarker) {
                mapMarker.setPosition(event.latLng);
            } else {
                mapMarker = createMarker(event.latLng, "test", markerType, "test");
            }
        });

        var clickListener = google.maps.event.addListener(customMap, 'click', function(event) {
            if (mapMarker) {
                select("hand_b");
                google.maps.event.clearListeners(customMap, 'mousemove');
                google.maps.event.removeListener(listener);
                mapMarker = createMarker(event.latLng, "test2", markerType, "test");

                var htmlInfo = "" +
                    "Category:" + category + "" +
                    "Item:" + markerType + "" +
                    "Notes:" +
                    "Location:" + mapMarker.getPosition().toString() + "" +
                    "" +
                    "";

                //infowindow.setContent(htmlInfo);
                //infowindow.open(customMap, mapMarker);
            }
        });
    }
}

function createMarker(latlng, title, icon, html) {
    var mapMarker = new google.maps.Marker({
        position: latlng,
        map: customMap,
        title: title,
        icon: 'Images/' + icon + '.png'
    });
    return mapMarker;
}

function select(buttonId) {
    document.getElementById("hand_b").className = "unselected";
    document.getElementById("placeMarker").className = "unselected";
    document.getElementById(buttonId).className = "selected";
}

Любая помощь или предложения будут великолепны. Может ли это быть ошибкой в ​​ff?

1 Ответ

1 голос
/ 02 ноября 2010

Я сделал что-то очень похожее для пакета программного обеспечения с открытым исходным кодом. В этом случае давайте предположим, что я выбрал «Огонь» в раскрывающемся меню, и это вызывает addFire (). Слушатель на маркерах удалит точку одним щелчком мыши или позволит перетащить ее. На карте одновременно может быть только один прослушиватель, но у каждого маркера все же может быть свой слушатель одновременно.

Вот код, который работал на Chrome, Firefox и IE8:

//This function sets up the map for adding a fire icon
function addFire() {
 //Kill old listener
 if(listening)
  google.maps.event.removeListener(listenerhandle);

 //Start new listener
 listenerhandle = google.maps.event.addListener(disasterMap, 'click', addFirePoint);
 listening = true;
}//end addFire

//This function adds new fire points to the map and controls dragging and clicking
function addFirePoint(event) {
 //Create the marker
 var fireMarker = new google.maps.Marker({
  icon: "./mapimgs/fire.png", position: event.latLng, map: disasterMap, draggable: true });

 newFireMarkers.push(fireMarker);
 fireMarker.setTitle("Fire");

 //Listen for clicks on the new marker
 google.maps.event.addListener(fireMarker, 'click', function() {
      fireMarker.setMap(null);
   //remove the marker from the array
   for(i=0;i
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...