지도 ID는 Google Cloud에 저장된 Google 지도 스타일 및 구성 설정을 나타내는 고유 식별자입니다. 지도 ID를 사용하여 웹사이트와 애플리케이션에서 기능을 사용 설정하거나 지도를 관리하거나 스타일을 지정합니다. Google Cloud 콘솔 프로젝트의 지도 관리 페이지에서 필요한 각 플랫폼(JavaScript, Android, iOS 또는 정적 지도)의 지도 ID를 만들 수 있습니다.
지도 ID를 사용하는 기능과 자세한 내용은 지도 ID 개요를 참고하세요.
필수 권한
프로젝트에서 지도 ID를 만들거나 관리하려면 프로젝트의 Cloud 콘솔 IAM 페이지에서 적절한 역할 수준 권한(편집자 또는 소유자)이 있는 주 구성원을 사용해야 합니다. 자세한 내용은 IAM 기본 및 사전 정의된 역할 참조를 참고하세요.
지도 ID 만들기
다음 단계에 따라 Cloud 콘솔에서 지도 ID를 만듭니다.
필요한 권한으로 Cloud 콘솔 프로젝트에 로그인하고 엽니다.
Cloud 콘솔에서 지도 관리 페이지로 이동합니다.
지도 ID 만들기를 클릭합니다.
새 지도 ID 만들기 페이지에서 다음을 수행합니다.
- 이름에 지도 ID의 이름을 지정합니다.
- 선택사항: 설명에 지도 ID의 용도를 설명합니다.
- 지도 유형에서 지도 ID를 사용할 플랫폼을 선택합니다. JavaScript를 선택하는 경우 래스터 (기본값) 또는 벡터 지도 유형도 선택합니다. 벡터 지도에 관한 자세한 내용은 벡터 지도를 참고하세요.
- 저장을 클릭하여 새 지도 ID를 표시합니다.
지도 ID를 지도 스타일에 연결
클라우드 기반 지도 스타일 지정을 사용하는 경우 지도 스타일을 지도 ID와 연결합니다. 자세한 내용은 연결을 참고하세요.
앱에 지도 ID 추가하기
Android
MapView
클래스를 사용하거나 프로그래매틱 방식으로 GoogleMapOptions
클래스를 사용하여 활동의 레이아웃 파일에 있는 <fragment>
요소를 통해 지도 ID를 추가합니다.
예를 들어 res/values/strings.xml
에 map_id
라는 문자열 값으로 저장된
지도 ID를 만들었다고 가정해보겠습니다.
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="map_id">MAP_ID</string>
</resources>
활동의 레이아웃 파일에 있는 <fragment>
요소를 통해 추가된 지도의 경우, 맞춤 스타일이 있어야 하는 모든 지도 프래그먼트에서 map:mapId
속성에 지도 ID를 지정해야 합니다.
<fragment xmlns:map="http://schemas.android.com/apk/res-auto"
map:name="com.google.android.gms.maps.SupportMapFragment"
…
map:mapId="@string/map_id" />
MapView
클래스의 map:mapId
속성을 사용하여 지도 ID를
지정할 수도 있습니다.
<com.google.android.gms.maps.MapView
xmlns:android="http://schemas.android.com/apk/res/android"
....
map:mapId="@string/map_id" />
프로그래매틱 방식으로 지도 ID를 지정하려면 GoogleMapOptions
클래스를 사용하여 지도 ID를 MapFragment
인스턴스에 전달합니다.
자바
MapFragment mapFragment = MapFragment.newInstance(
new GoogleMapOptions()
.mapId(getResources().getString(R.string.map_id)));
Kotlin
val mapFragment = MapFragment.newInstance(
GoogleMapOptions()
.mapId(resources.getString(R.string.map_id))
)
Android 스튜디오에서 평상시처럼 앱을 빌드하고 실행합니다. 첫 번째 단계에서 구성한 맞춤 스타일은 지정된 지도 ID가 있는 모든 지도에 적용됩니다.
iOS
지도 ID를 사용하여 지도를 인스턴스화하려면 다음 단계를 따르세요.
- Cloud 콘솔의 지도 ID 문자열로
GMSMapID
를 만듭니다. - 방금 만든 지도 ID를 지정하는
GMSMapView
를 만듭니다.
Swift
let camera = GMSCameraPosition(latitude: 47.0169, longitude: -122.336471, zoom: 12)
let mapID = GMSMapID(identifier: "MAP_ID")
let mapView = GMSMapView(frame: .zero, mapID: mapID, camera: camera)
self.view = mapView
Objective-C
GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:47.0169
longitude:-122.336471
zoom:12];
GMSMapID *mapID = [GMSMapID mapIDWithIdentifier:@"MAP_ID"];
GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero mapID:mapID camera:camera];
self.view = mapView;
자체 지도 ID를 사용하는 경우 언제든지 Cloud 콘솔에서 지도 ID를 새 스타일로 설정할 수 있으며, 이 스타일은 약 6시간 이내에 나와 사용자의 지도 뷰에 자동으로 반영됩니다.
변경사항을 즉시 확인하려면 앱을 종료하고 최근에 사용한 앱 목록에서 앱을 강제 종료한 후 다시 열어 앱을 닫고 다시 시작할 수 있습니다. 그러면 업데이트된 지도가 표시됩니다.
자바스크립트
애플리케이션 코드에서 지도 ID로 지도를 만들려면 다음 단계를 따르세요.
이미 삽입된 JSON 코드로 지도를 맞춤설정하고 있다면
MapOptions
객체에서styles
속성을 삭제합니다. 그렇지 않은 경우에는 이 단계를 건너뜁니다.mapId
속성을 사용하여 지도에 지도 ID를 추가합니다. 예를 들면 다음과 같습니다.
map = new google.maps.Map(document.getElementById('map'), { center: {lat: -34.397, lng: 150.644}, zoom: 8, mapId: 'MAP_ID' });
Maps Static
웹 서비스 API 중 하나를 사용하는 새 지도 또는 기존 지도에 지도 ID를 추가하려면 map_id
URL 매개변수를 추가하고 지도 ID로 설정합니다. 이 예에서는 Maps Static API를 사용하여 지도에 지도 ID를 추가하는 방법을 보여줍니다.
<img src="https://maps.googleapis.com/maps/api/staticmap?center=Brooklyn+Bridge,New+York,NY&zoom=13&size=600x300&maptype=roadmap&markers=color:blue%7Clabel:S%7C40.702147,-74.015794&markers=color:green%7Clabel:G%7C40.711614,-74.012318&markers=color:red%7Clabel:C%7C40.718217,-73.998284&key=YOUR_API_KEY&map_id=MAP_ID&signature=YOUR_SIGNATURE" />