פיד נתונים של מסלול מפורט מספק מידע ניווט בלבד למכשירים שלא מיועדים לפעול לפי הנחיות ניווט מבוססות-מפה. היא כוללת תמרונים עתידיים עם רכיבים שאתם מספקים:
- סמלים (שמאלה, ימינה, סיבוב פרסה)
- הופכים מספרים בכיכרות
- שמות של כבישים
- המרחקים המשוערים והזמן המשוער עד לשלב הבא בניווט או ליעד הסופי
אפשר להשתמש בפיד המפורט כדי ליצור חוויות שבהן ממשק המשתמש המלא של ה-SDK לא מתאים, למשל ל-Android Auto או לצגים במסכים קטנים שבהם אין סטאק מלא של Android. לדוגמה, אפשר להשתמש בהגדרה הזו לנוסעים בכלי רכב דו-גלגליים, שבה אפשר להציג הנחיות ניווט בלבד כדי לעזור להם להגיע ליעדים שלהם מהר יותר ובביטחון רב יותר, עם כמה שפחות הסחות דעת.
כדי להשתמש ב-SDK, יש ליצור שירות ולרשום אותו ב-Navigation SDK ל-Android, כך שיוכל לקבל פרטי ניווט חדשים בזמן אמת (בערך פעם שנייה במהלך הניווט).
במסמך הזה נסביר איך ליצור ולרשום שירות ניווט שמקבל פרטי ניווט מה-SDK ומספק את מצב הניווט למכשיר המקבל.
סקירה כללית
בקטע הזה נסביר איך להוסיף את הספרייה TurnByTurn לפרויקטים שלכם, ומסכמים את התהליך הכללי לבניית פונקציונליות של מסלול מפורט.
הוספת ספריית TurnByTurn לפרויקט באמצעות Maven (מומלץ)
כדי לצרוך גרסה עצמאית של ספריית TurnByTurn, צריך לבצע את הפעולות הבאות:
מגדירים את הסביבה כדי לגשת למאגר Maven המארח, כפי שמתואר במאמר תחילת העבודה עם ה-SDK של Drive במסמכי התיעוד בנושא נסיעות והזמנה.
מוסיפים את התלות הבאה להגדרות של 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
של הפרויקט. כדי לכלול את ה-JAR ב-build, צריך להוסיף את הערכים הבאים ל-
build.gradle
.dependencies { ... api fileTree(include: ['*.jar'], dir: 'libs') }
שימוש בספרייה TurnByTurn
אלה השלבים הכלליים להפעלת פונקציונליות של מסלול מפורט. הקטעים הבאים מספקים פרטים לגבי כל שלב.
יצירת שירות כדי לקבל עדכוני ניווט {#service}
ה-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
.
רישום השירות לעדכוני ניווט {#register}
קטעי הקוד הבאים רושמים את שירות הניווט.
boolean isNavInfoReceivingServiceRegistered = navigator.registerServiceForNavUpdates( getPackageName(), NavInfoReceivingService.class.getName(), numNextStepsToPreview);
הפעלה ועצירה של השירות
שירות הניווט פעיל כל עוד ה-SDK של הניווט קשור אליו. אפשר לבצע קריאה ידנית אל startService()
ואל stopService()
כדי לשלוט במחזור החיים של שירות הניווט, אבל כשרושמים את השירות ב-Navigation SDK, השירות מתחיל באופן אוטומטי ומפסיק רק כשמבטלים את הרישום. בהתאם לאופן שבו מגדירים את האפליקציה, יכול להיות שתרצו להפעיל שירות שפועל בחזית, כפי שמתואר בסקירה הכללית על השירותים במסמכי התיעוד של Android.
ביטול הרישום של השירות
כדי להפסיק לקבל עדכוני ניווט, צריך לבטל את הרישום של השירות ב-Navigation SDK.
navigator.unregisterServiceForNavUpdates();
הסבר על מצבי הניווט {#states}
משתמשים ב-NavInfo.getNavState()
כדי לקבל את מצב הניווט הנוכחי, שהוא אחד
מהמצבים הבאים:
Enroute – המצב
ENROUTE
מציין שהניווט המודרך פעיל כרגע והמשתמש נמצא במסלול שצוין. יש מידע על השלב הנוכחי בתמרון.ניתוב מחדש –
REROUTING
המשמעות היא שהניווט מתבצע אבל הניווט מחפש מסלול חדש. שלב התמרון הקרוב לא זמין, כי עדיין אין מסלול חדש. באפליקציה לדוגמה תופיע ההודעה "ניתוב מחדש..." במסך פרטי הניווט. אחרי שנמצא מסלול, נשלחת הודעתNavInfo
עם המצבENROUTE
.נעצר –
STOPPED
המשמעות היא שהניווט הסתיים. לדוגמה, הניווט מפסיק כשהמשתמש יוצא מהניווט באפליקציה. באפליקציה לדוגמה, מצבSTOPPED
מנקה את תצוגת פרטי הניווט כדי למנוע הצגה של ההוראות לשלבים.
אכלוס של תצוגת הפיד
עכשיו, לאחר שהגדרתם את שירות המסלול המפורט, הקטע הבא מפרט את הרכיבים החזותיים ורכיבי הטקסט שבהם תוכלו להשתמש כדי לאכלס את כרטיסי הניווט של הפיד המפורט.
שדות מידע של כרטיס הניווט
כשהנהג נכנס לניווט מודרך, מופיע בחלק העליון כרטיס ניווט עם תאריך הניווט שמוצג ב-API של הניווט. בתמונה הקשורה מוצגת דוגמה לרכיבי הניווט החיוניים האלה.
בטבלה הזו מוצגים השדות לפרטי הניווט והמקומות שבהם הם מוצגים.
השדות לכל שלב בניווט | שדות לנסיעה הכוללת |
---|---|
נמצא בStepInfo |
נמצא בNavInfo |
השם המלא של הכביש | הזמן שנותר |
סמל התמרון | מרחק ליעד |
המרחק לשלב הבא | |
שדות הנחייה בין נתיבים |
הנחייה בין נתיבים
ה-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
מגדיר כל תמרון אפשרי שיכול להתרחש בזמן הניווט, ואפשר לקבל את התמרון עבור שלב נתון מ-method StepInfo.getManeuver()
.
עליכם ליצור סמלי תמרון ולהתאים אותם לתמרונים שמשויכים אליהם.
בתמרונים מסוימים אפשר להגדיר מיפוי אחד לאחד לסמל, כמו DESTINATION_LEFT
ו-DESTINATION_RIGHT
. עם זאת, מכיוון שיש תמרונים דומים, כדאי למפות יותר מתמרון אחד לסמל אחד. לדוגמה,
TURN_LEFT
וגם ON_RAMP_LEFT
יכולים למפות לסמל הפנייה שמאלה.
חלק מהתמרונים כוללים תווית נוספת של clockwise
או counterclockwise
, שאותה מערכת ה-SDK קובעת על סמך הגורם הנהיגה במדינה. לדוגמה, במדינות שבהן הנסיעה היא בצד שמאל של הדרך, נהגים פונים לכיכר או לבצע פניית פרסה בכיוון השעון, בעוד שהמדינות שנמצאות מימין לכביש נעות בכיוון השעון. 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
|
שימוש בסמלים שנוצרו
כדי להקל על תרחישים לדוגמה של 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);
אחרי שמפעילים את יצירת הסמלים, האובייקט StepInfo
TurnbyTurn מאכלס את הסמלים maneuverBitmap ו-lanesBitmap.
המאמרים הבאים
- באפליקציות ל-Android Auto: