タスクを構成する

このドキュメントでは、タスクの作成方法と使用方法を理解していることを前提としています。提供するサービス 以下の方法で発送タスクを構成する方法の具体例を示します。

  • 配送タスクのターゲット期間を設定する: 期間を設定します。 トリガーされます。

  • タスクの公開設定をカスタマイズする: お客様やフリート オペレーターに表示するタスク アクティビティの公開設定をカスタマイズします。

配送タスクのフィールドの詳細については、配送タスクを作成するをご覧ください。既存のタスクに関する追加情報を更新する場合は、以下も行う必要があります。 タスクに関連する識別子と 更新します。

ターゲット時間枠を設定する

ターゲット時間枠は、タスクを実行する TimeWindow です。 完了していません。たとえば、配送にお届け日数を伝える場合 タスクの対象時間枠を使用して、この時間枠をキャプチャできます。 アラートを生成することも、過去の移動状況を分析することもできます。

ターゲット時間枠は開始時間と終了時間で構成され、任意のタスクタイプに設定できます。ターゲット時間枠はルーティングに影響しない 確認します。

次の例は、Java gRPC ライブラリを使用して時間枠を設定する方法、または UpdateTask に HTTP REST リクエストを行う方法を示しています。Google Chat では タスクの作成時にも設定します。

gRPC

  static final String PROJECT_ID = "my-delivery-co-gcp-project";
  static final String TASK_ID = "task-8241890";

  DeliveryServiceBlockingStub deliveryService =
    DeliveryServiceGrpc.newBlockingStub(channel);

  // Task settings
  String taskName = "providers/" + PROJECT_ID + "/tasks/" + TASK_ID;
  Task task = Task.newBuilder()
    .setName(taskName)
    .setTargetTimeWindow(
      TimeWindow.newBuilder()
        .setStartTime(Timestamp.newBuilder().setSeconds(1680123600))
        .setEndTime(Timestamp.newBuilder().setSeconds(1680130800)))
    .build();

  // Task request
  UpdateTaskRequest updateTaskRequest =
    UpdateTaskRequest.newBuilder()  // No need for the header
        .setTask(task)
        .setUpdateMask(FieldMask.newBuilder().addPaths("targetTimeWindow"))
        .build();

  try {
    Task updatedTask = deliveryService.updateTask(updateTaskRequest);
  } catch (StatusRuntimeException e) {
    Status s = e.getStatus();
    switch (s.getCode()) {
       case NOT_FOUND:
         break;
       case PERMISSION_DENIED:
         break;
    }
    return;
  }

REST

HTTP を使用してタスク時間ウィンドウを設定するには、PATCH を呼び出し、updateMask を使用して targetTimeWindow パラメータを更新します。

PATCH https://fleetengine.googleapis.com/v1/providers/<project_id>/tasks/<id>?updateMask=targetTimeWindow

ここで、<id> はタスクの一意の識別子です。リクエスト ヘッダー 値 Bearer <token>Authorization フィールドが含まれている必要があります。 ここで、&lt;token&gt; はガイドラインに従って、サーバーから発行されます。 (サービス アカウントのロールJSON Web トークン)で説明されています。

# Set JWT, PROJECT_ID, and TASK_ID in the local environment
  curl -X PATCH "https://fleetengine.googleapis.com/v1/providers/${PROJECT_ID}/tasks/${TASK_ID}?updateMask=targetTimeWindow" \
    -H "Content-type: application/json" \
    -H "Authorization: Bearer ${JWT}" \
    --data-binary @- << EOM
  {
    "targetTimeWindow": {
      "startTime": "2023-03-29T21:00:00Z",
      "endTime": "2023-03-29T23:00:00Z"
    }
  }
  EOM

タスクの公開設定をカスタマイズする

