Google지도-빠른 가이드

Google지도 란 무엇입니까?

Google지도는 다양한 유형의 지리 정보를 제공하는 Google의 무료 웹 매핑 서비스입니다. Google지도를 사용하면 할 수 있습니다.

  • 장소를 검색하거나 한 장소에서 다른 장소로가는 길을 찾아보세요.

  • 전 세계 여러 도시의 가로 및 세로 파노라마 거리 수준 이미지를보고 탐색합니다.

  • 특정 지점의 교통 정보와 같은 특정 정보를 가져옵니다.

Google지도는지도와지도에 표시되는 정보를 맞춤 설정할 수있는 API를 제공합니다. 이 장에서는 HTML 및 JavaScript를 사용하여 웹 페이지에 간단한 Google지도를로드하는 방법에 대해 설명합니다.

웹 페이지에지도를로드하는 단계

웹 페이지에지도를로드하려면 아래 단계를 따르세요.

1 단계 : HTML 페이지 만들기

아래와 같이 head 및 body 태그가있는 기본 HTML 페이지를 만듭니다.

<!DOCTYPE html>
<html>
   
   <head>
   </head>
   
   <body>
   ..............
   </body>
   
</html>

2 단계 : API로드

아래와 같이 스크립트 태그를 사용하여 Google Maps API를로드하거나 포함합니다.

<!DOCTYPE html>
<html>
   
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js"></script>
   </head>
   
   <body>
   ..............
   </body>
   
</html>

3 단계 : 컨테이너 생성

지도를 유지하려면 컨테이너 요소를 만들어야합니다. 일반적으로 <div> 태그 (일반 컨테이너)가이 용도로 사용됩니다. 컨테이너 요소를 생성하고 아래와 같이 치수를 정의합니다.

<div id = "sample" style = "width:900px; height:580px;"></div>

4 단계 :지도 옵션

지도를 초기화하기 전에 mapOptions객체 (리터럴처럼 생성됨) 및 맵 초기화 변수에 대한 값을 설정합니다. 지도에는 세 가지 주요 옵션이 있습니다.centre, zoom, 및 maptypeid.

  • centre−이 속성에서지도를 중앙에 배치 할 위치를 지정해야합니다. 위치를 전달하려면LatLng 필요한 위치의 위도와 경도를 생성자에 전달하여 객체를 생성합니다.

  • zoom −이 속성에서지도의 확대 / 축소 수준을 지정해야합니다.

  • maptypeid−이 속성에서 원하는지도 유형을 지정해야합니다. 다음은 Google에서 제공하는지도의 유형입니다-

    • ROADMAP (일반, 기본 2D지도)
    • SATELLITE (사진지도)
    • HYBRID (2 개 이상의 다른 유형 조합)
    • TERRAIN (산, 강 등이있는지도)

함수 내에서 loadMap(), mapOptions 객체를 생성하고 아래와 같이 center, zoom, mapTypeId에 ​​필요한 값을 설정합니다.

function loadMap() {
   var mapOptions = {
      center:new google.maps.LatLng(17.240498, 82.287598), 
      zoom:9, 
      mapTypeId:google.maps.MapTypeId.ROADMAP
   };
}

5 단계 :지도 개체 만들기

라는 JavaScript 클래스를 인스턴스화하여지도를 만들 수 있습니다. Map. 이 클래스를 인스턴스화하는 동안 필요한 맵에 대한 맵 및 맵 옵션을 보유하기 위해 HTML 컨테이너를 전달해야합니다. 아래와 같이지도 개체를 만듭니다.

var map = new google.maps.Map(document.getElementById("sample"),mapOptions);

6 단계 :지도로드

마지막으로 loadMap () 메소드를 호출하거나 DOM 리스너를 추가하여지도를로드합니다.

google.maps.event.addDomListener(window, 'load', loadMap);
                    or
<body onload = "loadMap()">

다음 예제는 확대 / 축소 값이 12 인 Vishakhapatnam이라는 도시의 로드맵을로드하는 방법을 보여줍니다.

<!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.609993, 83.221436), 
               zoom:12, 
               mapTypeId:google.maps.MapTypeId.ROADMAP
            };
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
         }
			
         google.maps.event.addDomListener(window, 'load', loadMap);
      </script>
      
   </head>
   
   <body>
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음 출력을 생성합니다-

