Додавання ідентифікаторів до маркерів Google Map


82

У мене є сценарій, який циклічно додає маркери по черзі.

Я намагаюся, щоб поточний маркер мав інформаційне вікно і мав одночасно лише 5 маркерів на карті (4 без інформаційних вікон та 1 з)

Як мені додати ідентифікатор до кожного маркера, щоб я міг видаляти та закривати інформаційні вікна за необхідності.

Це функція, яку я використовую для встановлення маркера:

function codeAddress(address, contentString) {

var infowindow = new google.maps.InfoWindow({
  content: contentString
});

if (geocoder) {

  geocoder.geocode( { 'address': address}, function(results, status) {

    if (status == google.maps.GeocoderStatus.OK) {

        map.setCenter(results[0].geometry.location);

       var marker = new google.maps.Marker({
          map: map, 
          position: results[0].geometry.location
       });

       infowindow.open(map,marker);

      } else {
       alert("Geocode was not successful for the following reason: " + status);
      }
    });
  }

}

Відповіді:


193

JavaScript - це динамічна мова. Ви можете просто додати його до самого об’єкта.

var marker = new google.maps.Marker(markerOptions);
marker.metadata = {type: "point", id: 1};

Крім того, оскільки всі v3 об’єкти розширюються MVCObject(). Ви можете використовувати:

marker.setValues({type: "point", id: 1});
// or
marker.set("type", "point");
marker.set("id", 1);
var val = marker.get("id");

11
Мені цікаво, як тільки ви надасте ідентифікатори маркерів, як ви хочете отримати доступ до цих маркерів поза полотном карти. $ ('# 1'). DoSomething (); наприклад?
willdanceforfun

@willdanceforfun Додайте подію натискання до маркера та отримайте інформацію про this:google.maps.event.addListener(yourMarker, 'click', function (event) { console.log(this); });
Mayeenul Islam

15

Просто додавши інше рішення, яке працює для мене .. Ви можете просто додати його в параметри маркера:

var marker = new google.maps.Marker({
    map: map, 
    position: position,

    // Custom Attributes / Data / Key-Values
    store_id: id,
    store_address: address,
    store_type: type
});

А потім отримайте їх за допомогою:

marker.get('store_id');
marker.get('store_address');
marker.get('store_type');

Це допомогло купу. Жоден із прикладів цього не мав. Добре підходить для передачі значень споживання за допомогою функцій повернення кліків.
cngodles

2

У мене є простий Locationклас, який я використовую для обробки всіх своїх речей, пов’язаних із маркерами. Я вставлю свій код нижче, щоб ви могли його розглянути.

Останній рядок - це те, що насправді створює об’єкти маркера. Він циклічно переглядає деякі JSON моїх розташувань, які виглядають приблизно так:

{"locationID":"98","name":"Bergqvist Järn","note":null,"type":"retail","address":"Smidesvägen 3","zipcode":"69633","city":"Askersund","country":"Sverige","phone":"0583-120 35","fax":null,"email":null,"url":"www.bergqvist-jb.com","lat":"58.891079","lng":"14.917371","contact":null,"rating":"0","distance":"45.666885421019"}

Ось код:

Якщо ви подивитеся на target()метод у моєму класі Location, то побачите, що я зберігаю посилання на інформаційне вікно і можу просто open()і close()їх через посилання.

Дивіться демонстрацію в прямому ефірі: http://ww1.arbesko.com/en/locator/ (введіть шведське місто, наприклад, Стокгольм, і натисніть Enter)

var Location = function() {
    var self = this,
        args = arguments;

    self.init.apply(self, args);
};

