使用onClick事件显示不同的地图 - Google Maps V3。

时间:2014-01-02 16:21:58

标签: javascript jquery html google-maps google-maps-api-3

尝试根据点击事件显示4个不同的地图。虽然我确实发生了这种特殊的交互,但地图本身没有正确居中,也无法在中心SCREENSHOT HERE中实际加载地图。

我目前设法做到这一点的方式有点像黑客,因为我不是最好的JS和谷歌地图集成相当新,所以原谅如果代码是垃圾。随意提供更好,更优雅的解决方案。

到目前为止,我已经这样做了: - 创建并初始化了四个不同的地图。 - 使用关联地图绘制相关标记(用餐地图获取餐厅位置等)。 - 单击相关导航元素时,应显示地图(单击用餐,用餐地图显示)

这样可行,但地图显示不正确。 LIVE DEMO

HTML:

<section class="recommend-map">
      <div class="col-one">
        <h1>Recommends Map</h1>
        <ul>
            <li><a href="#" class="map-canvas">Map 1</a></li>
            <li><a href="#" class="map-canvas-2">Map 2</a></li>
            <li><a href="#" class="map-canvas-3">Map 3</a></li>
            <li><a href="#" class="map-canvas-4">Map 4</a></li>
          </ul>
      </div>
      <div class="col-two">
        <div class="content1" id="map-canvas" style="width: 550px; height: 300px;" data-location="javitz">
        </div>
        <div class="content2" id="map-canvas-2" style="width: 550px; height: 300px;" data-location="javitz">
        </div>  
        <div class="content3" id="map-canvas-3" style="width: 550px; height: 300px;" data-location="pier92">
        </div>
        <div class="content4" id="map-canvas-4" style="width: 550px; height: 300px;" data-location="pier94">
        </div>
      </div>
    </section>

JS:

function initialize() {
// removed actual array data for brevity, it was a lot. 

var dining = [
      ["Yankee Stadium",  40.829584,-73.927571],
      ["South Street Seaport", 40.70514,-74.008734],
      ["Musical", 40.762341,-73.978329],
      ["Frick collection!", 40.771385,-73.967171]
      ];

var drinks = [
     ["Central Park ", 40.78678,-73.966312],
     ["Broadway Shows",  40.765461,-73.984337],
     ["Broadway musicals", 40.762471,-73.970947],
     ["Musical", 40.736169,-74.001621]
     ];

var roofOutdoor = [
      ["The Ballet",  40.73495,-73.998671],
      ["Central Park",  40.78678,-73.966312],
      ["Broadway shows",  40.756685,-73.987813],
      ["Galapagos artspaace",   40.703871,-73.990924]
      ];

var leisure = [
        ["Chelsea Girl",  40.725169,-74.003005],
        ["What Goes Around Comes Around", 40.722925,-74.00323],
        ["The Library", 40.752166,-73.981708]
      ];

      var mapCenter = new google.maps.LatLng(40.75688,-73.984264);

        var map = new google.maps.Map(document.getElementById('map-canvas'), {
          zoom: 12,
          center: mapCenter,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        });

        var map2 = new google.maps.Map(document.getElementById('map-canvas-2'), {
          zoom: 13,
          center: mapCenter,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        });

        var map3 = new google.maps.Map(document.getElementById('map-canvas-3'), {
          zoom: 13,
          center: mapCenter,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        });

        var map4 = new google.maps.Map(document.getElementById('map-canvas-4'), {
          zoom: 13,
          center: mapCenter,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        });

        var infowindow = new google.maps.InfoWindow();

        var marker, marker2, marker3, marker4, i;



        // Map1 Markers
        for (i = 0; i < dining.length; i++) {
          marker = new google.maps.Marker({
            position: new google.maps.LatLng(dining[i][4], dining[i][5]),
            map: map
          });

          google.maps.event.addListener(marker, 'click', (function(marker, i) {
            return function() {
              infowindow.setContent("<h1>" + dining[i][0] + "</h1><p>" + dining[i][1] + "</p><p>" + dining[i][2] + "</p><p>" + dining[i][3] + "</p>");
              infowindow.open(map, marker);
            }
          })(marker, i));
        }

        // Map2 Markers
        for (i = 0; i < drinks.length; i++) {
          marker2 = new google.maps.Marker({
            position: new google.maps.LatLng(drinks[i][1], drinks[i][2]),
            map: map2
          });

          google.maps.event.addListener(marker2, 'click', (function(marker2, i) {
            return function() {
              infowindow.setContent(drinks[i][0]);
              infowindow.open(map2, marker2);
            }
          })(marker2, i));
        }

        // Map3 Markers
        for (i = 0; i < roofOutdoor.length; i++) {
          marker3 = new google.maps.Marker({
            position: new google.maps.LatLng(roofOutdoor[i][1], roofOutdoor[i][2]),
            map: map3
          });

          google.maps.event.addListener(marker3, 'click', (function(marker3, i) {
            return function() {
              infowindow.setContent(roofOutdoor[i][0]);
              infowindow.open(map3, marker3);
            }
          })(marker3, i));
        }

        // Map4 Markers
        for (i = 0; i < leisure.length; i++) {
          marker4 = new google.maps.Marker({
            position: new google.maps.LatLng(leisure[i][1], leisure[i][2]),
            map: map4
          });

          google.maps.event.addListener(marker4, 'click', (function(marker4, i) {
            return function() {
              infowindow.setContent(leisure[i][0]);
              infowindow.open(map4, marker4);
            }
          })(marker4, i));
        }
      }

      google.maps.event.addDomListener(window, 'load', initialize);

});

