Rotayı izleme

iOS için Navigation SDK'yı kullanarak uygulamanızda tek bir hedefe giden rota çizmek için bu kılavuzu izleyin.

Genel Bakış

  1. Projenizi ayarlama bölümünde açıklandığı gibi Navigation SDK'yı uygulamanıza entegre edin.
  2. GMSMapView yapılandırın.
  3. Kullanıcıdan hüküm ve koşulları kabul etmesini ve konum hizmetleri ile arka plan bildirimlerine izin vermesini isteyin.
  4. Bir veya daha fazla hedef içeren bir dizi oluşturun.
  5. Adım adım navigasyonu kontrol etmek için GMSNavigator tanımlayın.

Kodu görüntüleme

Kullanıcıdan gerekli yetkilendirmeleri yapmasını isteyin.

Kullanıcı, Navigation SDK'yı kullanmadan önce şartları ve koşulları kabul etmeli ve konum hizmetlerinin kullanımını yetkilendirmelidir. Bu, navigasyon için gereklidir. Uygulamanız arka planda çalışacaksa kullanıcıdan rehberlik uyarısı bildirimlerini yetkilendirmesini de istemelidir. Bu bölümde, gerekli yetkilendirme istemlerinin nasıl gösterileceği açıklanmaktadır.

Konum hizmetlerini yetkilendirme

Navigation SDK, konum hizmetlerini kullanır. Bu hizmetler için kullanıcı yetkilendirmesi gerekir. Konum hizmetlerini etkinleştirmek ve yetkilendirme iletişim kutusunu göstermek için şu adımları uygulayın:

  1. NSLocationAlwaysUsageDescription anahtarını Info.plist'e ekleyin.
  2. Değer için uygulamanızın neden konum hizmetlerine ihtiyaç duyduğuna dair kısa bir açıklama ekleyin. Örneğin: "Bu uygulamanın adım adım navigasyon için konum hizmetlerini kullanma izni gerekiyor."

  3. Yetkilendirme iletişim kutusunu göstermek için konum yöneticisi örneğinin requestAlwaysAuthorization() işlevini çağırın.

Swift

self.locationManager.requestAlwaysAuthorization()

Objective-C

[_locationManager requestAlwaysAuthorization];

Arka plan rehberliği için uyarı bildirimlerine izin verme

Navigation SDK'nın, uygulama arka planda çalışırken uyarı bildirimleri gönderebilmesi için kullanıcı izni gerekir. Kullanıcıdan bu bildirimleri gösterme izni istemek için aşağıdaki kodu ekleyin:

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");
     }
   }];

Hükümler ve koşulları kabul etme

Şartlar ve koşullar iletişim kutusunu göstermek ve kullanıcı şartları kabul ettiğinde gezinmeyi etkinleştirmek için aşağıdaki kodu kullanın. Bu örnekte, konum hizmetleri ve rehberlik uyarısı bildirimleriyle ilgili kodun (daha önce gösterilmişti) yer aldığını unutmayın.

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.
   }
 }];

Rota oluşturma ve rehberliği başlatma

Rota çizmek için Navigator'ın setDestinations() yöntemini, ziyaret edilecek bir veya daha fazla hedef (GMSNavigationWaypoint) içeren bir diziyle çağırın. Başarıyla hesaplanan rota haritada gösterilir. Rotada, ilk hedeften başlayarak rehberliği başlatmak için geri aramada isGuidanceActive değerini true olarak ayarlayın.

Aşağıdaki örnekte şunlar gösterilmektedir:

  • İki hedefli yeni bir rota oluşturma
  • Rehberlik başlatılıyor.
  • Arka plan rehberliği bildirimlerini etkinleştirme
  • Rota boyunca seyahati simüle etme (isteğe bağlı)
  • Kamera modunu "takip et" olarak ayarlama (isteğe bağlı).

Swift

func startNav() {
  var destinations = [GMSNavigationWaypoint]()
  destinations.append(GMSNavigationWaypoint.init(placeID: "ChIJnUYTpNASkFQR_gSty5kyoUk",
                                                 title: "PCC Natural Market")!)
  destinations.append(GMSNavigationWaypoint.init(placeID:"ChIJJ326ROcSkFQRBfUzOL2DSbo",
                                                 title:"Marina Park")!)

  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"],
    [[GMSNavigationWaypoint alloc] initWithPlaceID:@"ChIJJ326ROcSkFQRBfUzOL2DSbo"
                                             title:@"Marina Park"]];

  [_mapView.navigator setDestinations:destinations
                             callback:^(GMSRouteStatus routeStatus){
                               [_mapView.locationSimulator simulateLocationsAlongExistingRoute];
                               _mapView.navigator.guidanceActive = YES;
                               _mapView.cameraMode = GMSNavigationCameraModeFollowing;
                             }];
}

Yer kimlikleri hakkında bilgi edinmek için lütfen Yer kimlikleri başlıklı makaleyi inceleyin.

Ulaşım şeklini ayarla

Seyahat modu, hangi rota türünün getirileceğini ve kullanıcının rotasının nasıl belirleneceğini belirler. Bir rota için dört ulaşım şeklinden birini ayarlayabilirsiniz: araba, bisiklet, yürüyüş ve taksi. Sürüş ve taksi modunda kullanıcının rotası, seyahat yönüne göre belirlenir. Bisiklet ve yürüyüş modunda ise rota, cihazın baktığı yöne göre (yatay modda cihazın üst kısmına doğru) gösterilir.

Harita görünümünün travelMode özelliğini aşağıdaki örnekte gösterildiği gibi ayarlayın:

Swift

self.mapView.travelMode = .cycling

Objective-C

_mapView.travelMode = GMSNavigationTravelModeCycling;

Kaçınılacak yolları ayarlama

Bir rota üzerindeki otoyolları ve/veya ücretli yolları kullanmamak için avoidsHighways ve avoidsTolls BOOL özelliklerini kullanın.

Swift

self.mapView.navigator?.avoidsTolls = true

Objective-C

_mapView.navigator.avoidsTolls = YES;

Yer kimliği bulma aracı

Rota hedefleri için kullanılacak yer kimliklerini bulmak üzere PlaceID Finder'ı kullanabilirsiniz. GMSNavigationWaypoint ile placeID konumundan hedef ekleyin.

Kaydırma metni

Google ilişkilendirmesi kapatılmadığı sürece, uygulamanızın herhangi bir yerine kayan metin ekleyebilirsiniz. Navigation SDK, metnin haritadaki bir enlem/boylama veya bir etikete sabitlenmesini desteklemez. Daha fazla bilgi için Bilgi pencereleri başlıklı makaleyi inceleyin.