本文說明如何為消費者使用的網路版行程追蹤應用程式,自訂地圖的路線折線。
使用 Consumer SDK,您可以控制地圖上行程路線的折線顯示設定,或設定路線折線的樣式。SDK 會為路程中有效或剩餘路徑的每組座標建立 google.maps.Polyline 物件。程式庫會在下列兩種情況套用這些自訂項目:
- 再將物件新增至地圖
- 用於物件的資料已變更
設定路線折線的樣式
與標記樣式類似,您可以使用自訂參數設定路線折線的樣式。接著,請使用下列其中一種方式設定樣式:
- 最簡單:使用 PolylineOptions在建立或更新所有相符的Polyline物件時套用。
- 進階:指定自訂函式。
自訂函式可根據 Fleet Engine 傳送的資料,個別設定物件樣式。這項函式可以根據行程的目前狀態變更每個物件的樣式;例如,車輛移動速度較慢時,將 Polyline物件的顏色調深或加粗。您甚至可以從 Fleet Engine 以外的來源加入對向,並根據該資訊設定Polyline物件的樣式。
自訂參數
設定路徑折線樣式時,您會使用 FleetEngineTripLocationProviderOptions 中提供的參數。這些參數會提供車輛旅程中不同的路徑狀態,如下所示:
- 已走過的路徑:使用 takenPolylineCustomization。
- 實際走過的路徑:使用 activePolylineCustomization。
- 尚未出發的路徑:使用 remainingPolylineCustomization。
使用 PolylineOptions
以下範例說明如何使用 PolylineOptions 設定 Polyline 物件的樣式。按照這個模式,使用先前列出的任何折線自訂項目,自訂任何 Polyline 物件的樣式。
JavaScript
activePolylineCustomization = {
  strokeWidth: 5,
  strokeColor: 'black',
};
TypeScript
activePolylineCustomization = {
  strokeWidth: 5,
  strokeColor: 'black',
};
使用自訂函式設定路線折線樣式
以下範例說明如何設定有效路線折線的樣式。按照這個模式,使用先前列出的任何路徑折線自訂參數,自訂任何 Polyline 物件的樣式。
JavaScript
// Color the route polyline objects in green if the vehicle is nearby.
activePolylineCustomization =
  (params) => {
    const distance = params.trip.remainingWaypoints[0].distanceMeters;
    if (distance < 1000) {
      // params.polylines contains an ordered list of Polyline objects for
      // the path.
      for (const polylineObject of params.polylines) {
        polylineObject.setOptions({strokeColor: 'green'});
      }
    }
  };
TypeScript
// Color the route Polyline objects in green if the vehicle is nearby.
activePolylineCustomization =
  (params: TripPolylineCustomizationFunctionParams) => {
    const distance = params.trip.remainingWaypoints[0].distanceMeters;
    if (distance < 1000) {
      // params.polylines contains an ordered list of Polyline objects for
      // the path.
      for (const polylineObject of params.polylines) {
        polylineObject.setOptions({strokeColor: 'green'});
      }
    }
  };
控制路線折線的顯示設定
根據預設,所有 Polyline 物件都會顯示。如要讓 Polyline 物件隱形,請設定其 visible 屬性:
JavaScript
remainingPolylineCustomization = {visible: false};
TypeScript
remainingPolylineCustomization = {visible: false};