マップ ID を使用する

マップ ID は、Google Cloud Console で作成し、スタイルと関連付ける識別子で、アプリコードに格納され、そのスタイルを地図に適用します。

マップ ID は、作成時にプロジェクトに関連付けられ、単一のプラットフォーム(Android、iOS、JavaScript)または Maps Static API に限定されます。

Cloud Console でマップ ID を作成または管理するには、プロジェクト所有者またはプロジェクト編集者の IAM の役割が必要です。

マップ ID を作成する

マップ ID は、Google マップの 1 つのインスタンスを表す一意の識別子です。マップ ID の作成と、マップ ID に関連付けられたスタイルの更新は、Cloud Console でいつでも行えます。

マップ ID の作成方法:

  1. Cloud Console で、[マップ管理] ページに移動します。
  2. [新しいマップ ID を作成] を選択して、[新しいマップ ID を作成] フォームを表示します。
    新しいマップ ID の作成

    フォーム内で次の操作を行います。

    • 地図の名前を指定します。
    • 地図の種類またはプラットフォームを指定します。
    • JavaScript マップの場合は、ラスターマップまたはベクターマップを選択します。
    • 地図の説明文を入力します。
    • [次へ] を選択して、新しいマップ ID を表示します。

マップ ID を地図のスタイルに関連付ける

以下の手順は、プロジェクトに既存の地図のスタイルが少なくとも 1 つあることを前提としています。

  1. Cloud Console で、[マップ管理] ページに移動します。
  2. このページの [地図の名前] 列から既存のマップ ID を選択します。
  3. このフォームの下部の [このマップ ID に関連付けられた地図のスタイル] プルダウンから地図のスタイルを選択します。
  4. [保存] を選択します。
    地図のスタイルをこのマップ ID に関連付けるためのプルダウン フィールドなど、1 つのマップ ID の詳細ページを示すスクリーンショット。

マップ ID をアプリに追加する

アクティビティのレイアウト ファイルの <fragment> 要素を使ってマップ ID を追加するには、MapView クラスを使用するか、プログラムで GoogleMapOptions クラスを使用します。

たとえば、map_id という名前の文字列値として res/values/strings.xml に保存されているマップ ID を作成したとします。

<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="map_id">YOUR_MAP_ID</string>
</resources>

アクティビティのレイアウト ファイルで <fragment> 要素を使って追加した地図の場合、カスタム スタイルを持つすべての地図フラグメントで、map:mapId 属性にマップ ID を指定する必要があります。

<fragment xmlns:map="http://schemas.android.com/apk/res-auto"
    class="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 クラスを使って MapFragment インスタンスに渡します。

Java

  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 Studio で、通常どおりにアプリをビルドして実行します。最初の手順で設定したカスタム スタイルは、ID を持つすべての地図に適用されます。