ปรับค่ากําหนดการกําหนดเส้นทาง

การคำนวณเส้นทาง (รวมถึงการเปลี่ยนเส้นทาง) จะแสดงเส้นทางที่ใช้เวลาในการนำทางน้อยที่สุดเป็นเส้นทางที่ดีที่สุดเริ่มต้น แต่คุณเปลี่ยนกลยุทธ์การกำหนดเส้นทางเพื่อให้ระบบแสดงเส้นทางสำรองที่สั้นกว่าแทนได้

คำว่าสั้นกว่าหมายถึงเส้นทางที่สั้นที่สุดในบรรดาเส้นทางที่เหมาะสม โดยอิงตามโมเดลต้นทุนเริ่มต้นของเรา เส้นทางที่สั้นกว่าอาจไม่ใช่เส้นทางที่สั้นที่สุด เนื่องจากตัวเลือกนั้นอาจเป็นทางเลือกที่ไม่ดี ตัวอย่างเช่น หาก เส้นทางที่สั้นที่สุดคือ 10 กม. และใช้เวลา 50 นาทีในการนำทาง และ อีกเส้นทางยาว 15 กม. แต่ใช้เวลาเพียง 20 นาทีในการนำทาง ตัวเลือกที่ 2 จะดีที่สุด เนื่องจากใช้เวลา 30 นาทีเพื่อลดระยะทาง 5 กม. ไม่ใช่การแลกเปลี่ยนที่คุ้มค่า

เมื่อตั้งค่ากลยุทธ์การกำหนดเส้นทางสำหรับการเดินทางแล้ว ระบบจะไม่เปลี่ยนแปลงกลยุทธ์ดังกล่าวจนกว่าการเดินทางจะเสร็จสมบูรณ์ หากต้องการเปลี่ยนกลยุทธ์การกำหนดเส้นทางสำหรับการเดินทางที่มีอยู่ คุณต้องล้าง จุดหมายและรีเซ็ตอีกครั้งด้วยกลยุทธ์การกำหนดเส้นทางใหม่

กำลังดึงรายละเอียดเส้นทาง

หากต้องการพิจารณาว่ากลยุทธ์เส้นทางใดเป็นตัวเลือกที่เหมาะสมที่สุดสำหรับจุดอ้างอิงที่กำหนด ให้เรียกใช้ getRouteInfoForDestination() เพื่อรับรายละเอียดเส้นทางสำหรับทั้งเส้นทางเริ่มต้น ที่ดีที่สุดและเส้นทางที่สั้นที่สุด รายละเอียดประกอบด้วยระยะเวลาและ ระยะทางไปยังจุดพักรถ

รายละเอียดเหล่านี้มาจาก GMSNavigationRouteInfo ในการเรียกกลับ

ตัวอย่าง

ตัวอย่างโค้ดต่อไปนี้แสดงวิธีรับรายละเอียดเส้นทางสำหรับ กลยุทธ์การกำหนดเส้นทางทั้ง 2 แบบ

Swift

let routingOptions = GMSNavigationRoutingOptions()
navigator?.getRouteInfoForDestination(destination,
                                      routingOptions: routingOptions) { routeInfo in
  ...
}

Objective-C

GMSNavigationRoutingOptions *routingOptions =
    [[GMSNavigationRoutingOptions alloc] init];
[navigator getRouteInfoForDestination:destination
                   withRoutingOptions:routingOptions
                             callback:^(GMSNavigationRouteInfo *routeInfo){...}];

การกำหนดกลยุทธ์การกำหนดเส้นทาง

คุณกำหนดค่ากลยุทธ์การกำหนดเส้นทางได้โดยใช้ GMSNavigationRoutingOptions และตั้งค่า routingStrategy เมื่อเรียกใช้ setDestinations()

routingStrategy ใช้ค่าการแจงนับค่าใดค่าหนึ่งต่อไปนี้

ค่าการแจงนับคำอธิบาย
GMSNavigationRoutingStrategyDefaultBest จัดอันดับเส้นทางตามโมเดลต้นทุนเริ่มต้นของ Navigation SDK นี่คือ กลยุทธ์การกำหนดเส้นทางเริ่มต้น
GMSNavigationRoutingStrategyShorter จัดอันดับเส้นทางตามระยะทาง เส้นทางที่มีอันดับสูงสุดคือเส้นทางที่สั้นที่สุดในบรรดาเส้นทางที่แสดงผล

ตัวอย่าง

ตัวอย่างโค้ดต่อไปนี้แสดงวิธีตั้งค่ากลยุทธ์การกำหนดเส้นทางที่สั้นกว่า

Swift

let routingOptions = GMSNavigationRoutingOptions(routingStrategy: .shorter)
navigator?.setDestinations(destinations,
                           routingOptions: routingOptions) { routeStatus in
  ...
}

Objective-C

GMSNavigationRoutingOptions *routingOptions = [[GMSNavigationRoutingOptions alloc] initWithRoutingStrategy:GMSNavigationRoutingStrategyShorter];
[navigator setDestinations:destinations
            routingOptions:routingOptions
                  callback:^(GMSRouteStatus routeStatus){...}];

เส้นทางที่มีเรือข้ามฟาก

โดยค่าเริ่มต้น Navigation SDK สำหรับ iOS จะไม่รวมเส้นทางที่มีเรือข้ามฟาก หากต้องการรวมตัวเลือกเรือข้ามฟากเป็นส่วนหนึ่งของเส้นทาง คุณสามารถปรับค่ากำหนดการกำหนดเส้นทางนี้เพื่อแสดงการเดินทางไปยังส่วนเรือข้ามฟากได้โดยตั้งค่า avoidsFerries เป็น false

ตัวอย่าง

Swift

self.mapView.navigator?.avoidsFerries = false

Objective-C

self.mapView.navigator.avoidsFerries = NO

รูปแบบข้อความไฮไลต์เส้นทาง

ภายใต้กลยุทธ์การกำหนดเส้นทางที่สั้นกว่า ป้ายข้อความตามเส้นทางจะแสดง รายละเอียดระยะทาง แต่คุณใช้ข้อความไฮไลต์ของ ETA แทนได้

การกำหนดค่ารูปแบบข้อความไฮไลต์เส้นทาง

คุณเปลี่ยนรูปแบบข้อความเส้นทางได้โดยการตั้งค่า routeCalloutFormat ใน GMSMapView routeCalloutFormat ใช้ค่าใดค่าหนึ่งต่อไปนี้

ค่าการแจงนับคำอธิบาย
GMSNavigationRouteCalloutFormatDefault แสดงเวลาที่เหลือเมื่อใช้กลยุทธ์การกำหนดเส้นทางที่ดีที่สุดเริ่มต้น แสดงระยะทางที่เหลือเมื่อใช้กลยุทธ์การกำหนดเส้นทางที่สั้นกว่า
GMSNavigationRouteCalloutFormatTime แสดงเวลาที่เหลือ
GMSNavigationRouteCalloutFormatDistance Dแสดงระยะทางที่เหลือ

ตัวอย่าง

ตัวอย่างโค้ดต่อไปนี้แสดงวิธีกำหนดค่ารูปแบบข้อความไฮไลต์เส้นทาง

Swift

self.mapView.routeCalloutFormat = .time

Objective-C

_mapView.routeCalloutFormat = GMSNavigationRouteCalloutFormatTime;