अपने ऐप्लिकेशन में किसी एक जगह का रास्ता दिखाने के लिए, इस गाइड को फ़ॉलो करें. इसके लिए, iOS के लिए Navigation SDK का इस्तेमाल करें.
खास जानकारी
- अपने ऐप्लिकेशन में Navigation SDK को इंटिग्रेट करें, जैसा कि अपने प्रोजेक्ट को सेट अप करें सेक्शन में बताया गया है.
GMSMapViewकॉन्फ़िगर करें.- उपयोगकर्ता से नियम और शर्तें स्वीकार करने के लिए कहें. साथ ही, जगह की जानकारी की सेवाओं और बैकग्राउंड में सूचनाएं दिखाने की अनुमति लें.
- एक या उससे ज़्यादा जगहों वाला कलेक्शन बनाएं.
मोड़-दर-मोड़ नेविगेशन को कंट्रोल करने के लिए,
GMSNavigatorतय करें.setDestinationsका इस्तेमाल करके, जगहें जोड़ें.- नेविगेशन शुरू करने के लिए,
isGuidanceActiveकोtrueपर सेट करें. - टेस्टिंग,
डीबग करने, और अपने ऐप्लिकेशन को दिखाने के लिए,
simulateLocationsAlongExistingRouteका इस्तेमाल करके, रास्ते पर वाहन की प्रोग्रेस को सिम्युलेट करें.
कोड देखें
ज़रूरी अनुमतियों के लिए, उपयोगकर्ता से अनुमति लें
Navigation SDK का इस्तेमाल करने से पहले, उपयोगकर्ता को नियम और शर्तों से सहमत होना होगा. साथ ही, जगह की जानकारी की सेवाओं के इस्तेमाल की अनुमति देनी होगी. नेविगेशन के लिए, यह ज़रूरी है. अगर आपका ऐप्लिकेशन बैकग्राउंड में चलेगा, तो उसे उपयोगकर्ता से, रास्ते की जानकारी देने वाली चेतावनियों की सूचनाएं दिखाने की अनुमति भी लेनी होगी. इस सेक्शन में, अनुमति के लिए ज़रूरी प्रॉम्प्ट दिखाने का तरीका बताया गया है.
जगह की जानकारी की सेवाओं के इस्तेमाल की अनुमति लेना
Navigation SDK, जगह की जानकारी की सेवाओं का इस्तेमाल करता है. इसके लिए, उपयोगकर्ता की अनुमति ज़रूरी है. जगह की जानकारी की सेवाओं को चालू करने और अनुमति का डायलॉग बॉक्स दिखाने के लिए, यह तरीका अपनाएं:
Info.plistमें,NSLocationWhenInUseUsageDescriptionऔरNSLocationAlwaysAndWhenInUseUsageकी जोड़ें.वैल्यू के लिए, कम शब्दों में यह जानकारी दें कि आपके ऐप्लिकेशन को जगह की जानकारी की सेवाओं की ज़रूरत क्यों है. उदाहरण के लिए: "मोड़-दर-मोड़ नेविगेशन के लिए, इस ऐप्लिकेशन को जगह की जानकारी की सेवाओं के इस्तेमाल की अनुमति चाहिए."
अनुमति का डायलॉग बॉक्स दिखाने के लिए, जगह की जानकारी के मैनेजर इंस्टेंस के
requestAlwaysAuthorization()तरीके को कॉल करें.
Swift
self.locationManager.requestAlwaysAuthorization()
Objective-C
[_locationManager requestAlwaysAuthorization];
जगह की जानकारी की सेवा की अनुमति के बारे में पूरी जानकारी के लिए, Apple का दस्तावेज़ देखें.
बैकग्राउंड में रास्ते की जानकारी देने वाली चेतावनियों की सूचनाएं दिखाने की अनुमति लेना
जब ऐप्लिकेशन बैकग्राउंड में चल रहा हो, तब चेतावनियों की सूचनाएं दिखाने के लिए, Navigation SDK को उपयोगकर्ता की अनुमति चाहिए. इन सूचनाओं को दिखाने की अनुमति के लिए, उपयोगकर्ता से अनुमति लेने के लिए यह कोड जोड़ें:
Swift
UNUserNotificationCenter.current().requestAuthorization(options: [.alert]) {
granted, error in
// Handle denied authorization to display notifications.
if !granted || error != nil {
print("User rejected request to display notifications.")
}
}
Objective-C
// Request authorization for alert notifications.
UNUserNotificationCenter *center = [UNUserNotificationCenter currentNotificationCenter];
UNAuthorizationOptions options = UNAuthorizationOptionAlert;
[center requestAuthorizationWithOptions:options
completionHandler:
^(
BOOL granted,
NSError *_Nullable error) {
if (!error && granted) {
NSLog(@"iOS Notification Permission: newly Granted");
} else {
NSLog(@"iOS Notification Permission: Failed or Denied");
}
}];
नियम और शर्तें स्वीकार करना
नियम और शर्तों का डायलॉग बॉक्स दिखाने के लिए, यह कोड इस्तेमाल करें. साथ ही, जब उपयोगकर्ता नियम और शर्तें स्वीकार कर ले, तब नेविगेशन की सुविधा चालू करें. ध्यान दें कि इस उदाहरण में, जगह की जानकारी की सेवाओं और रास्ते की जानकारी देने वाली चेतावनियों की सूचनाओं के लिए कोड शामिल है. यह कोड पहले दिखाया गया है.
Swift
let termsAndConditionsOptions = GMSNavigationTermsAndConditionsOptions(companyName: "Ride Sharing Co.")
GMSNavigationServices.showTermsAndConditionsDialogIfNeeded(
with: termsAndConditionsOptions) { termsAccepted in
if termsAccepted {
// Enable navigation if the user accepts the terms.
self.mapView.isNavigationEnabled = true
self.mapView.settings.compassButton = true
// Request authorization to use location services.
self.locationManager.requestAlwaysAuthorization()
// Request authorization for alert notifications which deliver guidance instructions
// in the background.
UNUserNotificationCenter.current().requestAuthorization(options: [.alert]) {
granted, error in
// Handle rejection of notification authorization.
if !granted || error != nil {
print("Authorization to deliver notifications was rejected.")
}
}
} else {
// Handle rejection of terms and conditions.
}
}
Objective-C
GMSNavigationTermsAndConditionsOptions *termsAndConditionsOptions = [[GMSNavigationTermsAndConditionsOptions alloc] initWithCompanyName:@"Ride Sharing Co."];
[GMSNavigationServices
showTermsAndConditionsDialogIfNeededWithOptions:termsAndConditionsOptions
callback:^(BOOL termsAccepted) {
if (termsAccepted) {
// Enable navigation if the user accepts the terms.
_mapView.navigationEnabled = YES;
_mapView.settings.compassButton = YES;
// Request authorization to use the current device location.
[_locationManager requestAlwaysAuthorization];
// Request authorization for alert notifications which deliver guidance instructions
// in the background.
UNUserNotificationCenter *center = [UNUserNotificationCenter currentNotificationCenter];
UNAuthorizationOptions options = UNAuthorizationOptionAlert;
[center requestAuthorizationWithOptions:options
completionHandler:
^(
BOOL granted,
NSError *_Nullable error) {
if (!error && granted) {
NSLog(@"iOS Notification Permission: newly Granted");
} else {
NSLog(@"iOS Notification Permission: Failed or Denied");
}
}];
} else {
// Handle rejection of the terms and conditions.
}
}];
रास्ता बनाना और रास्ते की जानकारी देना शुरू करना
रास्ता दिखाने के लिए, Navigator के setDestinations() तरीके को कॉल करें. इसके लिए, एक या उससे ज़्यादा जगहों
(GMSNavigationWaypoint)
वाला कलेक्शन इस्तेमाल करें. अगर रास्ता सही तरीके से तय हो जाता है, तो वह मैप पर दिखता है. रास्ते की जानकारी देना शुरू करने के लिए, कॉलबैक में isGuidanceActive को true पर सेट करें.
यहां दिए गए उदाहरण में यह दिखाया गया है:
- एक जगह के लिए नया रास्ता बनाना.
- रास्ते की जानकारी देना शुरू करना.
- बैकग्राउंड में रास्ते की जानकारी देने वाली चेतावनियों की सूचनाएं चालू करना.
- रास्ते पर यात्रा को सिम्युलेट करना (ज़रूरी नहीं).
- कैमरा मोड को "फ़ॉलो करें" पर सेट करना (ज़रूरी नहीं).
Swift
func startNav() {
var destinations = [GMSNavigationWaypoint]()
destinations.append(GMSNavigationWaypoint.init(placeID: "ChIJnUYTpNASkFQR_gSty5kyoUk",
title: "PCC Natural Market")!)
mapView.navigator?.setDestinations(destinations) { routeStatus in
self.mapView.navigator?.isGuidanceActive = true
self.mapView.locationSimulator?.simulateLocationsAlongExistingRoute()
self.mapView.cameraMode = .following
}
}
Objective-C
- (void)startNav {
NSArray<GMSNavigationWaypoint *> *destinations =
@[[[GMSNavigationWaypoint alloc] initWithPlaceID:@"ChIJnUYTpNASkFQR_gSty5kyoUk"
title:@"PCC Natural Market"],
[_mapView.navigator setDestinations:destinations
callback:^(GMSRouteStatus routeStatus){
[_mapView.locationSimulator simulateLocationsAlongExistingRoute];
_mapView.navigator.guidanceActive = YES;
_mapView.cameraMode = GMSNavigationCameraModeFollowing;
}];
}
प्लेस आईडी के बारे में जानने के लिए, कृपया प्लेस आईडी लेख पढ़ें.
एक से ज़्यादा जगहों के लिए रास्ता तय करना
ज़्यादा से ज़्यादा 25 वेपॉइंट कॉन्फ़िगर किए जा सकते हैं.
setDestinations तरीका, एक से ज़्यादा जगहों के लिए रास्ता तय करने की सुविधा के साथ काम नहीं करता. वेपॉइंट को यात्रा के अगले चरण पर ले जाने के लिए,
continueToNextDestinationWithCompletion()
का इस्तेमाल करें.
यात्रा मोड सेट करना
यात्रा मोड से तय होता है कि किस तरह का रास्ता फ़ेच किया जाएगा. साथ ही, यह भी तय होता है कि उपयोगकर्ता का कोर्स कैसे तय किया जाएगा. किसी रास्ते के लिए, यात्रा के चार मोड में से कोई एक सेट किया जा सकता है: ड्राइविंग, साइकल चलाना, पैदल चलना, और टैक्सी. ड्राइविंग और टैक्सी मोड में, उपयोगकर्ता का कोर्स यात्रा की दिशा पर आधारित होता है. वहीं, साइकल चलाने और पैदल चलने के मोड में, कोर्स को उस दिशा से दिखाया जाता है जिस तरफ़ डिवाइस का मुंह होता है. लैंडस्केप मोड में, डिवाइस के ऊपरी हिस्से की ओर.
मैप व्यू की travelMode
प्रॉपर्टी सेट करें. जैसा कि यहां दिए गए उदाहरण में दिखाया गया है:
Swift
self.mapView.travelMode = .cycling
Objective-C
_mapView.travelMode = GMSNavigationTravelModeCycling;
वे सड़कें सेट करना जिनसे बचना है
किसी रास्ते पर हाइवे और/या टोल रोड से बचने के लिए, avoidsHighways और avoidsTolls BOOL प्रॉपर्टी का इस्तेमाल करें.
Swift
self.mapView.navigator?.avoidsTolls = true
Objective-C
_mapView.navigator.avoidsTolls = YES;
PlaceID फ़ाइंडर
रास्ते की जगहों के लिए प्लेस आईडी ढूंढने के लिए, PlaceID फ़ाइंडर
का इस्तेमाल किया जा सकता है. GMSNavigationWaypoint की मदद से, placeID से कोई जगह जोड़ें.
फ़्लोटिंग टेक्स्ट
अपने ऐप्लिकेशन में कहीं भी फ़्लोटिंग टेक्स्ट जोड़ा जा सकता है. हालांकि, यह ज़रूरी है कि Google के एट्रिब्यूशन पर यह टेक्स्ट न दिखे. Navigation SDK, मैप पर अक्षांश/देशांतर या किसी लेबल पर टेक्स्ट को ऐंकर करने की सुविधा नहीं देता. ज़्यादा जानकारी के लिए, जानकारी वाले विंडो लेख पढ़ें.