หน้านี้อธิบายวิธีสร้างเส้นทางและเพิ่มแอตทริบิวต์ที่กำหนดเองโดยใช้ Roads Selection API ในส่วนต่อไปนี้
- สร้างเส้นทาง: กำหนดเส้นทางเดียวโดยใช้
createปลายทาง - สร้างเส้นทางเป็นกลุ่ม: กำหนดเส้นทางหลายเส้นทางในคำขอเดียวโดยใช้ปลายทาง
batchCreate - สร้างเส้นทางที่มีจุดแวะพักระหว่างทาง: กำหนดเส้นทางที่มีจุดแวะพักระหว่างทางได้สูงสุด 25 จุด
- ใช้แอตทริบิวต์เส้นทางที่กำหนดเอง: เพิ่มคู่คีย์-ค่าที่กำหนดเองได้สูงสุด 10 คู่ลงในเส้นทางเพื่อวัตถุประสงค์ในการจัดระเบียบ
สร้างเส้นทาง
หากต้องการสร้างเส้นทาง ให้ส่งคำขอ POST ไปยังปลายทาง create
https://roads.googleapis.com/selection/v1/projects/PROJECT_NUMBER/selectedRoutes?selectedRouteId=SELECTED_ROUTE_ID
เนื้อหาของคำขอต้องเป็นออบเจ็กต์ JSON ที่กำหนดSelectedRoute
ทรัพยากร ออบเจ็กต์นี้ระบุข้อมูลต่อไปนี้
- ออบเจ็กต์
dynamicRouteที่มีข้อมูลต่อไปนี้originของเส้นทางที่เลือกdestinationของเส้นทางที่เลือกintermediatesของเส้นทาง หรือที่เรียกว่าจุดอ้างอิง
selectedRouteIdที่ไม่ซ้ำกัน ค่านี้ต้องมีความยาว 4-63 อักขระ และใช้อักขระที่เป็นตัวอักษรและตัวเลขคละกันเท่านั้น หากคุณไม่ระบุรหัส ระบบจะสร้างรหัสที่ไม่ซ้ำกันสำหรับเส้นทางที่เลือก
โค้ดตัวอย่างต่อไปนี้แสดงโครงสร้างของคำขอ POST ไปยังปลายทาง create
curl -X POST -d '
{"dynamic_route": { \
origin: {latitude: ORIGIN_LATITUDE ,longitude: ORIGIN_LONGITUDE}, \
destination: {latitude: DESTINATION_LATITUDE, longitude: DESTINATION_LONGITUDE} \
}}' \' \
-H 'X-Goog-User-Project: PROJECT_NUMBER' \
-H 'Content-Type: application/json' \
-H "Authorization: Bearer ACCESS_TOKEN" \
"https://roads.googleapis.com/selection/v1/projects/PROJECT_NUMBER/selectedRoutes?selectedRouteId=SELECTED_ROUTE_ID"เมื่อสำเร็จ API จะแสดงทรัพยากร SelectedRoute คำตอบ
มี selectedRouteId ในช่อง name คุณใช้selectedRouteIdนี้เพื่อดึงข้อมูลหรือลบทรัพยากร SelectedRoute ได้
ตัวอย่างโค้ดต่อไปนี้แสดงโครงสร้างของการตอบกลับจากปลายทางที่สำเร็จ
create
{
"name": "projects/PROJECT_NUMBER/selectedRoutes/SELECTED_ROUTE_ID",
"dynamicRoute": {
"origin": {
"latitude": ORIGIN_LATITUDE,
"longitude": ORIGIN_LONGITUDE
},
"destination": {
"latitude": DESTINATION_LATITUDE,
"longitude": DESTINATION_LONGITUDE
}
},
"createTime": "CREATE_TIME",
"state": "STATE_VALIDATING"
}
สร้างเส้นทางแบบเป็นชุด
หากต้องการสร้างเส้นทางหลายเส้นทางในคำขอเดียว ให้ใช้ปลายทาง
batchCreate
ปลายทางนี้ช่วยให้คุณกำหนดเส้นทางได้สูงสุด 1,000 เส้นทางในการเรียกครั้งเดียว
ส่งคำขอ POST ไปยังปลายทาง batchCreate
https://roads.googleapis.com/selection/v1/projects/PROJECT_NUMBER/selectedRoutes:batchCreate
URL ใช้ไวยากรณ์การแปลงรหัส gRPC
เนื้อความของคำขอต้องเป็นออบเจ็กต์ JSON ที่มีอาร์เรย์ requests
ออบเจ็กต์แต่ละรายการภายในอาร์เรย์นี้คือ CreateSelectedRouteRequest ที่
กำหนดทรัพยากร SelectedRoute แต่ละรายการ
ตัวอย่างโค้ดต่อไปนี้แสดงโครงสร้างของคำขอ POST ไปยังปลายทาง batchCreate
curl -X POST -d '
{"requests": [
{
"dynamicRoute": {
"origin": {"latitude": ORIGIN_LATITUDE_1, "longitude": ORIGIN_LONGITUDE_1},
"destination": {"latitude": DESTINATION_LATITUDE_1, "longitude": DESTINATION_LONGITUDE_1}
},
"selectedRouteId": "route-one"
},
{
"dynamicRoute": {
"origin": {"latitude": ORIGIN_LATITUDE_2, "longitude": ORIGIN_LONGITUDE_2},
"destination": {"latitude": DESTINATION_LATITUDE_2, "longitude": DESTINATION_LONGITUDE_2}
},
"selectedRouteId": "route-two"
}
]}
' \
-H 'X-Goog-User-Project: PROJECT_NUMBER' \
-H 'Content-Type: application/json' \
-H "Authorization: Bearer ACCESS_TOKEN" \
"https://roads.googleapis.com/selection/v1/projects/PROJECT_NUMBER/selectedRoutes:batchCreate"เมื่อสำเร็จ API จะแสดงการตอบกลับที่มีอาร์เรย์ของทรัพยากร SelectedRoute ที่สร้างขึ้น
โค้ดตัวอย่างต่อไปนี้แสดงโครงสร้างของคำตอบของปลายทาง batchCreate
{
"selectedRoutes": [
{
"name": "projects/PROJECT_NUMBER/selectedRoutes/SELECTED_ROUTE_ID_1",
"dynamicRoute": {
"origin": {
"latitude": ORIGIN_LATITUDE_1,
"longitude": ORIGIN_LONGITUDE_1
},
"destination": {
"latitude": DESTINATION_LATITUDE_1,
"longitude": DESTINATION_LONGITUDE_1
}
},
"createTime": "CREATE_TIME_1",
"state": "STATE_VALIDATING"
},
{
"name": "projects/PROJECT_NUMBER/selectedRoutes/SELECTED_ROUTE_ID_2",
"dynamicRoute": {
"origin": {
"latitude": ORIGIN_LATITUDE_2,
"longitude": ORIGIN_LONGITUDE_2
},
"destination": {
"latitude": DESTINATION_LATITUDE_2,
"longitude": DESTINATION_LONGITUDE_2
}
},
"intermediates": [],
"createTime": "CREATE_TIME_2",
"state": "STATE_VALIDATING"
}
]
}
สร้างเส้นทางที่มีจุดแวะพักระหว่างทาง
หากต้องการสร้างเส้นทางที่ผ่านจุดที่เฉพาะเจาะจงระหว่างต้นทางกับปลายทาง ให้ใส่อาร์เรย์ intermediates ภายในออบเจ็กต์ dynamicRoute ในเนื้อหาคำขอ องค์ประกอบแต่ละรายการในอาร์เรย์ intermediates คือจุดอ้างอิงที่กำหนดโดย latitude และ longitude เส้นทางหนึ่งๆ มีจุดอ้างอิงได้สูงสุด 25 จุด
ตัวอย่างโค้ดต่อไปนี้แสดงวิธีสร้าง SelectedRoute ที่มี
จุดแวะพักกลางทาง
curl -X POST -d '
{"dynamic_route": { \
"origin": {"latitude": ORIGIN_LATITUDE , "longitude": ORIGIN_LONGITUDE}, \
"intermediates": [
{"latitude": INTERMEDIATE_LATITUDE_1, "longitude": INTERMEDIATE_LONGITUDE_1},
{"latitude": INTERMEDIATE_LATITUDE_2, "longitude": INTERMEDIATE_LONGITUDE_2},
{"latitude": INTERMEDIATE_LATITUDE_3, "longitude": INTERMEDIATE_LONGITUDE_3}
],
"destination": {"latitude": DESTINATION_LATITUDE, "longitude": DESTINATION_LONGITUDE}}}' \
-H 'X-Goog-User-Project: PROJECT_NUMBER' \
-H 'Content-Type: application/json' \
-H "Authorization: Bearer ACCESS_TOKEN" \
"https://roads.googleapis.com/selection/v1/projects/PROJECT_NUMBER/selectedRoutes?selectedRouteId=SELECTED_ROUTE_ID"ใช้แอตทริบิวต์เส้นทางที่กำหนดเอง
ออบเจ็กต์ SelectedRoute มีฟิลด์ route_attributes เพื่อเพิ่มประสิทธิภาพการจัดการเส้นทางและการวิเคราะห์ข้อมูลภายในข้อมูลเชิงลึกด้านการจัดการถนน
ใช้ฟิลด์ routeAttributes เพื่อกำหนดพร็อพเพอร์ตี้ที่กำหนดเองสำหรับ
เส้นทางแต่ละเส้น โดยที่แอตทริบิวต์แต่ละรายการเป็นคู่คีย์-ค่า คุณระบุคู่คีย์-ค่าที่กำหนดเองได้สูงสุด 10 คู่ต่อเส้นทาง
แอตทริบิวต์เหล่านี้มีประโยชน์ในการระบุเส้นทางที่เฉพาะเจาะจงหรือจัดกลุ่ม เส้นทางตามเกณฑ์ที่เกี่ยวข้องกับความต้องการของคุณ
ตัวอย่างแอตทริบิวต์เส้นทางที่คุณใช้ได้มีดังนี้
"road_classification": "highway""maintenance_zone": "north_district""event_id": "marathon_2024""pavement_type": "asphalt"
โปรดปฏิบัติตามหลักเกณฑ์ต่อไปนี้เมื่อกำหนดฟิลด์ routeAttributes
- คีย์ต้องไม่ขึ้นต้นด้วยคำนำหน้า
goog - ความยาวของคีย์และค่าแต่ละรายการต้องไม่เกิน 100 อักขระ
จากนั้นคุณจะใช้ routeAttributes ที่กำหนดเองเหล่านี้ภายในข้อมูลเชิงลึกด้านการจัดการถนน
ได้ด้วยวิธีต่อไปนี้
- กรองการแจ้งเตือน Pub/Sub: คุณสามารถตั้งค่าตัวกรองในการสมัครใช้บริการ Pub/Sub เพื่อรับข้อมูลอัปเดตเฉพาะเส้นทางที่ตรงหรือไม่ตรงกับ คีย์แอตทริบิวต์ที่เฉพาะเจาะจงและค่าที่เกี่ยวข้อง
- ปรับแต่งการวิเคราะห์ BigQuery: ในตาราง BigQuery คุณสามารถใช้แอตทริบิวต์ต่อไปนี้ เพื่อกรองเส้นทางที่เฉพาะเจาะจงตามค่าของแอตทริบิวต์ นอกจากนี้ คุณยังจัดกลุ่มเส้นทางตามคีย์แอตทริบิวต์ที่เฉพาะเจาะจงเพื่อการวิเคราะห์ข้อมูลที่ตรงเป้าหมายมากขึ้นได้ด้วย
ตัวอย่างโค้ดถัดไปแสดงวิธีสร้าง SelectedRoute ที่มี routeAttributes ที่กำหนดเอง
curl -X POST -d '
{"dynamic_route": { origin: {latitude: ORIGIN_LATITUDE ,longitude: ORIGIN_LONGITUDE}, destination: {latitude: DESTINATION_LATITUDE, longitude: DESTINATION_LONGITUDE}}, route_attributes: {"ATTRIBUTE_KEY":"ATTRIBUTE_VALUE"}}' \
-H 'X-Goog-User-Project: PROJECT_NUMBER' \
-H 'Content-Type: application/json' \
-H "Authorization: Bearer ACCESS_TOKEN" \
"https://roads.googleapis.com/selection/v1/projects/PROJECT_NUMBER/selectedRoutes?selectedRouteId=SELECTED_ROUTE_ID"