谷歌地图游标不会改变

时间:2013-03-14 19:56:39

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

我在更改缩放时尝试更改地图的光标。如果不移动鼠标,则无法看到更改。如果移动它,则光标会改变。你可以在这里测试:

http://tinkerbin.com/ENHFSmVR

如何重现:在不移动鼠标的情况下使用鼠标滚轮放大。光标应该改变,但它不会改变。移动鼠标。光标已更改。

如果你检查html,你会看到有一个带有内联样式的div,它有一个游标属性。除非移动鼠标,否则该游标属性不会改变。

<!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 { height: 100% }
    </style>
    <script type="text/javascript"
      src="https://maps.googleapis.com/maps/api/js?key=&sensor=false">
    </script>
    <script type="text/javascript">
      var odd = true;

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

        google.maps.event.addListener(map, "zoom_changed", function(event) {
          if (odd) {
            map.setOptions({ draggableCursor: 'crosshair', 
                         draggingCursor: 'crosshair'});
            odd = !odd;
          } else {
            map.setOptions({ draggableCursor: 'move', 
                         draggingCursor: 'move'});
            odd = !odd;
          }

        });
      }
      google.maps.event.addDomListener(window, 'load', initialize);
    </script>
  </head>
  <body>
    <div id="map-canvas"/>
  </body>
</html>

1 个答案:

答案 0 :(得分:1)

这看起来是设计的:

<强> draggableCursor

  

鼠标悬停在可拖动地图上时要显示的光标的名称或网址。

<强> draggingCursor

  

拖动地图时要显示的光标的名称或网址。

两种情况似乎都要求鼠标移动(鼠标悬停和被拖动都是动词,因此我假设在任一条件下移动鼠标时都会这样做。)

此外,它似乎适用于Chrome(响应延迟)。