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

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

คําว่าสั้นกว่าหมายถึงเส้นทางที่สั้นที่สุดในบรรดาเส้นทางที่ดีที่สุดโดยอิงตามรูปแบบต้นทุนเริ่มต้น เส้นทางที่สั้นกว่าอาจไม่ใช่เส้นทางที่สั้นที่สุดอย่างแท้จริง เนื่องจากตัวเลือกนั้นอาจเป็นทางเลือกที่ไม่เหมาะ ตัวอย่างเช่น หากเส้นทางที่สั้นที่สุดคือ 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

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

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

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

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

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

ตัวอย่าง

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

Swift

self.mapView.routeCalloutFormat = .time

Objective-C

_mapView.routeCalloutFormat = GMSNavigationRouteCalloutFormatTime;