地図のスタイルを設定する

このドキュメントでは、地図の外観をカスタマイズし、データの公開設定とビューポート オプションを制御する方法について説明します。その方法は次のとおりです。

  • Cloud ベースのマップのスタイル設定を使用する
  • 独自のコードで地図スタイル オプションを直接設定する

Cloud ベースのマップのスタイル設定を使って地図のスタイルを設定する

Cloud ベースのマップを使用して、マップ コンポーネントのデザインをカスタマイズする カスタマイズします。Google マップを使用するすべてのアプリの地図のスタイルは、Google Cloud コンソールでコードを変更することなく作成、編集できます。詳細については、Cloud ベースのマップのスタイル設定をご覧ください。

また、 ConsumerMapView および ConsumerMapFragment Cloud ベースのマップのスタイル設定をサポートしています。 Cloud ベースのマップのスタイル設定を使用するには、選択したマップが レンダラが LATEST である。以降のセクションでは、 Cloud ベースのマップのスタイル設定をプロジェクトに追加できます。

ConsumerMapView

ConsumerMapView で Cloud ベースのマップのスタイル設定を使用するには、 GoogleMapOptionsmapId フィールドを指定し、GoogleMapOptionsgetConsumerGoogleMapAsync(ConsumerMapReadyCallback, Fragment, GoogleMapOptions) または getConsumerGoogleMapAsync(ConsumerMapReadyCallback, FragmentActivity, GoogleMapOptions)

Java

public class SampleAppActivity extends AppCompatActivity {

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    ConsumerMapView mapView = findViewById(R.id.consumer_map_view);

    if (mapView != null) {
      GoogleMapOptions optionsWithMapId = new GoogleMapOptions().mapId("map-id");
      mapView.getConsumerGoogleMapAsync(
          new ConsumerMapReadyCallback() {
            @Override
            public void onConsumerMapReady(@NonNull ConsumerGoogleMap consumerGoogleMap) {
              // ...
            }
          },
          /* fragmentActivity= */ this,
          /* googleMapOptions= */ optionsWithMapId);
    }
  }
}

Kotlin

class SampleAppActivity : AppCompatActivity() {
  override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    val mapView = findViewById(R.id.consumer_map_view) as ConsumerMapView

    val optionsWithMapId = GoogleMapOptions().mapId("map-id")
    mapView.getConsumerGoogleMapAsync(
      object : ConsumerGoogleMap.ConsumerMapReadyCallback() {
        override fun onConsumerMapReady(consumerGoogleMap: ConsumerGoogleMap) {
          // ...
        }
      },
      /* fragmentActivity= */ this,
      /* googleMapOptions= */ optionsWithMapId)
  }
}

ConsumerMapFragment

ConsumerMapFragment でクラウドベースの地図のスタイル設定を使用する方法は 2 つあります。

  • XML を使用して静的に設定します。
  • newInstance で動的に。

XML を使用して静的に行う

Cloud ベースのマップのスタイル設定を ConsumerMapFragment は、指定された ID を持つ map:mapId XML 属性を追加します。 mapId。次の例をご覧ください。

<fragment
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:map="http://schemas.android.com/apk/res-auto"
    android:name="com.google.android.libraries.mapsplatform.transportation.consumer.view.ConsumerMapFragment"
    android:id="@+id/consumer_map_fragment"
    map:mapId="map-id"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>

newInstance で動的に

newInstance を指定して Cloud ベースのマップのスタイル設定を使用するには、 ConsumerMapFragment は、GoogleMapOptionsmapId フィールドを設定し、 GoogleMapOptionsnewInstance。次の例をご覧ください。

Java

public class SampleFragmentJ extends Fragment {

  @Override
  public View onCreateView(
      @NonNull LayoutInflater inflater,
      @Nullable ViewGroup container,
      @Nullable Bundle savedInstanceState) {

    final View view = inflater.inflate(R.layout.consumer_map_fragment, container, false);

    GoogleMapOptions optionsWithMapId = new GoogleMapOptions().mapId("map-id");
    ConsumerMapFragment consumerMapFragment = ConsumerMapFragment.newInstance(optionsWithMapId);

    getParentFragmentManager()
        .beginTransaction()
        .add(R.id.consumer_map_fragment, consumerMapFragment)
        .commit();

    consumerMapFragment.getConsumerGoogleMapAsync(
        new ConsumerMapReadyCallback() {
          @Override
          public void onConsumerMapReady(@NonNull ConsumerGoogleMap consumerGoogleMap) {
            // ...
          }
        });

    return view;
  }
}

Kotlin

class SampleFragment : Fragment() {
  override fun onCreateView(
    inflater: LayoutInflater,
    container: ViewGroup?,
    savedInstanceState: Bundle?): View? {

    val view = inflater.inflate(R.layout.consumer_map_fragment, container, false)

    val optionsWithMapId = GoogleMapOptions().mapId("map-id")
    val consumerMapFragment = ConsumerMapFragment.newInstance(optionsWithMapId)

    parentFragmentManager
      .beginTransaction()
      .add(R.id.consumer_map_fragment, consumerMapFragment)
      .commit()

    consumerMapFragment.getConsumerGoogleMapAsync(
      object : ConsumerMapReadyCallback() {
        override fun onConsumerMapReady(consumerGoogleMap: ConsumerGoogleMap) {
          // ...
        }
      })

    return view
  }
}

JavaScript カスタマー ジャーニーの共有地図に地図のスタイルを適用するには、 mapId、 その他 mapOptions これは JourneySharingMapView を作成するときです。

次の例は、マップ ID を使用して地図のスタイルを適用する方法を示しています。

JavaScript

const mapView = new google.maps.journeySharing.JourneySharingMapView({
  element: document.getElementById('map_canvas'),
  locationProviders: [locationProvider],
  mapOptions: {
    mapId: 'YOUR_MAP_ID'
  }
  // Any other styling options.
});

TypeScript

const mapView = new google.maps.journeySharing.JourneySharingMapView({
  element: document.getElementById('map_canvas'),
  locationProviders: [locationProvider],
  mapOptions: {
    mapId: 'YOUR_MAP_ID'
  }
  // Any other styling options.
});

独自のコードで地図のスタイルを直接設定する

JourneySharingMapView の作成時に地図オプションを設定して、地図のスタイルをカスタマイズすることもできます。次の例は、地図オプションを使用して地図のスタイルを設定する方法を示しています。設定できる地図オプションについて詳しくは、 mapOptions (Google Maps JavaScript API リファレンス)をご覧ください。

JavaScript

const mapView = new google.maps.journeySharing.JourneySharingMapView({
  element: document.getElementById('map_canvas'),
  locationProviders: [locationProvider],
  mapOptions: {
    styles: [
      {
        "featureType": "road.arterial",
        "elementType": "geometry",
        "stylers": [
          { "color": "#CCFFFF" }
        ]
      }
    ]
  }
});

TypeScript

const mapView = new google.maps.journeySharing.JourneySharingMapView({
  element: document.getElementById('map_canvas'),
  locationProviders: [locationProvider],
  mapOptions: {
    styles: [
      {
        "featureType": "road.arterial",
        "elementType": "geometry",
        "stylers": [
          { "color": "#CCFFFF" }
        ]
      }
    ]
  }
});

SDK に対するタスクデータの可視性を制御する

地図上の特定のタスク オブジェクトの表示 / 非表示を、 適用できます。

タスクデータのデフォルトの公開設定

デフォルトでは、車両に割り当てられたタスクのデータは、 タスクの 5 駅以内にあることを示します。公開設定の終了は、タスクの完了後に 表示されます。

次の表に、各タスクタイプのデフォルトの公開設定を示します。Google Chat では 多くのタスクの表示をカスタマイズできますが、すべてではありません。タスクの詳細については、 タイプについては、スケジュールされたタスクのガイドのタスクの種類をご覧ください。

タスクの種類 デフォルトの公開設定 カスタマイズ可能 説明
不在タスク 非表示 いいえ ドライバーの休憩と給油に使用されます。配送タスクへのルートが 別の停車地が含まれていると、その停車地は表示されません タスクのみに含まれている必要があります。到着予定時刻 タスク完了までの予想時間は 引き続き表示されます できます。
車両のタスクを開く 表示 タスクが完了またはキャンセルされると公開は終了します。 未完了の車両タスクの公開設定をカスタマイズできます。詳しくは、 [営業待ちリスト] の公開設定をカスタマイズする 車両タスク
クローズされた車両のタスク 非表示 いいえ 終了した車両タスクの公開設定はカスタマイズできません。

