0

このコードは短くするためにやり直しましたが、基本的には左クリックで円を追加し、右クリックで削除しようとしています。radius.setMap(null) は、関数内にない場合にのみ機能します。

    <!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="http://maps.googleapis.com/maps/api/js?key=mykey&sensor=false">
    </script>
    <script type="text/javascript">
      var centerlatlng = new google.maps.LatLng(-27.467726,153.026633);
      function initialize() {
        var mapOptions = {
          center: centerlatlng,
          zoom: 16,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        };
        var map = new google.maps.Map(document.getElementById("map_canvas"),
            mapOptions);

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

        google.maps.event.addDomListener(map, 'click', updateCircle);
        google.maps.event.addDomListener(map, 'rightclick', removeRadius);

    function removeRadius(){
        radius.setMap(null);}

    function updateCircle(){
        var radius = new google.maps.Circle({map: map,
                                            radius: 400,
                                            center: centerlatlng,
                                            fillOpacity: 0});}      
    }

    </script>
  </head>
  <body onload="initialize()">
    <div id="map_canvas" style="width:50%%; height:50%%"></div>
  <body>
</html>
4

3 に答える 3

2

radius 変数は関数 updateCircle() に対してローカルです。代わりにグローバルにします。

//Global variables
var centerlatlng = new google.maps.LatLng(-27.467726,153.026633);
var radius;


function updateCircle(){
      // do not use the 'var' keyword here
        radius = new google.maps.Circle({map: map,
                                            radius: 400,
                                            center: centerlatlng,
                                            fillOpacity: 0});}      
    }
于 2012-09-15T05:48:20.227 に答える
1

radiusは関数内でローカルに宣言されているupdateCircle()ため、 では使用できませんremoveRadius()

からの宣言をupdateCircle()それを含む functionに移動すると、とinitialize()の両方がグローバルにせずにそれを見ることができます。updateCircle()removeRadius()

function initialize() {
    var radius;
    var mapOptions = {...

    function updateCircle(){
        radius = new google.maps.Circle({map: map, ...
于 2012-09-15T05:53:22.893 に答える
0

これを Google マップ V3 で使用できます。

var shape=null;

google.maps.event.addDomListener(drawingManager, "circlecomplete", function(circle) {
    shape=circle;
});

この円を削除したいときに変数を割り当てた後、この関数を呼び出すだけです:

function removeOverlay {
    shape.setMap(null);
}

Google から返されたオブジェクトを特定の変数に保存するだけです。

これがあなたを助けることを願っています。

于 2012-09-15T11:17:43.663 に答える