เปิดใช้ฟีดข้อมูลแบบเลี้ยวต่อเลี้ยว

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

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

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

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

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

ภาพรวม

ส่วนนี้จะอธิบายวิธีเพิ่มไลบรารี TurnByTurn ลงในโปรเจ็กต์และสรุปขั้นตอนระดับสูงสำหรับการสร้างฟังก์ชันแบบเลี้ยวต่อเลี้ยว

หากต้องการใช้ไลบรารี TurnByTurn เวอร์ชันสแตนด์อโลน ให้ทำตามขั้นตอนต่อไปนี้

  1. ตั้งค่าสภาพแวดล้อมเพื่อเข้าถึงที่เก็บของโฮสต์ Maven ดังนี้

    Maven

    เพิ่มโค้ดต่อไปนี้ในไฟล์ pom.xml

        <project>
          ...
          <repositories>
            <repository>
              <id>google-maven-repository</id>
              <url>https://maven.google.com</url>
            </repository>
          </repositories>
          ...
        </project>
        
        

    Gradle

    เพิ่มโค้ดต่อไปนี้ในไฟล์ build.gradle

    repositories {
        ...
        google()
    }
        
  2. เพิ่มทรัพยากร Dependency ต่อไปนี้ในการกำหนดค่า Maven หรือ Gradle
  3. Maven

    <dependencies>
    ...
    <dependency>
          <groupId>com.google.android.maps</groupId>
          <artifactId>google_turnbyturn</artifactId>
          <version>1.0.0</version>
    </dependency>
    </dependencies>
        
        

    Gradle

    dependencies {
      ...
      implementation 'com.google.android.maps:google_turnbyturn:1.0.0'
    }
        

เพิ่มไลบรารี TurnByTurn ลงในโปรเจ็กต์โดยใช้ไฟล์ JAR ที่ดาวน์โหลดมา (ทางเลือก)

ไลบรารี TurnByTurn พร้อมใช้งานเป็นไฟล์ JAR ในโฟลเดอร์ SDK นี้ หากคุณไม่มีสิทธิ์เข้าถึง โปรดติดต่อตัวแทนของคุณ

  1. ดาวน์โหลดและปลดซิป google_turnbyturn_*.jar
  2. คัดลอกไฟล์ JAR ที่ดาวน์โหลดไว้ในไดเรกทอรี app/libs ของโปรเจ็กต์
  3. เพิ่มรายการต่อไปนี้ลงใน build.gradle เพื่อรวม JAR ในบิลด์ของคุณ

    dependencies {
       ...
       api fileTree(include: ['*.jar'], dir: 'libs')
    }
    

การใช้ไลบรารี TurnByTurn

ขั้นตอนระดับสูงสำหรับการเปิดการใช้งานฟังก์ชันแบบเลี้ยวต่อเลี้ยวมีดังนี้ ส่วนต่อไปนี้จะให้รายละเอียดเกี่ยวกับแต่ละขั้นตอน

  1. สร้างบริการเพื่อรับข้อมูลอัปเดตการนำทาง

  2. ลงทะเบียนบริการ

  3. ทำความเข้าใจสถานะการนำทาง

  4. ดูตัวอย่างการแสดงการนำทางที่แสดงองค์ประกอบที่สำคัญ

สร้างบริการเพื่อรับข้อมูลอัปเดตการนำทาง

Navigation SDK จะเชื่อมโยงกับบริการ TurnByTurn ของคุณและส่งการอัปเดตการนำทางผ่าน Android Messenger คุณจะสร้างบริการนำทางใหม่สำหรับการอัปเดตเหล่านี้หรือใช้บริการที่มีอยู่ก็ได้

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

บริการในตัวอย่างต่อไปนี้จะได้รับข้อมูลการนำทาง และใช้ TurnByTurnManager เพื่อแปลงข้อมูลเป็นออบเจ็กต์ NavInfo ที่มีรายละเอียดการนำทาง

/**
 *   Receives turn-by-turn navigation information forwarded from NavSDK.
 */
public class NavInfoReceivingService extends Service {
  /** The messenger used by the service to receive nav step updates. */
  private Messenger incomingMessenger;
  private TurnByTurnManager turnByTurnManager;