4 个答案:

答案 0 :(得分:1)

我以前做过这个。

我将jquery用于我的客户端JS。

<强> HTML 首先,我会尝试同时渲染所有地图。是。简单地让它们全部可见,以便它们各自相互推动。

<强> CSS 第二,你有“位置:绝对;”尝试“position:inline-block;”

<强> JS 最后,

调用“$(”SELECTOR NAME“)。hide();”在最初隐藏在JS代码顶部的3个地图上。

然后“$(”SELECTOR NAME“)。toggle();”打开或关闭其他的。

原因:我相信现在发生的事情是你有3个最初隐藏的地图生成,这样当客户端加载页面时,DOM实际上并没有生成的内容。生成的DOM对象需要委托操作。第一张地图工作正常,因为它生成与DOM

今晚我可以给你一个实际的代码示例,我正在工作,抱歉。

答案 1 :(得分:1)

你可以简单地拥有1个谷歌地图并取消设置并在其上设置标记。 使用marker.setMap(null)取消设置地图中的标记。 您必须在数组中跟踪这些标记。

这样的事情:

var markers = []; // To keep all markers
// array can be your array of 'dining', 'drinks', 'roofOutdoor' or 'leisure' which you could set by clicking on your a tag.

function setMarkers (array) {
    $.each(markers, function (index, marker) {
        // unset marker (they will be removed from the map)
        marker.setMap(null);
    });

    if (array !== undefined) {
        var bounds = new google.maps.LatLngBounds();
        $.each(array, function (index, value) {
            var pos = new google.maps.LatLng(value[1], value[1]);
            bounds.extend(pos);
            var marker = new google.maps.Marker({
                position: pos,
                map: map
            });
            markers.push(marker);

        });
        map.fitBounds(bounds);
    }
}

我添加了bounds只是为了转到标记,因此您确定它们已添加到地图中。

HTML:

<a href="javascript:;" onclick="setMarker(dining);">Show dining markers</a>

希望这有帮助。

答案 2 :(得分:0)

如果你想以同样的方式实现它,这是一个解决方案。

这是第二张地图的按钮

<button id="map2">map2</button>

一些内联js隐藏地图2 3 4并留下1个渲染

$('#2,#3,#4').hide();

这将在id =“2”的div之间显示某些内容,并隐藏父元素

中的所有其他内容
$("#map2").click(function() {
    $('#2').show().siblings().hide();
});

这是你的地图容器

<div class="map" id="2"> your map here </div> 

所以,如果你想保持大部分时间你的方式,这是最简单的。虽然效率低下,但如果超出限制,可能会导致Google停止解析您的API请求。 (他们确实限制了他们每天所服务的请求数量)

putvade的解决方案更加优雅。你应该肯定使用他的解决方案:P

答案 3 :(得分:0)

所以我找到了一个解决方案,感谢@MatUtter。

老实说,这是一个非常糟糕的黑客攻击。通常情况下,他们并不适合我。但是暂时我需要一些“有效”的东西,因为我正处于一个全站点的重构过程中(对公司公司而言)。

基本上,我已经意识到(感谢@MatUtter)是在运行$(“SELECTOR”)时。hide();它正在从DOM中删除一个元素。正如它应该的那样,但谷歌地图很难重新绘制地图,就像它原来那样,然后删除,然后重新绘制。至少这是我对它的理解。

所以现在,我正在选择每个地图元素,用'visibility:hidden'隐藏它们,因为这将允许每个地图保持它们在DOM中的位置,但是从视图中删除它们。点击每个关联的链接后,它会显示相应的地图。

这肯定是一个黑客,但它现在会做。谢谢你的帮助!

The most recent version of the site is here,如果你有任何额外的反馈或重构,你认为最好让我知道。我总是愿意修改,这是我今年的JS,所以我很高兴学习:)