이전 장에서 기본지도를로드하는 방법에 대해 설명했습니다. 여기에서는 필요한지도 유형을 선택하는 방법을 살펴 보겠습니다.

지도 유형

Google지도는 네 가지 유형의지도를 제공합니다. 그들은-

  • ROADMAP− 이것이 기본 유형입니다. 유형을 선택하지 않은 경우 표시됩니다. 선택한 지역의 스트리트 뷰를 보여줍니다.

  • SATELLITE − 선택한 지역의 위성 이미지를 보여주는지도 유형입니다.

  • HYBRID −이지도 유형은 위성 이미지에 주요 거리를 표시합니다.

  • TERRAIN − 지형과 초목을 보여주는지도 유형입니다.

통사론

이러한지도 유형 중 하나를 선택하려면 아래 표시된대로지도 옵션에서 해당지도 유형 ID를 언급해야합니다.

var mapOptions = {
   mapTypeId:google.maps.MapTypeId.Id of the required map type
};

로드맵

다음 예는 ROADMAP 유형의지도를 선택하는 방법을 보여줍니다.

<!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.609993, 83.221436),
               zoom:9,
               mapTypeId:google.maps.MapTypeId.ROADMAP
            };
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
         }
			
         google.maps.event.addDomListener(window, 'load', loadMap);
      </script>
      
   </head>
   
   <body>
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음과 같은 출력이 생성됩니다.

위성

다음 예는 SATELLITE 유형의지도를 선택하는 방법을 보여줍니다.

<!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.609993, 83.221436),
                  zoom:9,
                  mapTypeId:google.maps.MapTypeId.SATELLITE
            };
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
         }
			
         google.maps.event.addDomListener(window, 'load', loadMap);
      </script>
		
   </head>
      
   <body>
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음과 같은 출력이 생성됩니다.

잡종

다음 예는 HYBRID 유형의 맵을 선택하는 방법을 보여줍니다.

<!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.609993, 83.221436),
               zoom:9,
               mapTypeId:google.maps.MapTypeId.Hybrid
            };
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
         }
			
         google.maps.event.addDomListener(window, 'load', loadMap);
      </script>
      
   </head>
   
   <body>
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>

</html>

다음과 같은 출력이 생성됩니다.

지역

다음 예는 TERRAIN 유형의지도를 선택하는 방법을 보여줍니다.

<!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.609993, 83.221436),
               zoom:9,
               mapTypeId:google.maps.MapTypeId.TERRAIN
            };
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
         }
			
         google.maps.event.addDomListener(window, 'load', loadMap);
      </script>
      
   </head>
   
   <body>
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음과 같은 출력이 생성됩니다.

확대 / 축소 값 증가 / 감소

값을 수정하여지도의 확대 / 축소 값을 늘리거나 줄일 수 있습니다. zoom 지도 옵션의 속성.

통사론

확대 / 축소 옵션을 사용하여지도의 확대 / 축소 값을 늘리거나 줄일 수 있습니다. 다음은 현재지도의 확대 / 축소 값을 변경하는 구문입니다.

var mapOptions = {
   zoom:required zoom value
};

예 : Zoom 6

다음 코드는 확대 / 축소 값이 6 인 도시 Vishakhapatnam의 로드맵을 표시합니다.

<!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.609993, 83.221436),
               zoom:6,
               mapTypeId:google.maps.MapTypeId.ROADMAP
            };
            
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:587px; height:400px;"></div>
   </body>
   
</html>

다음과 같은 출력이 생성됩니다.

예 : 줌 10

다음 코드는 확대 / 축소 값이 10 인 도시 Vishakhapatnam의 로드맵을 표시합니다.

<!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.609993, 83.221436),
               zoom:10,
               mapTypeId:google.maps.MapTypeId.ROADMAP
            };
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:587px; height:400px;"></div>
   </body>
   
</html>

다음과 같은 출력이 생성됩니다.

기본적으로지도에 표시된 도시 이름과 옵션 이름은 영어로 표시됩니다. 필요한 경우 이러한 정보를 다른 언어로도 표시 할 수 있습니다. 이 프로세스는localization. 이 장에서는지도를 현지화하는 방법을 배웁니다.

지도 현지화

아래와 같이 URL에 언어 옵션을 지정하여지도의 언어를 사용자 지정 (현지화) 할 수 있습니다.

<script src = "https://maps.googleapis.com/maps/api/js?language=zh-Hans"></script>