  private final class IncomingNavStepHandler extends Handler {
    public IncomingNavStepHandler(Looper looper) {
      super(looper);
    }

    @Override
    public void handleMessage(Message msg) {
      // Identify the message through the msg.what field.
      if (TurnByTurnManager.MSG_NAV_INFO == msg.what) {
        // Extract the NavInfo object using the TurnByTurnManager.
        NavInfo navInfo = turnByTurnManager
          .readNavInfoFromBundle(msg.getData()));
      // Do something with the NavInfo
    }
  }
}

@Nullable
@Override
public IBinder onBind(Intent intent) {
  return incomingMessenger.getBinder();
}

@Override
public void onCreate() {
  turnByTurnManager = TurnByTurnManager.createInstance();
  HandlerThread thread =
    new HandlerThread("NavInfoReceivingService",
      Process.THREAD_PRIORITY_DEFAULT);
  thread.start();
  incomingMessenger = new Messenger(
    new IncomingNavStepHandler(thread.getLooper()));
}

รหัสข้อความ

ระบุข้อความ NavInfo รายการได้ในช่อง Message.what ของคลาส Message ซึ่งตั้งค่าไว้เป็น TurnByTurnManager.MSG_NAV_INFO

การลงทะเบียนบริการเพื่ออัปเดตการนำทาง

ข้อมูลโค้ดต่อไปนี้ลงทะเบียนบริการนำทาง

boolean isNavInfoReceivingServiceRegistered =
          navigator.registerServiceForNavUpdates(
              getPackageName(), NavInfoReceivingService.class.getName(), numNextStepsToPreview);

การเริ่มและการหยุดบริการ

บริการนำทางจะทำงานตราบใดที่ มีการเชื่อมโยงกับ SDK การนำทาง คุณจะเรียกใช้ startService() และ stopService() ด้วยตนเองเพื่อควบคุมวงจรของบริการนำทางได้ แต่เมื่อคุณลงทะเบียนบริการกับ Navigation SDK บริการของคุณจะเริ่มทำงานโดยอัตโนมัติและจะหยุดเฉพาะเมื่อคุณยกเลิกการลงทะเบียนเท่านั้น คุณอาจต้องลองเริ่มบริการที่ทำงานอยู่เบื้องหน้าตามที่อธิบายไว้ในภาพรวมบริการของเอกสารประกอบของ Android ทั้งนี้ขึ้นอยู่กับวิธีตั้งค่าแอป

การยกเลิกการลงทะเบียนบริการ

หากต้องการหยุดรับการอัปเดตการนำทาง ให้ยกเลิกการลงทะเบียนบริการจาก Navigation SDK

navigator.unregisterServiceForNavUpdates();

ทำความเข้าใจสถานะการนำทาง

ใช้ NavInfo.getNavState() เพื่อดูสถานะปัจจุบันของการนำทาง ซึ่งเป็นอย่างใดอย่างหนึ่งต่อไปนี้

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

  • กำลังเปลี่ยนเส้นทาง - REROUTING หมายความว่าการนำทางกำลังอยู่ระหว่างดำเนินการ แต่ผู้นำทางกำลังมองหาเส้นทางใหม่ ยังไม่มีแผนการเคลื่อนที่เร็วๆ นี้ เพราะยังไม่มีเส้นทางใหม่ ในแอปตัวอย่าง ข้อความ "กำลังเปลี่ยนเส้นทาง..." จะปรากฏในการแสดงข้อมูลการนำทาง เมื่อพบเส้นทางแล้ว ระบบจะส่งข้อความ NavInfo พร้อมสถานะ ENROUTE

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

ป้อนข้อมูลเพื่อแสดงฟีด

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

หน้าจอมือถือแสดงเลี้ยวซ้ายที่กำลังจะมาถึงในอีก 100 ฟุตเข้าสู่ W Ahwanee Ave. ที่ด้านล่างของหน้าจอ เหลือเวลาอีก 46 นาทีและเหลือระยะทาง 39 ไมล์

