設定地圖樣式

本文件將說明如何自訂地圖的外觀和風格,以及控管資料顯示和檢視區選項。您可以選擇下列其中一種操作方式:

  • 使用雲端式地圖樣式設定
  • 直接在自己的程式碼中設定地圖樣式選項

使用雲端式地圖樣式設定設定地圖樣式

使用雲端式地圖樣式設定,自訂地圖元件的外觀與風格。您可以在 Google Cloud 控制台上,為使用 Google 地圖的任何應用程式建立及編輯地圖樣式,完全不必變更程式碼。詳情請參閱「雲端式地圖樣式設定」。

ConsumerMapViewConsumerMapFragment 類別都支援雲端式地圖樣式設定。如要使用雲端式地圖樣式設定,請確保所選地圖轉譯器為 LATEST。以下各節舉例說明如何在專案中使用雲端式地圖樣式設定。

ConsumerMapView

如要在 ConsumerMapView 中使用雲端地圖樣式,請在 GoogleMapOptions 上設定 mapId 欄位,然後將 GoogleMapOptions 傳遞至 getConsumerGoogleMapAsync(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 中使用雲端式地圖樣式設定的方式有兩種:

  • 使用 XML 靜態。
  • 使用 newInstance 動態設定。

使用 XML 靜態

如要搭配 ConsumerMapFragment 中的 XML 使用雲端式地圖樣式設定,請新增 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 動態執行

如要在 ConsumerMapFragment 中搭配 newInstance 使用雲端式地圖樣式設定,請在 GoogleMapOptions 上設定 mapId 欄位,並將 GoogleMapOptions 傳遞至 newInstance。請參閱以下範例:

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 消費者行程共用地圖,請在建立 JourneySharingMapView 時指定 mapId 和任何其他 mapOptions

以下範例說明如何套用含有地圖 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 時設定地圖選項,藉此自訂地圖樣式。下例說明如何使用地圖選項設定地圖樣式。如要進一步瞭解可設定的地圖選項,請參閱 Google Maps JavaScript API 參考資料中的 mapOptions

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 個停靠站內時,顯示指派給車輛的任務資料。工作完成或取消時,顯示設定就會結束。

下表顯示了各類型工作的預設顯示設定。您可以自訂許多工作的瀏覽權限,但並非全部。如要進一步瞭解工作類型,請參閱排定工作指南中的「工作類型」。

工作類型 預設顯示設定 是否可自訂? 說明
無法使用的工作 隱藏 用於駕駛座的休息和收容。如果前往送貨工作的路線也包含其他車輛停靠站,如果該停靠站只包含無法使用的工作,系統就不會顯示該停靠站。配送工作本身仍會顯示預計抵達時間和預估工作完成時間。
開啟車輛工作 顯示 工作完成或取消後,就會停止顯示。 您可以自訂開放車輛任務的瀏覽權限。請參閱「自訂開放車輛任務的顯示權限」。
已關閉車輛的工作 隱藏 你無法自訂封閉車輛工作的顯示設定。

自訂開放車輛任務的顯示設定

TaskTrackingInfo 介面提供多個可透過 Consumer SDK 顯示的工作資料元素。

可自訂的工作資料元素

路線折線

預計到達時間

預估工作完成時間

與工作相關的剩餘行車距離

剩餘停靠站數量

車輛位置

每項工作的瀏覽權限選項

您可以在 Fleet Engine 內建立或更新工作時設定 TaskTrackingViewConfig,以自訂各項工作的瀏覽權限設定。請使用下列瀏覽權限選項建立條件,藉此判斷工作元素的瀏覽權限:

瀏覽權限選項

剩餘停靠站數量

距離預估抵達時間還有

剩餘行駛距離

一律顯示

一律不顯示

為了說明情況,假設自訂範例會使用下表中的條件調整三個資料元素的瀏覽權限。所有其他元素都會遵循預設的瀏覽權限規則。

要調整的資料元素 顯示設定 條件
路線折線 顯示 車輛位於 3 個停靠站內。
預計抵達時間 顯示 剩餘的駕駛距離少於 5000 公尺。
剩餘停靠站數 不再顯示 車輛位於 3 個停靠站內。

以下範例說明這項設定:

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

路線折線和車輛位置顯示規則

除非車輛位置也顯示出來,否則路線多邊形無法顯示;否則,車輛位置可由多邊形的端點推斷。

這些規範可協助您為路線折線和車輛位置顯示設定選項提供有效的組合。

相同的瀏覽權限選項 曝光度條件 指引
路線折線選項設為一律顯示。 將車輛位置設為一律顯示。
車輛位置設為「永不顯示」。 將路線折線設為一律不顯示。
瀏覽權限選項如下:
  • 剩餘停靠站計數
  • 到達時間
  • 剩餘行駛距離

將路線折線選項設為小於或等於為車輛位置設定的值。例如:

    "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,
  ...
});

後續步驟