פיד נתונים של מסלול מפורט מספק מידע על ניווט בלבד למכשירים שלא תוכננו להנחיות ניווט שמבוססות על מפה. הוא מספק תמונה של תמרונים עתידיים עם רכיבים שאתם מספקים:
- סמלים (שמאלה, ימינה, פניית פרסה)
- מספרי פנייה במעגלי תנועה
- שמות של כבישים
- המרחק והזמן המשוערים לשלב הבא בניווט או ליעד הסופי
אפשר להשתמש בפיד של מסלול מפורט כדי ליצור חוויות שבהן ממשק המשתמש המלא של Navigation SDK לא מתאים, למשל ב-Android Auto או במסכים קטנים שבהם סטאק Android מלא לא זמין. לדוגמה, תוכלו להשתמש בכך לנהגים של כלי רכב דו-גלגליים, ולפרויקט הנחיות ניווט בלבד כדי לעזור להם להגיע ליעדים מהר יותר ובביטחון רב יותר, עם מינימום הסחות דעת.
כדי להשתמש ב-SDK, צריך ליצור שירות ולרשום אותו ב-Navigation SDK ל-Android כדי שיוכל לקבל מידע ניווט חדש בזמן אמת (בערך פעם בשנייה במהלך הניווט).
במסמך הזה מוסבר איך ליצור ולרשום שירות ניווט שמקבל מידע על ניווט מה-SDK ומספק את מצב הניווט למכשיר המקבל.
סקירה כללית
בקטע הזה מוסבר איך להוסיף את הספרייה TurnByTurn לפרויקטים, ומצוין סיכום של התהליך הכללי ליצירת פונקציונליות של מסלול מפורט.
הוספת ספריית TurnByTurn לפרויקט באמצעות Maven (מומלץ)
כדי לצרוך גרסה עצמאית של ספריית TurnByTurn:
- מגדירים את הסביבה כך שתהיה לה גישה למאגר 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() }
- מוסיפים את התלות הבאה לתצורה של Maven או Gradle:
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 הזו. אם אין לכם גישה, פנו לנציג שלכם.
- מורידים את הקובץ
google_turnbyturn_*.jar
ופותחים את הארכיון. - מעתיקים את קובץ ה-JAR שהורדתם לתיקייה
app/libs
של הפרויקט. מוסיפים את הקטע הבא לקובץ
build.gradle
כדי לכלול את קובץ ה-JAR ב-build.dependencies { ... api fileTree(include: ['*.jar'], dir: 'libs') }
שימוש בספרייה של 'הוראות ניווט'
ריכזנו כאן את השלבים העיקריים להפעלת הפונקציונליות של מסלול מפורט. בקטעים הבאים מוסבר בהרחבה על כל שלב.
יצירת שירות לקבלת עדכוני ניווט
Navigation SDK מתחבר לשירות הניווט במסלול מפורט ושולח לו עדכוני ניווט דרך 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);
הפעלה והפסקה של השירות
שירות הניווט פעיל כל עוד Navigation SDK מקושר אליו. אפשר להפעיל את הפונקציות startService()
ו-stopService()
באופן ידני כדי לשלוט במחזור החיים של שירות הניווט, אבל כשרושמים את השירות ב-Navigation SDK, הוא מופעל באופן אוטומטי ומופסק רק כשמבטלים את הרישום שלו. בהתאם לאופן שבו מגדירים את האפליקציה, כדאי לשקול להפעיל שירות שפועל בחזית, כפי שמתואר במאמר סקירה כללית על שירותים במסמכי העזרה של Android.
ביטול הרישום של השירות
כדי להפסיק לקבל עדכוני ניווט, צריך לבטל את הרישום של השירות ב-Navigation SDK.
navigator.unregisterServiceForNavUpdates();
הסבר על מצבי הניווט
משתמשים ב-NavInfo.getNavState()
כדי לקבל את המצב הנוכחי של הניווט, שהוא אחד מהמצבים הבאים:
בדרך – המצב
ENROUTE
מציין שהניווט המלווה פעיל כרגע והמשתמש נמצא במסלול שסופק. מידע על השלב הנוכחי של התמרון הקרוב זמין.שינוי מסלול –
REROUTING
מציין שהניווט מתבצע, אבל המערכת מחפשת מסלול חדש. שלב התמרון הקרוב לא זמין כי עדיין אין מסלול חדש. באפליקציה לדוגמה, ההודעה 'שינוי מסלול…' מופיעה במסך פרטי הניווט. אחרי שמוצאים מסלול, נשלחת הודעתNavInfo
עם המצבENROUTE
.הושעה –
STOPPED
המשמעות היא שהניווט הסתיים. לדוגמה, הניווט מפסיק כשהמשתמש יוצא מהניווט באפליקציה. באפליקציית הדוגמה, המצבSTOPPED
מנקה את תצוגת המידע של הניווט כדי למנוע הצגה של הוראות של שלבים שעדיין לא בוצעו.
איך מאכלסים את תצוגת הפיד
אחרי שמגדירים את השירות של המסלול המפורט, בקטע הזה מוסבר איך להשתמש ברכיבי הטקסט והגרפיקה כדי לאכלס את כרטיסי ההנחיות בפיד המסלול המפורט.
שדות המידע בכרטיס הניווט
כשהמשתמש נכנס לניווט מודרך, מופיע כרטיס ניווט בחלק העליון, שמכיל נתוני ניווט שמאוכלסים מ-Navigation SDK. בתמונה הקשורה מוצגת דוגמה לרכיבי הניווט החיוניים האלה.
בטבלה הזו מוצגים השדות של פרטי הניווט והמקום שבו הם נמצאים.
שדות לכל שלב ניווט | שדות של הנסיעה הכוללת |
---|---|
נמצא ב-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}]
יצירת סמלים לתמרונים
המאפיין Maneuver
מגדיר כל תמרון אפשרי שיכול להתרחש במהלך הניווט, ואפשר לקבל את התמרון של שלב נתון מהשיטה StepInfo.getManeuver()
.
צריך ליצור סמלי תמרון ולהתאימם לתמרונים המשויכים.
למהלכים מסוימים, אפשר להגדיר מיפוי אחד-לאחד לסמל, כמו DESTINATION_LEFT
ו-DESTINATION_RIGHT
. עם זאת, מכיוון שחלק מהתמרונים דומים, יכול להיות שתרצו למפות יותר מתמרון אחד לסמל אחד. לדוגמה, אפשר למפות את TURN_LEFT
ואת ON_RAMP_LEFT
לסמל של פנייה שמאלה.
חלק מהתמרונים מכילים תווית clockwise
או counterclockwise
נוספת, שה-SDK קובע על סמך צד הנסיעה במדינה. לדוגמה, במדינות שבהן נוהגים בצד ימין של הכביש, נהגים עוברים במעגל תנועה או מבצעים פניית U בכיוון השעון, ואילו במדינות שבהן נוהגים בצד ימין של הכביש, הם עוברים במעגל תנועה או מבצעים פניית U בכיוון שעון. 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
|
שימוש בסמלים שנוצרו
כדי לאפשר תרחישים לדוגמה של שימוש ב-Android Auto, Navigation SDK תומך ביצירת סמלי הנחיה לתנועה ולנתיב. הסמלים האלה תואמים להנחיות לגבי גודל התמונות בספריית אפליקציות הרכב של Android Auto, שבהן מומלץ לטרגט תיבת מלבנית בגודל 500 x 74dp. פרטים נוספים זמינים במאמרים 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);
אחרי שמפעילים את יצירת הסמלים, האובייקט StepInfo
של TurnbyTurn מאכלס את השדות maneuverBitmap ו-lanesBitmap בסמלים.
המאמרים הבאים
- באפליקציות ל-Android Auto: