פיד נתונים של מסלול מפורט מספק מידע על ניווט בלבד למכשירים שלא תוכננו להנחיות ניווט שמבוססות על מפה. הוא מספק לכם מידע על תמרונים קרובים באמצעות רכיבים שאתם מספקים:
- סמלים (שמאלה, ימינה, פניית פרסה)
- מספרי פינות בריבועים
- שמות של כבישים
- המרחק והזמן המשוערים לשלב הבא בניווט או ליעד הסופי
אפשר להשתמש בפיד של מסלול מפורט כדי ליצור חוויות שבהן ממשק המשתמש המלא של 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. פרטים נוספים זמינים בתיעוד העזרה של Android לגבי setsLaneImage ו-CarIcon.
דוגמה ליצירת סמל
NavigationUpdatesOptions options =
NavigationUpdatesOptions.builder()
.setNumNextStepsToPreview(numNextStepsToPreview)
.setGeneratedStepImagesType(GeneratedStepImagesType.BITMAP)
.setDisplayMetrics(getResources().getDisplayMetrics())
.build();
boolean isRegistered =
navigator.registerServiceForNavUpdates(
getPackageName(),
NavInfoReceivingService.class.getName(),
options);
אחרי שמפעילים את יצירת הסמלים, האובייקט StepInfo
של מסלול הניווט מעדכן את השדות maneuverBitmap ו-lanesBitmap בסמלים.
המאמרים הבאים
- באפליקציות ל-Android Auto: