按钮点击隐藏谷歌地图标记

Button click hide Google map markers

本文关键字:地图 图标 谷歌 隐藏 按钮      更新时间:2023-09-26

我写了下面的代码,当点击id = "showmarkers"的按钮时,它会在谷歌地图上显示标记。

我想发生的是,当再次单击相同的按钮时(或者当单击另一个按钮时,id ="隐藏标记"),标记将隐藏。

任何帮助将不胜感激,谢谢

$(document).ready(function() {
$("#map").css({
    height: 500,
    width: 600
});
var myLatLng = new google.maps.LatLng(51.50754,-0.127894);
    MYMAP.init('#map', myLatLng, 13);
$("#showmarkers").click(function(e){
    MYMAP.placeMarkers('markers.xml');
});
});
var MYMAP = {
    map: null,
bounds: null
    }
MYMAP.init = function(selector, latLng, zoom) {
var myOptions = {
zoom:zoom,
center: latLng,
mapTypeId: google.maps.MapTypeId.ROADMAP
}
this.map = new google.maps.Map($(selector)[0], myOptions);
this.bounds = new google.maps.LatLngBounds();
}
MYMAP.placeMarkers = function(filename) {
$.get(filename, function(xml){
    $(xml).find("marker").each(function(){
        var name = $(this).find('name').text();
        var address = $(this).find('address').text();
        var lat = $(this).find('lat').text();
        var lng = $(this).find('lng').text();
        var point = new google.maps.LatLng(parseFloat(lat),parseFloat(lng));
        MYMAP.bounds.extend(point);
        var marker = new google.maps.Marker({
            position: point,
            map: MYMAP.map
        });
        var infoWindow = new google.maps.InfoWindow();
        var html='<strong>'+name+'</strong.><br />'+address;
        google.maps.event.addListener(marker, 'click', function() {
            infoWindow.setContent(html);
            infoWindow.open(MYMAP.map, marker);
        });
    });
});
}

你可以有一个布尔标志'shouldHideMarkers'并检查它是否为真,所以隐藏它们,或者假,所以显示它们。请记住,如果要从地图中删除标记,则应将其 Map 属性设置为 null。最好的方法是将所有标记变量存储到一个数组中并遍历数组,以便将其映射属性设置为 null 以隐藏它们