Location.prototype = {
    init: function(location, map) {
        var self = this;

        for (f in location) { self[f] = location[f]; }

        self.map = map;
        self.id = self.locationID;

        var ratings = ['bronze', 'silver', 'gold'],
            random = Math.floor(3*Math.random());

        self.rating_class = 'blue';

        // this is the marker point
        self.point = new google.maps.LatLng(parseFloat(self.lat), parseFloat(self.lng));
        locator.bounds.extend(self.point);

        // Create the marker for placement on the map
        self.marker = new google.maps.Marker({
            position: self.point,
            title: self.name,
            icon: new google.maps.MarkerImage('/wp-content/themes/arbesko/img/locator/'+self.rating_class+'SmallMarker.png'),
            shadow: new google.maps.MarkerImage(
                                        '/wp-content/themes/arbesko/img/locator/smallMarkerShadow.png',
                                        new google.maps.Size(52, 18),
                                        new google.maps.Point(0, 0),
                                        new google.maps.Point(19, 14)
                                    )
        });

        google.maps.event.addListener(self.marker, 'click', function() {
            self.target('map');
        });

        google.maps.event.addListener(self.marker, 'mouseover', function() {
            self.sidebarItem().mouseover();
        });

        google.maps.event.addListener(self.marker, 'mouseout', function() {
            self.sidebarItem().mouseout();
        });

        var infocontent = Array(
            '<div class="locationInfo">',
                '<span class="locName br">'+self.name+'</span>',
                '<span class="locAddress br">',
                    self.address+'<br/>'+self.zipcode+' '+self.city+' '+self.country,
                '</span>',
                '<span class="locContact br">'
        );

        if (self.phone) {
            infocontent.push('<span class="item br locPhone">'+self.phone+'</span>');
        }

        if (self.url) {
            infocontent.push('<span class="item br locURL"><a href="http://'+self.url+'">'+self.url+'</a></span>');
        }

        if (self.email) {
            infocontent.push('<span class="item br locEmail"><a href="mailto:'+self.email+'">Email</a></span>');
        }

        // Add in the lat/long
        infocontent.push('</span>');

        infocontent.push('<span class="item br locPosition"><strong>Lat:</strong> '+self.lat+'<br/><strong>Lng:</strong> '+self.lng+'</span>');

        // Create the infowindow for placement on the map, when a marker is clicked
        self.infowindow = new google.maps.InfoWindow({
            content: infocontent.join(""),
            position: self.point,
            pixelOffset: new google.maps.Size(0, -15) // Offset the infowindow by 15px to the top
        });

    },

    // Append the marker to the map
    addToMap: function() {
        var self = this;

        self.marker.setMap(self.map);
    },

    // Creates a sidebar module for the item, connected to the marker, etc..
    sidebarItem: function() {
        var self = this;

        if (self.sidebar) {
            return self.sidebar;
        }

        var li = $('<li/>').attr({ 'class': 'location', 'id': 'location-'+self.id }),
            name = $('<span/>').attr('class', 'locationName').html(self.name).appendTo(li),
            address = $('<span/>').attr('class', 'locationAddress').html(self.address+' <br/> '+self.zipcode+' '+self.city+' '+self.country).appendTo(li);

        li.addClass(self.rating_class);

        li.bind('click', function(event) {
            self.target();
        });

        self.sidebar = li;

        return li;
    },

    // This will "target" the store. Center the map and zoom on it, as well as 
    target: function(type) {
        var self = this;

        if (locator.targeted) {
            locator.targeted.infowindow.close();
        }

        locator.targeted = this;

        if (type != 'map') {
            self.map.panTo(self.point);
            self.map.setZoom(14);
        };

        // Open the infowinfow
        self.infowindow.open(self.map);
    }
};

for (var i=0; i < locations.length; i++) {
    var location = new Location(locations[i], self.map);
    self.locations.push(location);

    // Add the sidebar item
    self.location_ul.append(location.sidebarItem());

    // Add the map!
    location.addToMap();
};

Це не відповідає на питання. Зовсім.
MrUpsidown

1

Чому б не використовувати кеш, який зберігає кожен об’єкт маркера та посилається на ідентифікатор?

var markerCache= {};
var idGen= 0;

function codeAddress(addr, contentStr){
    // create marker
    // store
    markerCache[idGen++]= marker;
}

Змінити: звичайно, це покладається на числову систему індексів, яка не пропонує властивість length як масив. Звичайно, ви можете прототипувати об'єкт Object і створити довжину тощо для такої речі. OTOH, генерування унікального значення ідентифікатора (MD5 тощо) кожної адреси може бути правильним шляхом.


-2

Маркер вже має унікальний ідентифікатор

marker.__gm_id

Єдине рішення, яке я б використав із них.
clime

2
Подвійне підкреслення та gmпрефікс повинні вказувати вам, що це приватна змінна, яка не гарантує. Уникайте цього.
Lee Goddard
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.