Google지도-마커

지도에 객체를 그리고 원하는 위도와 경도에 바인딩 할 수 있습니다. 이를 오버레이라고합니다. 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>

다음 출력을 생성합니다-

마커 애니메이션

지도에 마커를 추가 한 후 더 나아가 다음과 같은 애니메이션을 추가 할 수 있습니다. bouncedrop. 다음 코드 스 니펫은 바운스 및 드롭 애니메이션을 마커에 추가하는 방법을 보여줍니다.

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

다음 출력을 생성합니다-