รายละเอียดเกี่ยวกับฟีดข้อมูลแบบเลี้ยวต่อเลี้ยว

ฟีดข้อมูลแบบเลี้ยวต่อเลี้ยวจะให้ข้อมูลการนำทางเท่านั้นแก่อุปกรณ์ที่ไม่ได้ออกแบบมาเพื่อคำแนะนำการนำทางตามแผนที่ โดยจะมีข้อมูลการบังคับเลี้ยวที่กําลังจะเกิดขึ้นพร้อมองค์ประกอบที่คุณระบุไว้ ดังนี้

  • ไอคอน (ซ้าย ขวา กลับรถ)
  • หมายเลขเลี้ยวในวงเวียน
  • ชื่อถนน
  • ระยะทางและเวลาโดยประมาณในการไปยังจุดหมายถัดไปหรือจุดหมายสุดท้าย

คุณสามารถใช้ฟีดแบบเลี้ยวต่อเลี้ยวเพื่อสร้างประสบการณ์การใช้งานในกรณีที่ UI ของ Navigation SDK แบบเต็มไม่เหมาะสม เช่น สำหรับการแสดงผลหน้าจอขนาดเล็ก ตัวอย่างเช่น คุณอาจใช้ฟีเจอร์นี้สำหรับผู้ขับขี่ยานพาหนะ 2 ล้อ ซึ่งคุณสามารถฉายคำแนะนำการนำทางเท่านั้นเพื่อช่วยให้ไปถึงจุดหมายได้เร็วขึ้นและมั่นใจมากขึ้นโดยมีการรบกวนน้อยที่สุด

องค์ประกอบการแสดงการนำทางที่จำเป็น

หน้าจอมือถือที่แสดงการเลี้ยวขวาในอีก 50 ฟุตบนถนน Church
Street ที่ด้านล่างของหน้าจอ เหลือเวลาอีก 13 นาทีถึงจุดหมาย และเหลือระยะทางอีก 2.1 ไมล์

ฟิลด์หลักสำหรับขั้นตอนการนำทางแต่ละขั้นตอนคือชื่อถนนแบบเต็ม การดำเนินการ และระยะทางทั้งหมดของขั้นตอน ซึ่งอยู่ใน GMSNavigationStepInfo

สำหรับการเดินทางโดยรวม คุณอาจต้องการแสดงเวลาที่เหลือและระยะทางไปยังขั้นตอนปัจจุบันหรือปลายทาง ซึ่งทั้งหมดนี้พร้อมใช้งานใน GMSNavigationNavInfo รูปภาพทางด้านขวาแสดงตัวอย่างองค์ประกอบการนําทางที่สําคัญเหล่านี้

ตั้งค่า Listener เหตุการณ์

หากต้องการใช้ข้อมูลการนําทางเท่านั้น คุณต้องติดตั้งใช้งาน Listener เหตุการณ์สําหรับเหตุการณ์ didChangeNavInfo เข้าถึงข้อมูลการเดินทางและขั้นตอนภายในโปรแกรมรับฟังเหตุการณ์เพื่อนำทางแบบเลี้ยวต่อเลี้ยวให้แก่ผู้ใช้

หากต้องการใช้ตัวแฮนเดิลเหตุการณ์ ตัวควบคุมมุมมองของแผนที่ต้องใช้โปรโตคอล GMSNavigatorListener ดูข้อมูลโดยละเอียดเกี่ยวกับการจัดการเหตุการณ์ใน Navigation SDK สําหรับ iOS ได้ที่ฟังเหตุการณ์การนําทาง

การจัดการเหตุการณ์ didChangeNavInfo

สร้าง Listener สําหรับเหตุการณ์ didChangeNavInfo เพื่อเพิ่มการรองรับการนําทางแบบเลี้ยวต่อเลี้ยวในแอปของคุณ ใน Listener เหตุการณ์ ให้ใช้คลาสและลิสต์แบบจำกัดต่อไปนี้เพื่อควบคุมการนําทางแบบเลี้ยวต่อเลี้ยว

  • GMSNavigationNavInfo — คลาสที่กําหนดข้อมูลเกี่ยวกับสถานะการนําทาง

  • GMSNavigationStepInfo - คลาสที่กําหนดข้อมูลเกี่ยวกับขั้นตอนเดียวในเส้นทางการนําทาง

  • GMSNavigationNavState — Enum ที่กําหนดสถานะปัจจุบันของการนําทาง เช่น อยู่ระหว่างทาง เปลี่ยนเส้นทาง หรือหยุด

  • GMSNavigationDrivingSide — Enum ที่ระบุว่าขั้นตอนนี้อยู่ในเส้นทางที่ขับเลนขวาหรือเลนซ้าย

  • GMSNavigationManeuver — Enum ที่กําหนดการดําเนินการในการนําทาง เช่น เลี้ยวซ้ายหรือเลี้ยวขวา

ตัวอย่าง Listener เหตุการณ์สําหรับเหตุการณ์ didChangeNavInfo มีดังนี้

Swift

  // ViewController.swift
  class SomeViewController: UIViewController {
    ...
    mapView.navigator?.add(self);
    ...
  }

  extension SomeViewController: GMSNavigatorListener {
    func navigator(_ navigator: GMSNavigator,
                   didUpdateNavInfo navInfo: GMSNavigationNavInfo) {

      // Get the current step information
      if navInfo.navState == .enroute {
        if let currentStep = navInfo.currentStep {
          ...
          roadNameLabel.text = currentStep.simpleRoadName
          ...
        }
      }
    }
  }

Objective-C

  // ViewController.h
  @interface SomeViewController () <GMSNavigatorListener>

  @end

  // ViewController.m
  @implementation SomeViewController
  // Some initialization code.
  ... {
    ...
    [_mapView.navigator addListener:self];
    ...
  }

  #pragma mark GMSNavigatorListener
  - (void)navigator:(GMSNavigator *)navigator didUpdateNavInfo:(GMSNavigationNavInfo *)navInfo {
    // Get the current step information
    if (navInfo.navState == GMSNavigationNavStateEnroute) {
      GMSNavigationStepInfo *currentStep = navInfo.currentStep;
      if (currentStep) {
        ...
        roadNameLabel.text = currentStep.simpleRoadName;
        ...
      }
    }
    ...
  }

ใช้พร็อพเพอร์ตี้ navState ของ GMSNavigationNavInfo เพื่อดูสถานะการนําทางปัจจุบัน ซึ่งอาจเป็นค่าใดค่าหนึ่งต่อไปนี้

  • อยู่ระหว่างทาง - สถานะ GMSNavigationNavStateEnroute หมายความว่าระบบนำทางแบบมีคำแนะนำทำงานอยู่และผู้ใช้อยู่ในเส้นทางที่ระบุ ข้อมูลเกี่ยวกับขั้นตอนการจัดการที่กําลังจะเกิดขึ้นในปัจจุบันจะพร้อมใช้งาน

  • กำลังเปลี่ยนเส้นทาง - GMSNavigationNavStateRerouting หมายความว่าระบบกำลังนำทางอยู่ แต่ระบบนำทางกำลังมองหาเส้นทางใหม่ ขั้นตอนการเปลี่ยนเลนข้างหน้าจะใช้งานไม่ได้เนื่องจากยังไม่มีเส้นทางใหม่

  • หยุดแล้ว - GMSNavigationNavStateStopped หมายความว่าการนำทางสิ้นสุดแล้ว เช่น การนำทางจะหยุดเมื่อผู้ใช้ออกจากการนำทางในแอป ในแอปตัวอย่าง สถานะ GMSNavigationNavStateStopped จะล้างการแสดงข้อมูลการนำทางเพื่อป้องกันไม่ให้แสดงวิธีการแบบทีละขั้นตอนค้างไว้

คำแนะนำเลน

Navigation SDK จะแสดงเลนในการ์ดเลี้ยวของการนำทางเป็นออบเจ็กต์ข้อมูล GMSNavigationLane และ GMSNavigationLaneDirection ออบเจ็กต์ GMSNavigationLane แสดงเลนเฉพาะระหว่างการนําทาง และมีรายการออบเจ็กต์ GMSNavigationLaneDirection ที่อธิบายการเลี้ยวทั้งหมดที่ทำได้จากเลนนี้

ทิศทางที่แนะนำซึ่งผู้ขับขี่ควรใช้เลนจะได้รับการระบุโดยใช้ช่อง recommended

ตัวอย่างคำแนะนำช่องทาง

ข้อมูลโค้ดต่อไปนี้แสดงการนําเสนอข้อมูลของเลนที่แสดงในภาพหน้าจอก่อนหน้า