未解決の車両タスクの表示をカスタマイズする

TaskTrackingInfo インターフェースは、さまざまなタスクデータ要素を提供します。 Consumer SDK で表示できます。

カスタマイズ可能なタスクデータ要素

ポリラインをルーティングする

到着までの予想時間

タスク完了までの予想時間

タスクまでの残りの走行距離

残りの停留所数

車両の位置情報

タスクごとの公開設定オプション

可視性の構成は、Fleet Engine 内でタスクを作成または更新するときに TaskTrackingViewConfig を設定して、タスクごとにカスタマイズできます。次の公開設定オプションを使用して、タスク要素の公開設定を決定する条件を作成します。

公開設定オプション

残りの経由地数

到着予定時刻までの時間

残りの走行距離

常に表示

非表示

たとえば、カスタマイズの例で、次の表に示す条件を使用して 3 つのデータ要素の公開設定を調整するとします。他のすべての要素は、デフォルトの公開設定ルールに従います。

調整するデータ要素 公開設定 Criterion
ルート ポリライン 表示 車両が 3 駅以内にある。
ETA 表示 残りの走行距離は 5,000 未満です メートルです。
残りの経由地数 表示しない 車両が 3 駅以内にある。

次の例は、この構成を示しています。

"taskTrackingViewConfig": {
  "routePolylinePointsVisibility": {
    "remainingStopCountThreshold": 3
  },
  "estimatedArrivalTimeVisibility": {
    "remainingDrivingDistanceMetersThreshold": 5000
  },
  "remainingStopCountVisibility": {
    "never": true
  }
}

ルート ポリラインと車両位置の公開設定ルール

車両の位置が特定されていない限り、ルートのポリラインは表示されない visible;そうでない場合は、車両の位置を ポリライン。

これらのガイドラインは、経路の有効な組み合わせを指定する際に役立ちます。 ポリラインと車両位置情報の公開設定オプション。

同じ公開設定オプション 公開設定の条件 ガイダンス
ルート ポリラインのオプションが常に表示される設定になっている。 車両の位置情報を「常に表示」に設定します。
車の位置情報が非表示に設定されています。 ルート ポリラインを非表示に設定します。
公開設定オプションは次のいずれかです。 <ph type="x-smartling-placeholder">
    </ph>
  • 残りの停留所数
  • 到着予定日までの所要時間
  • 残りの走行距離

ルート ポリライン オプションを、車両の位置に設定された値以下の値に設定します。例:

    "taskTrackingViewConfig": {
      "routePolylinePointsVisibility": {
        "remainingStopCountThreshold": 3
      },
      "vehicleLocationVisibility": {
        "remainingStopCountThreshold": 5
      },
    }
    
さまざまな公開設定オプション 公開設定の基準 ガイダンス
車両の位置情報は表示されています

これは、車両の位置情報と車両の両方の ポリラインの公開設定オプションが満たされています。例:

  "taskTrackingViewConfig": {
    "routePolylinePointsVisibility": {
      "remainingStopCountThreshold": 3
    },
    "vehicleLocationVisibility": {
      "remainingDrivingDistanceMetersThreshold": 3000
    },
  }

この例では、残りの停留所数が 3 以上で、残りの走行距離が 3,000 メートル以上の場合のみ、車両の位置情報が表示されます。

自動適合を無効にする

自動フィットを無効にすると、地図のビューポートが車両と予想ルートに自動的にフィットしなくなります。次の例をご覧ください。 ジャーニーの共有を設定する際に自動適合を無効にする方法を示します。 使用できます。

JavaScript

const mapView = new
    google.maps.journeySharing.JourneySharingMapView({
  element: document.getElementById('map_canvas'),
  locationProviders: [locationProvider],
  automaticViewportMode:
      google.maps.journeySharing
          .AutomaticViewportMode.NONE,
  ...
});

TypeScript

const mapView = new
    google.maps.journeySharing.JourneySharingMapView({
  element: document.getElementById('map_canvas'),
  locationProviders: [locationProvider],
  automaticViewportMode:
      google.maps.journeySharing
          .AutomaticViewportMode.NONE,
  ...
});

次のステップ