デフォルトでは、Fleet Engine はタスク アクティビティを可視化します。このアクティビティは、荷物を受け取るお客様と荷物を追跡するフリート オペレーターの両方に表示できます。これには、荷物の配達ステータスに関する通知をお客様に送信する前に、配達の停留所の数を示す情報などが含まれます。この情報は、ビジネスモデルに合わせてタスクごとにカスタマイズできます。

このセクションでは、地図上で追跡されているオブジェクトの公開設定ルールについて説明します。 これらのルールは、次の 2 つのカテゴリのオブジェクトに適用されます。

  • 位置マーカーの公開設定
  • ポリラインや到着予定時刻など、アクティブな車両タスクのタスクデータの可視性

場所マーカーの公開設定ルール

Fleet Engine では、配送のステータスに関係なく、配送先の位置マーカーが地図上に表示されます。

タスクデータの可視化ルール

このセクションでは、タスクデータに適用されるデフォルトの公開設定ルールについて説明します。 カスタマイズできるのはアクティブな車両タスクのみです。つまり、カスタマイズした公開設定ルールを適用できるのは、集荷と配達のタスクのみです。

次のタスクはカスタマイズできません。

  • スケジュール設定された停止
  • 利用できないタスク
  • 無効な車両タスク

利用不能タスクの公開設定ルール

デフォルトでは、1 台でも車両は地図に表示されません。 追跡中のタスクに割り当てられていません。たとえば、ドライバーが休憩を取っている場合や、追跡対象の荷物に向かう途中で車両が給油している場合などです。到着予定時刻とタスクの完了予定時刻は引き続き利用できます。繰り返しになりますが、このルールはカスタマイズできません。

アクティブな車両タスクの可視性

TaskTrackingInfo オブジェクトには、配送追跡ライブラリを使用して表示できるデータ要素がいくつか用意されています。デフォルトでは、タスクが車両に割り当てられ、車両がタスクから 5 停留所以内にある場合に、これらのフィールドが表示されます。タスクが完了またはキャンセルされると、公開は終了します。

可視性の構成は、Fleet Engine 内でタスクを作成または更新するときにタスクに TaskTrackingViewConfig を設定して、タスクごとにカスタマイズできます。これにより、個々のデータ要素に対してルールが作成され、 できます。

次の表に、公開設定ルールを適用できるフィールドを示します。

公開設定ルールの車両タスク フィールド
  • ルート ポリライン
  • 到着予定時刻
  • タスクの完了までの推定時間
  • タスクまでの残りの運転距離
  • 残りの停留所数
  • 車両の位置情報

次の表は、上記のフィールドで利用可能な公開設定オプションを示しています。

公開設定オプション
  • 残りの経由地数
  • 到着予定時刻までの所要時間
  • 残りの走行距離
  • 常に表示
  • 非表示

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

追跡している経路の場合、経路のポリラインの公開設定は 車両の可視性。車両が表示されていないアクティブなルートでルート ポリラインが表示されている場合でも、表示されているポリラインの終点から車両の位置を推測できます。そのため、ルート ポリラインの公開設定は、車両の公開設定と同等か、それより制限が厳しいものにする必要があります。

以下のルールに沿って、有効な経路のポリラインまたは車両の位置を指定してください 公開設定の組み合わせです

ルートのポリラインと車両の位置で同じ公開設定オプションを指定する

このシナリオでは、ポリラインと車両の位置の両方を同じに設定します。 次のオプションがあります。

  • 残りの経由地数
  • 到着予定時刻までの所要時間
  • 残りの走行距離

このルールに従うには、ルートのポリラインの公開設定をより小さくする必要があります 車両の公開設定に設定された値以上。この例では ポリラインの残りの停止地点のしきい値は 3 に設定されます。これは、 車両に指定された 5 の値。つまり、トラッキング対象の広告が タスクの場所から 5 駅の位置に到達すると、車両は表示されますが、 その車両のルートは、目的地まで 3 駅しかありません。

```js
"taskTrackingViewConfig": {
  "routePolylinePointsVisibility": {
    "remainingStopCountThreshold": 3
  },
  "vehicleLocationVisibility": {
    "remainingStopCountThreshold": 5
  },
}
```