// Lane 1
GMSNavigationLaneDirections =
  [{/*GMSNavigationLaneShape=*/
GMSNavigationLaneShapeNormalLeft, /*recommended=*/ true}]

// Lane 2
GMSNavigationLaneDirections =
  [{/*GMSNavigationLaneShape=*/
GMSNavigationLaneShapeNormalLeft, /*recommended=*/ true}]

// Lane 3
GMSNavigationLaneDirections =
  [{/*GMSNavigationLaneShape=*/
GMSNavigationLaneShapeStraight, /*recommended=*/ false}]

// Lane 4
GMSNavigationLaneDirections =
  [{/*GMSNavigationLaneShape=*/
GMSNavigationLaneShapeStraight, /*recommended=*/ false},
{/*GMSNavigationLaneShape=*/ GMSNavigationLaneShapeNormalRight, /*recommended=*/ false}]

รูปภาพคำแนะนำช่องทาง

Navigation SDK รองรับการสร้างรูปภาพเลนสำหรับขั้นตอนการนำทางแต่ละขั้นตอนตามที่ GMSNavigationStepInfo ระบุ ไอคอนเหล่านี้เป็นไปตามคำแนะนำการปรับขนาดรูปภาพของ CarPlay

Swift

let currentStepInfo = navInfo.currentStep

let options = GMSNavigationStepImageOptions()
options.maneuverImageSize = .square96
options.screenMetrics = UIScreen.mainScreen

let maneuverImage = currentStepinfo.maneuverImage(options: options)
      

Objective-C

GMSNavigationStepInfo *stepInfo = navInfo.currentStep;

GMSNavigationStepImageOptions *options = [[GMSNavigationStepImageOptions alloc] init];
options.maneuverImageSize = GMSNavigationManeuverImageSizeSquare96;
options.screenMetrics = UIScreen.mainScreen;

UIImage* maneuverImage = [stepInfo maneuverImageWithOptions:options];
      

การสร้างไอคอนสำหรับการเคลื่อนไหว

ไอคอนการบังคับ

อนุกรม GMSNavigationManeuver กำหนดการหลบหลีกที่เป็นไปได้แต่ละรายการที่อาจเกิดขึ้นขณะนำทาง และคุณดูการหลบหลีกของขั้นตอนหนึ่งๆ ได้จากพร็อพเพอร์ตี้ maneuver ของ GMSNavigationStepInfo

คุณต้องสร้างไอคอนของกลยุทธ์และจับคู่กับกลยุทธ์ที่เกี่ยวข้อง สำหรับการเคลื่อนไหวบางอย่าง คุณสามารถตั้งค่าการแมปแบบ 1:1 กับไอคอนได้ เช่น GMSNavigationManeuverDestinationLeft และ GMSNavigationManeuverDestinationRight อย่างไรก็ตาม เนื่องจากการหลบเลี่ยงบางอย่างมีลักษณะคล้ายกับการหลบเลี่ยงอื่นๆ คุณจึงอาจต้องแมปการหลบเลี่ยงมากกว่า 1 รายการกับไอคอนเดียว เช่น GMSNavigationManeuverTurnLeft และ GMSNavigationManeuverOnRampLeft อาจแมปกับไอคอนเลี้ยวซ้ายได้ทั้งคู่

การหมุนบางรายการจะมีป้ายกำกับ "ตามเข็มนาฬิกา" หรือ "ทวนเข็มนาฬิกา" เพิ่มเติม ซึ่ง SDK จะกำหนดตามด้านที่ขับรถของประเทศ ตัวอย่างเช่น ในประเทศที่ขับรถทางด้านซ้ายของถนน ผู้ขับขี่จะเลี้ยวเข้าวงเวียนหรือเลี้ยวกลับทางตามเข็มนาฬิกา ส่วนประเทศที่ขับรถทางด้านขวาของถนนจะเลี้ยวตามทวนเข็มนาฬิกา Navigation SDK จะตรวจจับว่าการดำเนินการเปลี่ยนเลนเกิดขึ้นในช่องทางซ้ายหรือขวา และแสดงผลการดำเนินการที่เหมาะสม ดังนั้น ไอคอนการบังคับเลี้ยวของคุณจึงอาจแตกต่างกันไปสำหรับการดำเนินการแบบตามเข็มนาฬิกาและทวนเข็มนาฬิกา

ขยายเพื่อดูตัวอย่างไอคอนสำหรับการดำเนินการต่างๆ