다음은 GoogleMaps를 현지화하는 방법을 보여주는 예입니다. 여기에서 중국어로 현지화 된 중국 로드맵을 볼 수 있습니다.

<!DOCTYPE html>
<html>
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js?language=zh-Hans"></script>
      
      <script>
         function loadMap() {
			
            var mapOptions = {
               center:new google.maps.LatLng(32.870360, 101.645508),
               zoom:9, 
               mapTypeId:google.maps.MapTypeId.ROADMAP
            };
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>

</html>

산출

다음과 같은 출력이 생성됩니다.

Google지도는 사용자가지도와 상호 작용할 수 있도록 다양한 컨트롤이있는 사용자 인터페이스를 제공합니다. 이러한 컨트롤을 추가, 사용자 지정 및 비활성화 할 수 있습니다.

기본 컨트롤

다음은 Google지도에서 제공하는 기본 컨트롤 목록입니다.

  • Zoom−지도의 확대 / 축소 수준을 높이거나 낮추기 위해 기본적으로 + 및 − 버튼이있는 슬라이더가 있습니다. 이 슬라이더는지도의 왼쪽 모서리에 있습니다.

  • Pan − 확대 / 축소 슬라이더 바로 위에지도를 이동하기위한 이동 컨트롤이 있습니다.

  • Map Type−이 컨트롤은지도의 오른쪽 상단에서 찾을 수 있습니다. 위성, 로드맵 및 지형과 같은지도 유형 옵션을 제공합니다. 사용자는 이러한지도 중 하나를 선택할 수 있습니다.

  • Street view− 팬 아이콘과 확대 / 축소 슬라이더 사이에 페그 맨 아이콘이 있습니다. 사용자는이 아이콘을 드래그하여 특정 위치에 배치하여 스트리트 뷰를 볼 수 있습니다.

다음은 Google지도에서 제공하는 기본 UI 컨트롤을 관찰 할 수있는 예입니다.

UI 기본 컨트롤 비활성화

Google지도에서 제공하는 기본 UI 컨트롤을 비활성화 할 수 있습니다. disableDefaultUI 맵 옵션에서 true 값입니다.

다음 예제는 Google지도에서 제공하는 기본 UI 컨트롤을 비활성화하는 방법을 보여줍니다.

<!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.609993, 83.221436),
               zoom:5,
               mapTypeId:google.maps.MapTypeId.ROADMAP,
               disableDefaultUI: true
            };
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>

</html>

다음과 같은 출력이 생성됩니다.

모든 컨트롤 활성화 / 비활성화

이러한 기본 컨트롤 외에도 Google지도는 아래와 같이 세 가지 컨트롤을 더 제공합니다.

  • Scale− Scale 컨트롤은지도 축척 요소를 표시합니다. 이 컨트롤은 기본적으로 활성화되어 있지 않습니다.

  • Rotate− 회전 컨트롤에는 비스듬한 이미지가 포함 된지도를 회전 할 수있는 작은 원형 아이콘이 있습니다. 이 컨트롤은 기본적으로지도의 왼쪽 상단에 표시됩니다. (자세한 내용은 45 ° 이미지를 참조하십시오.)

  • Overview−지도의 확대 / 축소 수준을 높이거나 낮추기 위해 기본적으로 + 및 − 버튼이있는 슬라이더가 있습니다. 이 슬라이더는지도의 왼쪽 모서리에 있습니다.

지도 옵션에서 아래와 같이 Google지도에서 제공하는 컨트롤을 활성화 및 비활성화 할 수 있습니다.

{
   panControl: boolean,
   zoomControl: boolean,
   mapTypeControl: boolean,
   scaleControl: boolean,
   streetViewControl: boolean,
   overviewMapControl: boolean
}

다음 코드는 모든 컨트롤을 활성화하는 방법을 보여줍니다.

<!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:5,
               panControl: true,
               zoomControl: true,
               scaleControl: true,
               mapTypeControl:true,
               streetViewControl:true,
               overviewMapControl:true,
               rotateControl:true
            }
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>

</html>

다음과 같은 출력이 생성됩니다.

제어 옵션

제어 옵션을 사용하여 Google지도 제어의 모양을 변경할 수 있습니다. 예를 들어, 확대 / 축소 컨트롤은 크기를 줄이거 나 확대 할 수 있습니다. MapType 컨트롤 모양은 가로 막대 또는 드롭 다운 메뉴로 다양 할 수 있습니다. 다음은 Zoom 및 MapType 컨트롤에 대한 컨트롤 옵션 목록입니다.

Sr. 아니. 컨트롤 이름 제어 옵션
1 줌 제어
  • google.maps.ZoomControlStyle.SMALL
  • google.maps.ZoomControlStyle.LARGE
  • google.maps.ZoomControlStyle.DEFAULT
2 MapType 컨트롤
  • google.maps.MapTypeControlStyle.HORIZONTAL_BAR
  • google.maps.MapTypeControlStyle.DROPDOWN_MENU
  • google.maps.MapTypeControlStyle.DEFAULT

다음 예제는 제어 옵션을 사용하는 방법을 보여줍니다-

<!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:5,
               mapTypeControl: true,
               
               mapTypeControlOptions: {
                  style: google.maps.MapTypeControlStyle.DROPDOWN_MENU, mapTypeIds: [
                     google.maps.MapTypeId.ROADMAP,
                     google.maps.MapTypeId.TERRAIN
                  ]
               },
					
               zoomControl: true,
               
               zoomControlOptions: {
                  style: google.maps.ZoomControlStyle.SMALL
               }
            }
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음 출력을 생성합니다-

제어 위치

컨트롤 옵션에 다음 줄을 추가하여 컨트롤의 위치를 ​​변경할 수 있습니다.

position:google.maps.ControlPosition.Desired_Position,

다음은지도에 컨트롤을 배치 할 수있는 위치 목록입니다.

  • TOP_CENTER
  • TOP_LEFT
  • TOP_RIGHT
  • LEFT_TOP
  • RIGHT_TOP
  • LEFT_CENTER
  • RIGHT_CENTER
  • LEFT_BOTTOM
  • RIGHT_BOTTOM
  • BOTTOM_CENTER
  • BOTTOM_LEFT
  • BOTTOM_RIGHT

다음 예제는지도의 상단 중앙에 MapTypeid 컨트롤을 배치하는 방법과지도의 하단 중앙에 확대 / 축소 컨트롤을 배치하는 방법을 보여줍니다.

<!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:5,
               mapTypeControl: true,
               
               mapTypeControlOptions: {
                  style: google.maps.MapTypeControlStyle.DROPDOWN_MENU,
                  position:google.maps.ControlPosition.TOP_CENTER,
                  
                  mapTypeIds: [
                     google.maps.MapTypeId.ROADMAP,
                     google.maps.MapTypeId.TERRAIN
                  ]
               },
					
               zoomControl: true,
               
               zoomControlOptions: {
                  style: google.maps.ZoomControlStyle.SMALL,
                  position:google.maps.ControlPosition.BOTTOM_CENTER
               }
            }
				
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음 출력을 생성합니다-

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

다음 출력을 생성합니다-

이전 장에서 Google지도에서 마커를 사용하는 방법을 배웠습니다. 마커와 함께 원, 다각형, 직사각형, 다중 선 등과 같은 다양한 모양을 추가 할 수도 있습니다.이 장에서는 Google지도에서 제공하는 모양을 사용하는 방법을 설명합니다.

폴리 라인

Google지도에서 제공하는 폴리 라인은 다양한 경로를 추적하는 데 유용합니다. 클래스를 인스턴스화하여지도에 폴리 라인을 추가 할 수 있습니다.google.maps.Polyline. 이 클래스를 인스턴스화하는 동안 StrokeColor, StokeOpacity 및 strokeWeight와 같은 폴리 라인의 속성에 필요한 값을 지정해야합니다.

객체를 메소드에 전달하여 폴리 라인을지도에 추가 할 수 있습니다. setMap(MapObject). SetMap () 메서드에 null 값을 전달하여 폴리 라인을 삭제할 수 있습니다.

다음 예는 델리, 런던, 뉴욕, 베이징 사이의 경로를 강조하는 폴리 라인을 보여줍니다.

<!DOCTYPE html>
<html>
   
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js"></script>
      
      <script>
         function loadMap(){
			
            var mapProp = {
               center:new google.maps.LatLng(51.508742,-0.120850),
               zoom:3,
               mapTypeId:google.maps.MapTypeId.ROADMAP
            };
            
            var map = new google.maps.Map(document.getElementById("googleMap"),mapProp);
            
            var tourplan = new google.maps.Polyline({
               path:[
                  new google.maps.LatLng(28.613939, 77.209021),
                  new google.maps.LatLng(51.507351, -0.127758),
                  new google.maps.LatLng(40.712784, -74.005941),
                  new google.maps.LatLng(28.213545, 94.868713) 
               ],
               
               strokeColor:"#0000FF",
               strokeOpacity:0.6,
               strokeWeight:2
            });
            
            tourplan.setMap(map);
            //to remove plylines
            //tourplan.setmap(null);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "googleMap" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음과 같은 출력이 생성됩니다.

다각형

다각형은 주 또는 국가의 특정 지리적 영역을 강조하는 데 사용됩니다. 클래스를 인스턴스화하여 원하는 다각형을 만들 수 있습니다.google.maps.Polygon. 인스턴스화하는 동안 path, strokeColor, strokeOapacity, fillColor, fillOapacity 등과 같은 Polygon의 속성에 원하는 값을 지정해야합니다.

다음 예제는 Hyderabad, Nagpur 및 Aurangabad 도시를 강조하기 위해 다각형을 그리는 방법을 보여줍니다.

<!DOCTYPE html>
<html>
   
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js"></script>
      
      <script>
         function loadMap(){
			
            var mapProp = {
               center:new google.maps.LatLng(17.433053, 78.412172),
               zoom:4,
               mapTypeId: google.maps.MapTypeId.ROADMAP
            };
            
            var map = new google.maps.Map(document.getElementById("googleMap"),mapProp);
            
            var myTrip = [
               new google.maps.LatLng(17.385044, 78.486671),
               new google.maps.LatLng(19.696888, 75.322451), 
               new google.maps.LatLng(21.056296, 79.057803), 
               new google.maps.LatLng(17.385044, 78.486671)
            ];
            
            var flightPath = new google.maps.Polygon({
               path:myTrip,
               strokeColor:"#0000FF",
               strokeOpacity:0.8,
               strokeWeight:2,
               fillColor:"#0000FF",
               fillOpacity:0.4
            });
            
            flightPath.setMap(map);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "googleMap" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음과 같은 출력이 생성됩니다.

직사각형

직사각형을 사용하여 직사각형 상자를 사용하여 특정 지역 또는주의 지리적 영역을 강조 표시 할 수 있습니다. 클래스를 인스턴스화하여지도에 직사각형을 가질 수 있습니다.google.maps.Rectangle. 인스턴스화하는 동안 path, strokeColor, strokeOapacity, fillColor, fillOapacity, strokeWeight, bounds 등과 같은 사각형의 속성에 원하는 값을 지정해야합니다.

다음 예제는 직사각형을 사용하여지도에서 특정 영역을 강조하는 방법을 보여줍니다.

<!DOCTYPE html>
<html>
   
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js"></script>
      
      <script>
         function loadMap(){
			
            var mapProp = {
               center:new google.maps.LatLng(17.433053, 78.412172),
               zoom:6,
               mapTypeId:google.maps.MapTypeId.ROADMAP
            };
            
            var map = new google.maps.Map(document.getElementById("googleMap"),mapProp);
            
            var myrectangle = new google.maps.Rectangle({
               strokeColor:"#0000FF",
               strokeOpacity:0.6,
               strokeWeight:2,
               
               fillColor:"#0000FF",
               fillOpacity:0.4,
               map:map,
               
               bounds:new google.maps.LatLngBounds(
                  new google.maps.LatLng(17.342761, 78.552432),
                  new google.maps.LatLng(16.396553, 80.727725)
               )
					
            });
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "googleMap" style = "width:580px; height:400px;"></div>
   </body>
</html>

이것은 다음과 같은 출력을 제공합니다-

서클

직사각형과 마찬가지로 Circle을 사용하여 클래스를 인스턴스화하여 특정 지역 또는 원을 사용하는주의 지리적 영역을 강조 표시 할 수 있습니다. google.maps.Circle. 인스턴스화하는 동안 경로, strokeColor, strokeOapacity, fillColor, fillOapacity, strokeWeight, 반경 등과 같은 원의 속성에 원하는 값을 지정해야합니다.

다음 예제는 원을 사용하여 뉴 델리 주변 지역을 강조하는 방법을 보여줍니다-

<!DOCTYPE html>
<html>
   
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js"></script>
      
      <script>
         function loadMap(){
			
            var mapProp = {
               center:new google.maps.LatLng(28.613939,77.209021),
               zoom:5,
               mapTypeId:google.maps.MapTypeId.ROADMAP
            };
         
            var map = new google.maps.Map(document.getElementById("googleMap"),mapProp);
         
            var myCity = new google.maps.Circle({
               center:new google.maps.LatLng(28.613939,77.209021),
               radius:150600,
            
               strokeColor:"#B40404",
               strokeOpacity:0.6,
               strokeWeight:2,
            
               fillColor:"#B40404",
               fillOpacity:0.6
            });
				
            myCity.setMap(map);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "googleMap" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음과 같은 출력이 생성됩니다.

마커, 폴리곤, 폴리 라인 및 기타 기하학적 모양 외에도지도에 정보 창을 그릴 수도 있습니다. 이 장에서는 정보 창을 사용하는 방법에 대해 설명합니다.

창 추가

정보 창은지도에 모든 종류의 정보를 추가하는 데 사용됩니다. 예를 들어지도상의 위치에 대한 정보를 제공하려는 경우 정보 창을 사용할 수 있습니다. 일반적으로 정보창은 마커에 연결됩니다. 인스턴스화하여 정보 창을 첨부 할 수 있습니다.google.maps.InfoWindow수업. 그것은 다음과 같은 속성을 가지고 있습니다-

  • Content −이 옵션을 사용하여 콘텐츠를 문자열 형식으로 전달할 수 있습니다.

  • position −이 옵션을 사용하여 정보 창의 위치를 ​​선택할 수 있습니다.

  • maxWidth− 기본적으로 정보창의 너비는 텍스트가 줄 바꿈 될 때까지 늘어납니다. maxWidth를 지정하면 정보창의 크기를 가로로 제한 할 수 있습니다.

다음 예제는 마커를 설정하고 그 위에 정보 창을 지정하는 방법을 보여줍니다.

<!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.433053, 78.412172),
               zoom:5
            }
            
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
            
            var marker = new google.maps.Marker({
               position: new google.maps.LatLng(17.433053, 78.412172),
               map: map,
               draggable:true,
               icon:'/scripts/img/logo-footer.png'
            });
            
            marker.setMap(map);
            
            var infowindow = new google.maps.InfoWindow({
               content:"388-A , Road no 22, Jubilee Hills, Hyderabad Telangana, INDIA-500033"
            });
				
            infowindow.open(map,marker);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음과 같은 출력이 생성됩니다.

마커, 다각형, 폴리 라인 및 기타 기하학적 모양 외에도 미리 정의 된 벡터 이미지 (기호)를지도에 추가 할 수도 있습니다. 이 장에서는 Google지도에서 제공하는 기호를 사용하는 방법에 대해 설명합니다.

기호 추가

Google은 마커 또는 폴리 라인에서 사용할 수있는 다양한 벡터 기반 이미지 (기호)를 제공합니다. 다른 오버레이와 마찬가지로 미리 정의 된 심볼을지도에 그리려면 각각의 클래스를 인스턴스화해야합니다. 다음은 Google에서 제공하는 사전 정의 된 기호 목록과 클래스 이름입니다.

  • Circle − google.maps.SymbolPath.CIRCLE

  • Backward Pointing arrow (closed) − google.maps.SymbolPath.BACKWARD_CLOSED_ARROW

  • Forward Pointing arrow (closed) − google.maps.SymbolPath.FORWARD_CLOSED_ARROW

  • Forward Pointing arrow (open) − google.maps.SymbolPath.CIRCLE

  • Backward Pointing arrow (open) − google.maps.SymbolPath.CIRCLE

이러한 심볼은 path, fillColor, fillOpacity, scale, stokeColor, strokeOpacity 및 strokeWeight 속성을 갖습니다.

다음 예제는 Google지도에서 사전 정의 된 기호를 그리는 방법을 보여줍니다.

<!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.433053, 78.412172),
               zoom:5
            }
            
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
            
            var marker = new google.maps.Marker({
               position: map.getCenter(),
               
               icon: {
                  path: google.maps.SymbolPath.BACKWARD_CLOSED_ARROW,
                  scale: 5,
                  strokeWeight:2,
                  strokeColor:"#B40404"
               },
					
               draggable:true,
               map: map,
            });
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음 출력을 생성합니다-

