เอกสารนี้อธิบายวิธีแสดงยานพาหนะสำหรับจัดส่ง
สภาพแวดล้อมและข้อจำกัด
คุณสามารถแสดงยานพาหนะสำหรับนำส่งจากสภาพแวดล้อมเซิร์ฟเวอร์หรือเบราว์เซอร์ได้ Driver SDK ไม่รองรับการแสดงยานพาหนะนำส่ง
การระบุยานพาหนะนำส่งเป็นการขอสิทธิ์เข้าถึงยานพาหนะนำส่งอย่างกว้างๆ และมีไว้สำหรับผู้ใช้ที่เชื่อถือได้เท่านั้น ใช้โทเค็น Delivery Fleet Reader หรือ Fleet Engine Admin เมื่อส่งคำขอยานพาหนะสำหรับนำส่งรายการ
ยานพาหนะการนำส่งที่ระบุไว้จะมีช่องต่อไปนี้ปกปิดเนื่องจากส่งผลต่อขนาดของคำตอบ
CurrentRouteSegment
RemainingVehicleJourneySegments
การใช้งาน
คุณสามารถแสดงยานพาหนะตามตัวกรองแอตทริบิวต์และขอบเขตของวิวพอร์ตได้ หากคุณไม่ได้ระบุตัวกรองหรือวิวพอร์ต การตอบกลับจะรวมช่องทางการแสดงโฆษณาทั้งหมด
รายการที่มีตัวกรองแอตทริบิวต์
คุณสามารถแสดงยานพาหนะสำหรับจัดส่งตามตัวกรองได้โดยใช้พร็อพเพอร์ตี้ attributes
เช่น หากต้องการค้นหาแอตทริบิวต์ที่มีคีย์ my_key
และค่า my_value
ให้ใช้ attributes.my_key = my_value
หากต้องการค้นหาแอตทริบิวต์หลายรายการ ให้รวมการค้นหาโดยใช้โอเปอเรเตอร์ตรรกะ AND
และ OR
ดังตัวอย่างใน attributes.key1 = value1 AND
attributes.key2 = value2
ดูคำอธิบายไวยากรณ์การค้นหาตัวกรองแบบเต็มได้ที่ AIP-160 หากคุณรวมตัวกรองเข้ากับขอบเขตวิวพอร์ต ตัวกรองจะทําหน้าที่เป็นโอเปอเรเตอร์ AND
กับขอบเขตวิวพอร์ต ดูรายละเอียดได้ที่การกรองคำถามแอตทริบิวต์ของยานพาหนะ
รายการที่มีขอบเขตวิวพอร์ต
คุณกรองยานพาหนะนำส่งที่แสดงตามสถานที่ตั้งได้โดยใช้พารามิเตอร์viewport
request
พารามิเตอร์คำขอ viewport
จะกำหนดวิวพอร์ตโดยใช้พิกัดขอบเขต 2 รายการ ได้แก่ คู่พิกัดละติจูดและลองจิจูด high
(ตะวันออกเฉียงเหนือ) และ low
(ตะวันตกเฉียงใต้) ระบบจะปฏิเสธคำขอที่มีละติจูดสูงซึ่งต่ำกว่าละติจูดต่ำตามภูมิศาสตร์
แสดงรายการคำตอบ
ระบบจะแบ่งรายการยานพาหนะสำหรับจัดส่งเป็นหน้าๆ โดยค่าเริ่มต้นโดยใช้ขนาดหน้าที่เหมาะสม หากคุณระบุขนาดหน้า คำขอจะแสดงเฉพาะจำนวนยานพาหนะที่ระบุตามขีดจำกัด หรือน้อยกว่านั้น หากขนาดหน้าเว็บที่ขอเกินค่าสูงสุดภายใน ระบบจะใช้ค่าสูงสุดภายใน ขนาดหน้าเว็บเริ่มต้นและสูงสุดคือ 100 คัน
รายการยานพาหนะนำส่งอาจมีโทเค็นสําหรับการอ่านผลการค้นหาหน้าถัดไป โทเค็นหน้าเว็บจะแสดงในการตอบกลับก็ต่อเมื่อมียานพาหนะที่นําส่งในหน้าอื่นๆ ที่สามารถดึงข้อมูลได้ หากต้องการเรียกข้อมูลหน้างานถัดไป ให้ใช้โทเค็นหน้าเว็บกับคำขอที่เหมือนกับคำขอก่อนหน้า
แสดงตัวอย่างยานพาหนะ
คุณสามารถใช้ไลบรารี gRPC ของ Java หรือ REST เพื่อแสดงรายการยานพาหนะนำส่งในภูมิภาคหนึ่งๆ ที่มีแอตทริบิวต์หนึ่งๆ การตอบกลับที่สำเร็จอาจยังคงว่างเปล่า ในกรณีนี้ หมายความว่าไม่มียานพาหนะที่มีแอตทริบิวต์ที่ระบุอยู่ในวิวพอร์ตที่ระบุ
Java
static final String PROJECT_ID = "my-delivery-co-gcp-project";
DeliveryServiceBlockingStub deliveryService =
DeliveryServiceGrpc.newBlockingStub(channel);
// Tasks request
String parent = "providers/" + PROJECT_ID;
ListDeliveryVehiclesRequest listDeliveryVehiclesRequest =
ListDeliveryVehiclesRequest.newBuilder() // No need for the header
.setParent(parent)
.setViewport(
Viewport.newBuilder()
.setHigh(LatLng.newBuilder()
.setLatitude(37.45)
.setLongitude(-122.06)
.build())
.setLow(LatLng.newBuilder()
.setLatitude(37.41)
.setLongitude(-122.11)
.build())
.setFilter("attributes.my_key = my_value")
.build();
try {
ListDeliveryVehiclesResponse listDeliveryVehiclesResponse =
deliveryService.listDeliveryVehicles(listDeliveryVehiclesRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND:
break;
case PERMISSION_DENIED:
break;
}
return;
}
REST
# HTTP request
html GET https://fleetengine.googleapis.com/v1/providers/<project_id>/deliveryVehicles
# Request with a filter
# Request sets JWT, PROJECT_ID, and VEHICLE_ID in the local environment
curl -H "Authorization: Bearer ${JWT}" \
"https://fleetengine.googleapis.com/v1/providers/${PROJECT_ID}/deliveryVehicles?filter=attributes.my_key%20%3D%20my_value%20&viewport.high.latitude=37.45&viewport.high.longitude=-122.06&viewport.low.latitude=37.41&viewport.low.longitude=-122.11"
หากการค้นหาสําเร็จ เนื้อหาการตอบกลับจะมีข้อมูลซึ่งมีโครงสร้างดังต่อไปนี้
// JSON representation
{
"deliveryVehicles": [
{
object (DeliveryVehicle)
}
],
"nextPageToken": string,
"totalSize": integer
}