이 문서에서는 다중 목적지 경로를 만들고 올바른 필드를 설정하고 실행할 차량에 할당하는 방법을 설명합니다. Fleet를 설정했다고 가정합니다. 차량을 만들었고 실제로 작동하는 운전자 앱이 있는지 소비자 앱(선택사항) 또한 Google Cloud Platform이라는 시나리오에 적용할 수 있습니다 다음 관련 가이드를 참고하세요. 다음과 같습니다.
- Fleet Engine 설정
- 차량 만들기
- 주문형 이동 개요의 이동 시나리오
경로 만들기 기본사항
이 섹션에서는 Fleet Engine에서 이동을 만들 때 필요한 요청 세부정보를 설명합니다. gRPC 및 REST를 사용하여 생성 요청을 실행합니다.
이동 필드
다음 필드를 사용하여 Fleet Engine에서 이동을 만듭니다. 다른 여러 종류의 이동: 단일 목적지 또는 다중 목적지, 풀링 여행을 공유하는 방법 등이 있습니다. 경로를 만들 때 선택적 필드를 제공하거나 나중에 경로를 업데이트할 때 설정할 수 있습니다.
이름 | 필수 여부 | 설명 |
---|---|---|
parent | 예 | 프로젝트 ID가 포함된 문자열입니다. 이 ID는 사용된 ID와 동일해야 합니다. 전체 Fleet Engine 통합에서 동일한 서비스 계정으로 역할을 수행합니다 |
trip_id | 예 | 이 이동을 고유하게 식별하는 문자열로, 이동 ID에 다음이 포함됩니다. 특정 제한사항이 적용될 수 있습니다 |
trip_type | 예 | 만들려는 이동 유형에 따라 TripType을 다음 값으로 설정합니다.
|
pickup_point | 예 | 이동의 출발점입니다. |
중간 대상 | 예 | 여러 목적지 이동만: 운전자가 중간에 방문하는 중간 목적지의 목록입니다.
승차 및 하차입니다. |
vehicle_waypoints | 예 | 공유 풀링 경로만 해당: 이 필드는 여러 경로의 중간 지점을 교체하는 것을 지원합니다.
여기에는 할당된 차량의 나머지 경유지도 모두 포함됩니다.
을 이 이동의 승차 및 하차 경유지로 지정합니다. 이 필드는
|
number_of_passengers | 아니요 | 이동의 승객 수입니다. |
dropoff_point | 아니요 | 여정의 목적지입니다. |
vehicle_id | 아니요 | 이동에 할당된 차량의 ID입니다. |
예: 다중 목적지 여정 만들기
다음은 승차 지점, 하차 지점, 중간 목적지가 하나 있는 독점 다중 목적지 경로를 만드는 방법을 보여줍니다.
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "multi-destination-trip-A";
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
// Trip initial settings.
String parent = "providers/" + PROJECT_ID;
Trip trip = Trip.newBuilder()
.setTripType(TripType.EXCLUSIVE)
.setPickupPoint(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.195139).setLongitude(106.820826)))
.setNumberOfPassengers(1)
.setDropoffPoint(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.1275).setLongitude(106.6537)))
// Add the list of intermediate destinations.
.addAllIntermediateDestinations(
ImmutableList.of(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.195139).setLongitude(106.820826)).build()))
.build();
// Create the Trip request.
CreateTripRequest createTripRequest = CreateTripRequest.newBuilder()
.setParent(parent)
.setTripId(TRIP_ID) // Trip ID assigned by the Provider server.
.setTrip(trip) // Initial state is NEW.
.build();
// Error handling.
try {
Trip createdTrip =
tripService.createTrip(createTripRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case ALREADY_EXISTS: // Trip already exists.
break;
case PERMISSION_DENIED:
break;
}
return;
}
여러 목적지 경로 업데이트
Fleet Engine이 경로를 따라 차량을 추적할 수 있도록 차량 ID로 이동을 구성해야 합니다. 경로 업데이트에 대한 자세한 내용은 다음을 참조하세요. 경로를 업데이트하고 경로를 관리합니다.
목적지를 변경할 때 하차 또는 중간 목적지를 지정하지 않은 경우 언제든지 이 시점에서 이동을 생성할 수 있습니다.
경로 업데이트 예시
다음은 이동을 업데이트하여 중급자 목록을 추가하는 방법을 보여줍니다. 차량 ID를 설정할 수 있습니다.
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "multi-destination-trip-A";
String tripName = "providers/" + PROJECT_ID + "/trips/" + TRIP_ID;
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
// The trip settings to be updated.
Trip trip = Trip.newBuilder()
// Add the list of intermediate destinations.
.addAllIntermediateDestinations(
ImmutableList.of(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.195139).setLongitude(106.820826)).build()))
.setVehicleId("8241890")
.build();
// The trip update request.
UpdateTripRequest updateTripRequest = UpdateTripRequest.newBuilder()
.setName(tripName)
.setTrip(trip)
.setUpdateMask(
FieldMask.newBuilder()
.addPaths("intermediate_destinations")
.addPaths("vehicle_id")
.build())
.build();
// Error handling.
try {
Trip updatedTrip =
tripService.updateTrip(updateTripRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND: // The trip doesn't exist.
break;
case PERMISSION_DENIED:
break;
}
return;
}
여러 목적지 이동의 이동 상태 관리
TripStatus
열거형 중 하나를 사용하여 이동 상태를 지정합니다.
값으로 사용됩니다. 이동 상태가 변경되면(예: ENROUTE_TO_PICKUP
에서 ARRIVED_AT_PICKUP
로) Fleet Engine에서 이동 상태를 업데이트해야 합니다. 이동 상태는 항상 NEW
값으로 시작하고 COMPLETE
또는 CANCELED
값으로 끝납니다.
다중 대상 경로의 경우 단일 대상 경로와 마찬가지로 경로 상태를 업데이트하는 것 외에도 차량이 중간 대상에 도달할 때마다 다음을 업데이트해야 합니다.
intermediateDestinationIndex
intermediateDestinationsVersion
이렇게 하려면 TripStatus
열거형의 다음 값을 사용하세요.
ENROUTE_TO_PICKUP
ARRIVED_AT_PICKUP
ENROUTE_TO_INTERMEDIATE_DESTINATION
ARRIVED_AT_INTERMEDIATE_DESTINATION
ENROUTE_TO_DROPOFF
COMPLETE
중급 목적지가 있는 여행의 예
다음은 승차 지점을 지나 첫 번째 중간 목적지로 이동 중인 다중 목적지 경로를 만드는 방법을 보여줍니다.
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "multi-destination-trip-A";
String tripName = "providers/" + PROJECT_ID + "/trips/" + TRIP_ID;
// Get the trip object from either the Fleet Engine or storage.
Trip trip = …;
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
// The trip settings to be updated.
Trip trip = Trip.newBuilder()
// Trip status cannot return to a previous state once it has passed.
.setTripStatus(TripStatus.ENROUTE_TO_INTERMEDIATE_DESTINATION)
// Enroute to the first intermediate destination.
.setIntermediateDestinationIndex(0)
// You must provide an intermediate_destinations_version to ensure that you
// have the same intermediate destinations list as the Fleet Engine.
.setIntermediateDestinationsVersion(
trip.getIntermediateDestinationsVersion())
.build();
// The trip update request.
UpdateTripRequest updateTripRequest = UpdateTripRequest.newBuilder()
.setName(tripName)
.setTrip(trip)
.setUpdateMask(
FieldMask.newBuilder()
.addPaths("trip_status")
.addPaths("intermediate_destination_index")
// intermediate_destinations_version must not be in the update mask.
.build())
.build();
// Error handling.
try {
Trip updatedTrip =
tripService.updateTrip(updateTripRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND: // The trip doesn't exist.
break;
case FAILED_PRECONDITION: // Either the trip status is invalid, or the
// intermediate_destinations_version doesn't
// match Fleet Engine's.
break;
case PERMISSION_DENIED:
break;
}
return;
}