심볼 애니메이션

마커와 마찬가지로 바운스 및 드롭과 같은 애니메이션을 심볼에도 추가 할 수 있습니다.

다음 예제는 심볼을지도에서 마커로 사용하고 애니메이션을 추가하는 방법을 보여줍니다.

<!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.433053, 78.412172),
               zoom:5
            }
            
            var map = new google.maps.Map(document.getElementById("sample"),mapOptions);
            
            var marker = new google.maps.Marker({
               position: map.getCenter(),
               
               icon: {
                  path: google.maps.SymbolPath.BACKWARD_CLOSED_ARROW,
                  scale: 5,
                  strokeWeight:2,
                  strokeColor:"#B40404"
               },
               
               animation:google.maps.Animation.DROP,
               draggable:true,
               map: map
            });
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "sample" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음 출력을 생성합니다-

Google Maps JavaScript 프로그램은 사용자가 생성 한 다양한 이벤트에 응답 할 수 있습니다. 이 장에서는 Google지도로 작업하는 동안 이벤트 처리를 수행하는 방법을 보여주는 예제를 제공합니다.

이벤트 리스너 추가

메소드를 사용하여 이벤트 리스너를 추가 할 수 있습니다. addListener(). 리스너를 추가 할 객체 이름, 이벤트 이름 및 핸들러 이벤트와 같은 매개 변수를받습니다.