เมื่อผู้ใช้เข้าสู่การนำทางที่มีคำแนะนำ การ์ดการนำทางจะปรากฏที่ด้านบน และมีข้อมูลการนำทางที่สร้างจาก รหัสการนำทาง รูปภาพที่เกี่ยวข้องจะแสดงตัวอย่าง องค์ประกอบการนำทางที่สำคัญเหล่านี้

ตารางนี้แสดงช่องสำหรับข้อมูลการนำทางและตำแหน่งที่จะพบช่อง

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

คำแนะนำช่องทาง

Navigation SDK แสดงช่องทางในการ์ดเลี้ยวนำทางเป็นออบเจ็กต์ข้อมูล Lane และ LaneDirection วัตถุ Lane แสดงถึงเลนที่เจาะจงระหว่างการนำทางและมีรายการ LaneDirection ออบเจ็กต์ที่อธิบายการเลี้ยวทั้งหมดที่สามารถทำได้จากเลนนี้

ตัวอย่างการกำหนดค่า
คำแนะนำช่องทาง

เส้นทางที่แนะนำที่ผู้ใช้ควรใช้ในเลนจะมีเครื่องหมายบอกเป็นช่อง isRecommended

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

ข้อมูลโค้ดต่อไปนี้จะแสดงข้อมูลของช่องทางที่แสดงด้านบน

// Lane 1
LaneDirections = [{/*laneShape=*/ STRAIGHT, /*isRecommended=*/ false},
                  {/*laneShape=*/ SLIGHT_LEFT, /*isRecommended=*/ true}]

// Lane 2
LaneDirections = [{/*laneShape=*/ STRAIGHT, /*isRecommended=*/ false}]

สร้างไอคอนสำหรับการขับขี่

enum ของ Maneuver จะกำหนดวิธีที่เป็นไปได้แต่ละรายการที่อาจเกิดขึ้นขณะนำทาง และคุณสามารถดูวิธีสำหรับขั้นตอนหนึ่งๆ จากเมธอด StepInfo.getManeuver() ได้

คุณต้องสร้างไอคอนการเคลื่อนย้ายและจับคู่กับวิธีที่เกี่ยวข้อง สำหรับกระบวนการบางอย่าง คุณสามารถตั้งค่าการแมปแบบหนึ่งต่อหนึ่งกับไอคอน เช่น DESTINATION_LEFT และ DESTINATION_RIGHT ได้ อย่างไรก็ตาม เนื่องจากขั้นตอนบางอย่างมีความคล้ายคลึงกัน คุณอาจต้องจับคู่วิธีการจัดวางมากกว่า 1 แบบกับไอคอนเดียว ตัวอย่างเช่น ทั้ง TURN_LEFT และ ON_RAMP_LEFT จะแมปกับไอคอนเลี้ยวซ้ายได้

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

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

ไอคอนตัวอย่าง กระบวนการ TurnByTurn
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

เพื่ออำนวยความสะดวกต่อกรณีการใช้งานของ Android Auto การนำทาง SDK รองรับการสร้างไอคอนการนำทางและไอคอนการนำทางช่องทาง ไอคอนเหล่านี้เหมาะกับหลักเกณฑ์การปรับขนาดรูปภาพของไลบรารีแอปรถยนต์ของ Android Auto ซึ่งแนะนำให้กำหนดเป้าหมายไปยังกรอบล้อมรอบ 500 x 74 dp ดูรายละเอียดได้ที่ setsLaneImage และ CarIcon ในเอกสารอ้างอิงของ Android

ตัวอย่างการสร้างไอคอน

NavigationUpdatesOptions options =
  NavigationUpdatesOptions.builder()
             .setNumNextStepsToPreview(numNextStepsToPreview)
             .setGeneratedStepImagesType(GeneratedStepImagesType.BITMAP)
             .setDisplayMetrics(getResources().getDisplayMetrics())
             .build();
boolean isRegistered =
          navigator.registerServiceForNavUpdates(
              getPackageName(),
              NavInfoReceivingService.class.getName(),
              options);

หลังจากเปิดใช้การสร้างไอคอน ออบเจ็กต์ TurnbyTurn StepInfo จะเติมไอคอนในช่อง maneuverBitmap และ lanesBitmap

ขั้นตอนถัดไป