ไอคอนตัวอย่าง เลี้ยวต่อเลี้ยว
DEPART
UNKNOWN
STRAIGHT
ON_RAMP_UNSPECIFIED
OFF_RAMP_UNSPECIFIED
NAME_CHANGE
TURN_RIGHT
ON_RAMP_RIGHT
TURN_LEFT
ON_RAMP_LEFT
TURN_SLIGHT_RIGHT
ON_RAMP_SLIGHT_RIGHT
OFF_RAMP_SLIGHT_RIGHT
TURN_SLIGHT_LEFT
ON_RAMP_SLIGHT_LEFT
OFF_RAMP_SLIGHT_LEFT
TURN_SHARP_RIGHT
ON_RAMP_SHARP_RIGHT
OFF_RAMP_SHARP_RIGHT
TURN_SHARP_LEFT
ON_RAMP_SHARP_LEFT
OFF_RAMP_SHARP_LEFT
TURN_U_TURN_COUNTERCLOCKWISE
ON_RAMP_U_TURN_COUNTERCLOCKWISE
OFF_RAMP_U_TURN_COUNTERCLOCKWISE
TURN_U_TURN_CLOCKWISE
ON_RAMP_U_TURN_CLOCKWISE
OFF_RAMP_U_TURN_CLOCKWISE
ROUNDABOUT_SHARP_RIGHT_COUNTERCLOCKWISE
ROUNDABOUT_SHARP_RIGHT_CLOCKWISE
ROUNDABOUT_RIGHT_COUNTERCLOCKWISE
ROUNDABOUT_RIGHT_CLOCKWISE
ROUNDABOUT_SLIGHT_RIGHT_COUNTERCLOCKWISE
ROUNDABOUT_SLIGHT_RIGHT_CLOCKWISE
ROUNDABOUT_STRAIGHT_COUNTERCLOCKWISE
ROUNDABOUT_STRAIGHT_CLOCKWISE
ROUNDABOUT_SLIGHT_LEFT_COUNTERCLOCKWISE
ROUNDABOUT_SLIGHT_LEFT_CLOCKWISE
ROUNDABOUT_LEFT_COUNTERCLOCKWISE
ROUNDABOUT_LEFT_CLOCKWISE
ROUNDABOUT_SHARP_LEFT_COUNTERCLOCKWISE
ROUNDABOUT_SHARP_LEFT_CLOCKWISE
ROUNDABOUT_U_TURN_COUNTERCLOCKWISE
ROUNDABOUT_U_TURN_CLOCKWISE
ROUNDABOUT_COUNTERCLOCKWISE
ROUNDABOUT_CLOCKWISE
ROUNDABOUT_EXIT_COUNTERCLOCKWISE
ROUNDABOUT_EXIT_CLOCKWISE
MERGE_RIGHT
OFF_RAMP_RIGHT
MERGE_LEFT
OFF_RAMP_LEFT
FORK_RIGHT
TURN_KEEP_RIGHT
ON_RAMP_KEEP_RIGHT
OFF_RAMP_KEEP_RIGHT
FORK_LEFT
TURN_KEEP_LEFT
ON_RAMP_KEEP_LEFT
OFF_RAMP_KEEP_LEFT
MERGE_UNSPECIFIED
DESTINATION
DESTINATION_RIGHT
DESTINATION_LEFT
FERRY_BOAT
FERRY_TRAIN

ใช้ไอคอนที่สร้างขึ้น

Navigation SDK รองรับการสร้างไอคอนการเลี้ยวสําหรับ GMSNavigationStepInfo หนึ่งๆ ไอคอนเหล่านี้เป็นไปตามคำแนะนำการปรับขนาดรูปภาพ CarPlay

Swift

let currentStepInfo = navInfo.currentStep

let options = GMSNavigationStepImageOptions()
options.maneuverImageSize = .square96
options.screenMetrics = UIScreen.mainScreen

let maneuverImage = currentStepinfo.maneuverImage(options: options)
      

Objective-C

GMSNavigationStepInfo *stepInfo = navInfo.currentStep;

GMSNavigationStepImageOptions *options = [[GMSNavigationStepImageOptions alloc] init];
options.maneuverImageSize = GMSNavigationManeuverImageSizeSquare96;
options.screenMetrics = UIScreen.mainScreen;

UIImage* maneuverImage = [stepInfo maneuverImageWithOptions:options];