다음 예제는 마커 객체에 이벤트 리스너를 추가하는 방법을 보여줍니다. 프로그램은 마커를 두 번 클릭 할 때마다지도의 확대 / 축소 값을 5 씩 올립니다.

<!DOCTYPE html>
<html>
   
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js"></script>
      
      <script>
         var myCenter = new google.maps.LatLng(17.433053, 78.412172);
         function loadMap(){
			
            var mapProp = {
               center: myCenter,
               zoom:5,
               mapTypeId: google.maps.MapTypeId.ROADMAP
            };
            
            var map = new google.maps.Map(document.getElementById("googleMap"),mapProp);
            
            var marker = new google.maps.Marker({
               position: myCenter,
               title:'Click to zoom'
            });
            
            marker.setMap(map);
            
            //Zoom to 7 when clicked on marker
            google.maps.event.addListener(marker,'click',function() {
               map.setZoom(9);
               map.setCenter(marker.getPosition());
            });
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "googleMap" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음 출력을 생성합니다-

클릭시 정보 창 열기

다음 코드는 마커를 클릭하면 정보 창을 엽니 다-

<!DOCTYPE html>
<html>
   
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js"></script>
      
      <script>
         var myCenter = new google.maps.LatLng(17.433053, 78.412172);
         function loadMap(){
			
            var mapProp = {
               center:myCenter,
               zoom:4,
               mapTypeId:google.maps.MapTypeId.ROADMAP
            };
            
            var map = new google.maps.Map(document.getElementById("googleMap"),mapProp);
            
            var marker = new google.maps.Marker({
               position:myCenter,
            });
            
            marker.setMap(map);
            
            var infowindow = new google.maps.InfoWindow({
               content:"Hi"
            });
            
            google.maps.event.addListener(marker, 'click', function() {
               infowindow.open(map,marker);
            });
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "googleMap" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음 출력을 생성합니다-

리스너 제거

메소드를 사용하여 기존 리스너를 제거 할 수 있습니다. removeListener(). 이 메서드는 리스너 객체를 받아들이므로 리스너를 변수에 할당하고이 메서드에 전달해야합니다.

다음 코드는 리스너를 제거하는 방법을 보여줍니다-

<!DOCTYPE html>
<html>
   
   <head>
      <script src = "https://maps.googleapis.com/maps/api/js"></script>
      
      <script>
         var myCenter = new google.maps.LatLng(17.433053, 78.412172);
         function loadMap(){
			
            var mapProp = {
               center:myCenter,
               zoom:4,
               mapTypeId:google.maps.MapTypeId.ROADMAP
            };
            
            var map = new google.maps.Map(document.getElementById("googleMap"),mapProp);
            
            var marker = new google.maps.Marker({
               position:myCenter,
            });
            
            marker.setMap(map);
            
            var infowindow = new google.maps.InfoWindow({
               content:"Hi"
            });
            
            var myListener = google.maps.event.addListener(marker, 'click', function() {
               infowindow.open(map,marker);
            });
				
            google.maps.event.removeListener(myListener);
         }
      </script>
      
   </head>
   
   <body onload = "loadMap()">
      <div id = "googleMap" style = "width:580px; height:400px;"></div>
   </body>
   
</html>

다음 출력을 생성합니다-