ルートのポリラインと車両の位置に異なる公開設定オプションを指定している

経路のポリラインと車両の位置表示オプションが異なる場合、 車両の位置情報は、公開設定オプションの両方がオンになっている場合にのみ表示されます できます。繰り返しになりますが、ポリラインの公開設定には公開設定ルールが適用されます。 車両:

  • 常に表示: 経路のポリラインは、[常に表示] に設定する必要があります。 車両位置情報によって常に同じ情報が提供される場合に、 表示公開設定オプションを使用します。
  • 非表示: 経路のポリラインは、非表示の公開設定を使用する必要があります。 このオプションは、車両の位置情報で非表示の公開設定オプションを使用している場合に行われます。

以下に例を示します。

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

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

タスクの公開設定のカスタマイズの例

次の例は、タスクを設定する方法を示しています。 公開設定ルール:

  • 車両が 3 つ目の停留所内にある場合は、ルートのポリラインを表示します。
  • 残りの走行距離が 5,000 メートル未満の場合は、到着予定時刻を表示します。
  • 残りの停留所数は表示しないでください。
  • 他のフィールドは、車両がタスクから 5 停留所以内にある場合に表示されるデフォルトの公開設定を保持します。

gRPC または REST については、TaskTrackingViewConfig をご覧ください。

gRPC

static final String PROJECT_ID = "my-delivery-co-gcp-project";
static final String TASK_ID = "task-8241890";

DeliveryServiceBlockingStub deliveryService =
  DeliveryServiceGrpc.newBlockingStub(channel);

// Task settings
String taskName = "providers/" + PROJECT_ID + "/tasks/" + TASK_ID;
Task task = Task.newBuilder()
  .setName(taskName)
  .setTaskTrackingViewConfig(
    TaskTrackingViewConfig.newBuilder()
      .setRoutePolylinePointsVisibility(
        VisibilityOption.newBuilder().setRemainingStopCountThreshold(3))
      .setEstimatedArrivalTimeVisibility(
        VisibilityOption.newBuilder().remainingDrivingDistanceMetersThreshold(5000))
      .setRemainingStopCountVisibility(
        VisibilityOption.newBuilder().setNever(true)))
  .build();

// Task request
UpdateTaskRequest updateTaskRequest =
  UpdateTaskRequest.newBuilder()  // No need for the header
      .setTask(task)
      .setUpdateMask(FieldMask.newBuilder().addPaths("taskTrackingViewConfig"))
      .build();

try {
  Task updatedTask = deliveryService.updateTask(updateTaskRequest);
} catch (StatusRuntimeException e) {
  Status s = e.getStatus();
  switch (s.getCode()) {
      case NOT_FOUND:
        break;
      case PERMISSION_DENIED:
        break;
  }
  return;
}

REST

HTTP を使用してタスク トラッキング ビュー構成ウィンドウを設定するには、PATCH を呼び出します。 updateMask を使用して taskTrackingViewConfig パラメータを更新します。

PATCH https://fleetengine.googleapis.com/v1/providers/<project_id>/tasks/<id>?updateMask=taskTrackingViewConfig

例:

# Set JWT, PROJECT_ID, and TASK_ID in the local environment
curl -X PATCH "https://fleetengine.googleapis.com/v1/providers/${PROJECT_ID}/tasks/${TASK_ID}?updateMask=taskTrackingViewConfig" \
  -H "Content-type: application/json" \
  -H "Authorization: Bearer ${JWT}" \
  --data-binary @- << EOM
{
  "taskTrackingViewConfig": {
    "routePolylinePointsVisibility": {
      "remainingStopCountThreshold": 3
    },
    "estimatedArrivalTimeVisibility": {
      "remainingDrivingDistanceMetersThreshold": 5000
    },
    "remainingStopCountVisibility": {
      "never": true
    }
  }
}
EOM

次のステップ