グーグルマップ-マーカー

マップ上にオブジェクトを描画し、それらを目的の緯度と経度にバインドできます。これらはオーバーレイと呼ばれます。Googleマップは、以下に示すようにさまざまなオーバーレイを提供します。

  • Markers
  • Polylines
  • Polygons
  • 円と長方形
  • 情報ウィンドウ
  • Symbols

地図上の単一の場所をマークするために、Googleマップは提供します markers。これらのマーカーは標準の記号を使用し、これらの記号はカスタマイズできます。この章では、マーカーを追加する方法と、マーカーをカスタマイズ、アニメーション化、および削除する方法について説明します。

単純なマーカーの追加

以下に示すように、マーカークラスをインスタンス化し、latlngを使用してマークする位置を指定することにより、マップの目的の場所に単純なマーカーを追加できます。

var marker = new google.maps.Marker({
   position: new google.maps.LatLng(19.373341, 78.662109),
   map: map,
});

次のコードは、ハイデラバード(インド)の都市にマーカーを設定します。

<!DOCTYPE html>
<html>
   
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js"></script>
      
      <script>
         function loadMap() {
			
            var mapOptions = {
               center:new google.maps.LatLng(19.373341, 78.662109),
               zoom:7
            }
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
            
            var marker = new google.maps.Marker({
               position: new google.maps.LatLng(17.088291, 78.442383),
               map: map,
            });
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

次の出力を生成します-

マーカーのアニメーション

マップにマーカーを追加した後、さらに進んで、次のようなアニメーションをマップに追加できます。 bounce そして drop。次のコードスニペットは、バウンスとドロップのアニメーションをマーカーに追加する方法を示しています。

//To make the marker bounce`
animation:google.maps.Animation.BOUNCE 

//To make the marker drop
animation:google.maps.Animation.Drop

次のコードは、アニメーション効果が追加されたハイデラバード市のマーカーを設定します-

<!DOCTYPE html>
<html>
   
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js"></script>
      
      <script>
         function loadMap() {
			
            var mapOptions = {
               center:new google.maps.LatLng(17.377631, 78.478603),
               zoom:5
            }
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
            
            var marker = new google.maps.Marker({
               position: new google.maps.LatLng(17.377631, 78.478603),
               map: map,
               animation:google.maps.Animation.Drop
            });
         }
      </script>

   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

次の出力を生成します-

マーカーのカスタマイズ

Googleマップが提供するデフォルトのアイコンの代わりに、独自のアイコンを使用できます。アイコンを次のように設定するだけですicon:'ICON PATH'。そして、設定することでこのアイコンをドラッグ可能にすることができますdraggable:true

次の例は、マーカーを目的のアイコンにカスタマイズする方法を示しています-

<!DOCTYPE html>
<html>
   
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js"></script>
      
      <script>
         function loadMap() {
			
            var mapOptions = {
               center:new google.maps.LatLng(17.377631, 78.478603),
               zoom:5
            }
            
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
            
            var marker = new google.maps.Marker({
               position: new google.maps.LatLng(17.377631, 78.478603),
               map: map,
               draggable:true,
               icon:'/scripts/img/logo-footer.png'
            });
				
            marker.setMap(map);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

次の出力を生成します-

マーカーの削除

を使用してマーカーをnullに設定することにより、既存のマーカーを削除できます。 marker.setMap() 方法。

次の例は、マップからマーカーを削除する方法を示しています-

<!DOCTYPE html>
<html>
   
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js"></script>
      
      <script>
         function loadMap() {
			
            var mapOptions = {
               center:new google.maps.LatLng(17.377631, 78.478603),
               zoom:5
            }
            
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
            
            var marker = new google.maps.Marker({
               position: new google.maps.LatLng(17.377631, 78.478603),
               map: map,
               animation:google.maps.Animation.Drop
            });
				
            marker.setMap(null);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

次の出力を生成します-