2

ズームを変更したときに地図のカーソルを変更しようとしています。マウスを動かさないと、変更は表示されません。移動するとカーソルが変わります。あなたはここにテストすることができます:

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>
4

1 に答える 1

1

これは仕様によるようです:

ドラッグ可能なカーソル

ドラッグ可能な地図の上にマウスを置いたときに表示されるカーソルの名前または URL。

ドラッグカーソル

地図がドラッグされているときに表示されるカーソルの名前または URL。

どちらの場合も、マウスを動かす必要があるようです (マウスオーバーとドラッグはどちらも動詞であるため、マウスがいずれかの状態で動かされていると仮定します)。

さらに、Chrome でも動作するようです (応答が遅くなります)。

于 2013-03-14T20:03:08.820 に答える