【问题标题】:Panning the map after trigering click on a marker to open infowindow触发后平移地图点击标记打开信息窗口
【发布时间】:2013-09-12 19:37:31
【问题描述】:

我有一个简单的谷歌地图 v3,上面附有一个标记和信息窗口。

如果我单击标记,信息窗口会自动显示并地图平移以适应视图中的信息窗口,但是如果我尝试在页面加载时触发单击以打开信息窗口,信息窗口会打开但不会发生平移。

触发是这样完成的:

google.maps.event.trigger(marker, 'click');

如果我将上面的代码移动到一个函数中并使用 setTimeout 500 调用它,那么平移也会发生。

我在 API 中进行了挖掘,但找不到导致按需自动平移的函数。有没有办法不使用超时?为什么超时有帮助?

谢谢

这是不平移的示例:

<!DOCTYPE html>
<html>
  <head>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
      html { height: 100% }
      body { height: 100%; margin: 0; padding: 0 }
      #map-canvas { width: 400px; height: 320px }
    </style>
    <script type="text/javascript"
      src="https://maps.googleapis.com/maps/api/js?sensor=false">
    </script>
    <script type="text/javascript">
      function initialize() {
        var myLatlng = new google.maps.LatLng(42.6620233,-78.4250679);
        var mapOptions = {
          center: myLatlng,
          zoom: 7,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        };
        var map = new google.maps.Map(document.getElementById("map-canvas"),
            mapOptions);

        var contentString = '<div style="width: 200px; height: 100px;">Testing</div>';

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

        var marker = new google.maps.Marker({
            position: myLatlng,
            map: map,
            title:"Hello World!"
        });

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

        google.maps.event.trigger(marker, 'click'); 

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

    </script>
  </head>
  <body>
    <div id="map-canvas"/>
  </body>
</html>

这是一个可以平移但只有超时的:

<!DOCTYPE html>
<html>
  <head>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
      html { height: 100% }
      body { height: 100%; margin: 0; padding: 0 }
      #map-canvas { width: 400px; height: 320px }
    </style>
    <script type="text/javascript"
      src="https://maps.googleapis.com/maps/api/js?sensor=false">
    </script>
    <script type="text/javascript">
      var map;
      var marker;

      function initialize() {
        var myLatlng = new google.maps.LatLng(42.6620233,-72.4250679);
        var mapOptions = {
          center: myLatlng,
          zoom: 7,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        };
        map = new google.maps.Map(document.getElementById("map-canvas"),
            mapOptions);

        var contentString = '<div style="width: 200px; height: 100px;">Testing</div>';

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

        marker = new google.maps.Marker({
            position: myLatlng,
            map: map,
            title:"Hello World!"
        });

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

        setTimeout('pop()', 500);
        //google.maps.event.trigger(marker, 'click');
        //infowindow.open(map,marker);
        //map.pan();

      }

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

      function pop() {
        google.maps.event.trigger(marker, 'click');
      }

      //setTimeout('pop()', 500);

    </script>
  </head>
  <body>
    <div id="map-canvas"/>
  </body>
</html>

【问题讨论】:

    标签: google-maps google-maps-api-3


    【解决方案1】:

    地图的初始化不是一个同步过程,当您创建地图实例时,需要一些时间才能设置地图的所有属性(因此可能需要一些属性来确定平移位置地图)

    当您使用超时并且它起作用时,此时会设置所需的属性。

    我建议在瓦片加载完毕后调用该函数而不是超时,您可以确定此时地图的初始化已经完成:

    google.maps.event.addListenerOnce(map, 'tilesloaded', pop);
    

    【讨论】:

    • 我曾尝试这样做,但之前没有成功,结果我在事件侦听器中有错字。 'titlesloaded' 而不是 'tilesloaded'。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-10-06
    • 1970-01-01
    • 2011-04-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多