Android'de bir geziyi takip etme

Platform seçin: Android iOS JavaScript

Bir seyahati takip ettiğinizde tüketici uygulaması, uygun aracın konumunu tüketiciye gösterir. Bunun için uygulamanızın bir yolculuğu takip etmeye başlaması, yolculuğun ilerleme durumunu güncellemesi ve yolculuk tamamlandığında takip etmeyi durdurması gerekir.

Bu belgede bu sürecin işleyiş şekli açıklanmaktadır.

Başlamadan önce

Aşağıdakileri ayarladığınızdan emin olun:

  • Tüketici uygulamanız için arka uç hizmetleri kullanıma hazır ve tüketicileri araçlarla eşleştirmeye yönelik hizmetleriniz çalışır durumda olmalıdır.

  • Uygulamanız için harita oluşturdunuz.

Bir geziyi takip etmeye başlama

Arka uç sunucunuz bir tüketiciyi bir araçla eşleştirdiğinde, geziyi takip etmeye başlamak için JourneySharingSession simgesini kullanın.

Aşağıdaki örnek kod, görüntü yüklendikten sonra bir geziyi nasıl takip etmeye başlayacağınızı gösterir.

Java

public class MainActivity extends AppCompatActivity
    implements ConsumerViewModel.JourneySharingListener  {

  // Class implementation

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    // Create a TripModel instance to listen for updates to the trip specified by this trip name.
    String tripName = ...;
    TripModelManager tripModelManager = consumerApi.getTripModelManager();
    TripModel tripModel = tripModelManager.getTripModel(tripName);

    // Create a JourneySharingSession instance based on the TripModel.
    JourneySharingSession session = JourneySharingSession.createInstance(tripModel);

    // Add the JourneySharingSession instance on the map for updating the UI.
    consumerController.showSession(session);

    // Register for trip update events.
    tripModel.registerTripCallback(new TripModelCallback() {
      @Override
      public void onTripETAToNextWaypointUpdated(
          TripInfo tripInfo, @Nullable Long timestampMillis) {
        // ...
      }

      @Override
      public void onTripActiveRouteRemainingDistanceUpdated(
          TripInfo tripInfo, @Nullable Integer distanceMeters) {
        // ...
      }

      // ...
    });
  }

  @Override
  protected void onDestroy() {
    super.onDestroy();

    if (journeySharingSession != null) {
      journeySharingSession.stop();
    }
  }
}

Kotlin

class SampleAppActivity : AppCompatActivity(), ConsumerViewModel.JourneySharingListener {

  // Class implementation

  override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)

    // Create a TripModel instance to listen for updates to the trip specified by this trip name.
    val tripName = "tripName"
    val tripModelManager = consumerApi.getTripModelManager()
    val tripModel = tripModelManager.getTripModel(tripName)

    // Create a JourneySharingSession instance based on the TripModel.
    val session = JourneySharingSession.createInstance(tripModel)

    // Add the JourneySharingSession instance on the map for updating the UI.
    consumerController.showSession(session)

    // Register for trip update events.
    tripModel.registerTripCallback(
      object : TripModelCallback() {
        override fun onTripETAToNextWaypointUpdated(
          tripInfo: TripInfo,
          timestampMillis: Long?,
        ) {
          // ...
        }

        override fun onTripActiveRouteRemainingDistanceUpdated(
          tripInfo: TripInfo,
          distanceMeters: Int?,
        ) {
          // ...
        }

      // ...
    })
  }

  override fun onDestroy() {
    super.onDestroy()

    journeySharingSession?.stop()
  }
}

Gezi ilerleme durumunu güncelleme

Araçla varış noktasına kadar katılması gereken mesafe ve tahmini varış zamanı gibi seyahat ilerleme ayrıntılarını güncellemek için uygulamanızın aşağıdaki örneklerde gösterildiği gibi bir dinleyiciyi kaydettirip yapılandırması gerekir.

  1. TripModel nesnesine bir dinleyici kaydedin.

    Java

    // Create a TripModel instance for listening to updates to the trip specified by this trip name.
    String tripName = ...;
    TripModelManager tripModelManager = consumerApi.getTripModelManager();
    TripModel tripModel = tripModelManager.getTripModel(tripName);
    
    // Create a JourneySharingSession instance based on the TripModel.
    JourneySharingSession session = JourneySharingSession.createInstance(tripModel);
    
    // Add the JourneySharingSession instance on the map for updating the UI.
    consumerController.showSession(session);
    
    // Register for trip update events.
    tripModel.registerTripCallback(new TripModelCallback() {
    @Override
    public void onTripETAToNextWaypointUpdated(
            TripInfo tripInfo, @Nullable Long timestampMillis) {
          // ...
    }
    
    @Override
    public void onTripActiveRouteRemainingDistanceUpdated(
            TripInfo tripInfo, @Nullable Integer distanceMeters) {
          // ...
    }
    
    // ...
    });
    

    Kotlin

    // Create a TripModel instance for listening to updates to the trip specified by this trip name.
    val tripName = "tripName"
    val tripModelManager = consumerApi.getTripModelManager()
    val tripModel = tripModelManager.getTripModel(tripName)
    
    // Create a JourneySharingSession instance based on the TripModel.
    val session = JourneySharingSession.createInstance(tripModel)
    
    // Add the JourneySharingSession instance on the map for updating the UI.
    consumerController.showSession(session)
    
    // Register for trip update events.
    tripModel.registerTripCallback(
      object : TripModelCallback() {
        override fun onTripETAToNextWaypointUpdated(
          tripInfo: TripInfo,
          timestampMillis: Long?,
        ) {
          // ...
        }
    
        override fun onTripActiveRouteRemainingDistanceUpdated(
          tripInfo: TripInfo,
          distanceMeters: Int?,
        ) {
          // ...
        }
    
      // ...
    })
    
  2. TripModelOptions'ü kullanarak dinleyiciyi seyahatiniz için yapılandırın.

    Java

    // Set refresh interval to 2 seconds.
    TripModelOptions tripOptions =
          TripModelOptions.builder().setRefreshIntervalMillis(2000).build();
    tripModel.setTripModelOptions(tripOptions);
    

    Kotlin

    // Set refresh interval to 2 seconds.
    val tripOptions = TripModelOptions.builder().setRefreshIntervalMillis(2000).build()
    tripModel.setTripModelOptions(tripOptions)
    

Bir geziyi takip etmeyi bırakma

Uygulamanızın, artık gerekmediği durumlarda (ör. sürücü tarafından arka uçta gezi TAM olarak işaretlendiğinde) bir geziyi takip etmeyi durdurduğundan emin olun. Yolculuğu paylaşma özelliğini durdurmak, Fleet Engine'a gereksiz ağ istekleri göndermeyi ve bellek sızıntısını önler.

Aşağıdaki örnek kodda gösterildiği gibi, geziyi takip etmeyi durdurmak için JourneySharingSession simgesini kullanın.

Java

public class MainActivity extends AppCompatActivity
    implements ConsumerViewModel.JourneySharingListener  {

  // Class implementation

  @Override
  protected void onDestroy() {
    super.onDestroy();

    if (journeySharingSession != null) {
      journeySharingSession.stop();
    }
  }
}

Kotlin

class SampleAppActivity : AppCompatActivity(), ConsumerViewModel.JourneySharingListener {

  // Class implementation

  override fun onDestroy() {
    super.onDestroy()

    journeySharingSession?.stop()
  }
}

Gezi hatalarını işleme

onTripRefreshError yöntemi, yolculuk izleme sırasında oluşan hataları gösterir. Hata mesajları Google Cloud hata standardına uygundur. Hata mesajı tanımlarının ayrıntıları ve tüm hata kodları için Google Cloud Hataları belgelerine bakın.

Seyahat izleme sırasında ortaya çıkabilecek bazı yaygın hatalar aşağıda verilmiştir:

HTTP TBG Açıklama
400 INVALID_ARGUMENT İstemci, geçersiz bir gezi adı belirtti. Gezi adı providers/{provider_id}/trips/{trip_id} biçiminde olmalıdır. provider_id, hizmet sağlayıcının sahip olduğu Cloud projesinin kimliği olmalıdır.
401 UNAUTHENTICATED Geçerli kimlik doğrulama kimlik bilgileri yoksa bu hatayı alırsınız. Örneğin, JWT jetonu seyahat kimliği olmadan imzalanmışsa veya JWT jetonunun süresi dolmuşsa.
403 PERMISSION_DENIED İstemcinin yeterli izni yoksa (ör. tüketici rolüne sahip bir kullanıcı updateTrip'i çağırmaya çalışırsa), JWT jetonu geçersizse veya API, istemci projesi için etkinleştirilmemişse bu hatayı alırsınız. JWT jetonu eksik olabilir veya jeton, istenen seyahat kimliğiyle eşleşmeyen bir seyahat kimliğiyle imzalanmış olabilir.
429 RESOURCE_EXHAUSTED Kaynak kotası sıfır veya trafik hızı sınırı aşıyor.
503 UNAVAILABLE Hizmet kullanılamıyor. Genellikle sunucu kapalıdır.
504 DEADLINE_EXCEEDED İstek bitiş tarihi aşıldı. Bu hata yalnızca arayanın, yöntemin varsayılan son tarihinden daha kısa bir son tarih belirlemesi (yani istenen son tarih, sunucunun isteği işlemesi için yeterli olmaması) ve istek son tarih içinde tamamlanmamışsa ortaya çıkar.

Tüketici SDK Hatalarını Yönetme

Tüketici SDK'sı, geri çağırma mekanizması kullanarak tüketici uygulamasına seyahat güncelleme hatalarını gönderir. Geri çağırma parametresi, platforma özgü bir dönüş türüdür (Android'de TripUpdateError, iOS'te NSError).

Durum kodlarını ayıklama

Geri çağırma işlevine iletilen hatalar genellikle gRPC hatalarıdır ve bu hatalardan durum kodu biçiminde ek bilgiler de ayıklayabilirsiniz. Durum kodlarının tam listesi için Durum kodları ve gRPC'de kullanımları başlıklı makaleyi inceleyin.

Java

onTripUpdateError() tarafından döndürülen TripUpdateError öğesinden hatayla ilgili ayrıntılar sağlayan bir gRPC durum kodu ayıklayabilirsiniz.

// Called when there is a trip update error.
@Override
public void onTripUpdateError(TripInfo tripInfo, TripUpdateError error) {
  Status.Code code = error.getStatusCode();
}

Kotlin

onTripUpdateError() tarafından döndürülen TripUpdateError öğesinden hatayla ilgili ayrıntılar sağlayan bir gRPC durum kodu ayıklayabilirsiniz.

// Called when there is a trip update error.
override fun onTripUpdateError(tripInfo: TripInfo, error: TripUpdateError) {
  val code = error.getStatusCode()
}

Durum kodlarını yorumlama

Durum kodları iki tür hatayı kapsar: sunucu ve ağla ilgili hatalar ve istemci tarafı hatalar.

Sunucu ve ağ hataları

Aşağıdaki durum kodları ağ veya sunucu hatalarıyla ilgilidir ve bunları çözmek için herhangi bir işlem yapmanız gerekmez. Tüketici SDK'sı bu hatalardan otomatik olarak kurtarır.

Durum KoduAçıklama
İPTAL EDİLDİ Sunucu yanıt göndermeyi durdurdu. Bu durum genellikle bir sunucu sorunundan kaynaklanır.
İPTAL EDİLDİ Sunucu, giden yanıtı sonlandırdı. Bu durum genellikle uygulama arka plana gönderildiğinde veya tüketici uygulamasında durum değişikliği olduğunda meydana gelir.

KESİLDİ
DEADLINE_EXCEEDED Sunucunun yanıt vermesi çok uzun sürdü.
UNAVAILABLE Sunucu kullanılamıyordu. Bu durum genellikle ağ sorunundan kaynaklanır.

İstemci hataları

Aşağıdaki durum kodları istemci hatalarına yöneliktir ve bunları çözmek için işlem yapmanız gerekir. Tüketici SDK'sı, yolculuk paylaşımını sonlandırana kadar geziyi yenilemeyi denemeye devam eder ancak siz bir işlem yapmadığınız sürece kurtarmaz.

Durum KoduAçıklama
INVALID_ARGUMENT Tüketici uygulaması geçersiz bir gezi adı belirtti. Gezi adı providers/{provider_id}/trips/{trip_id} biçimine uymalıdır.
NOT_FOUND Gezi hiç oluşturulmadı.
PERMISSION_DENIED Tüketici uygulaması yeterli izinlere sahip değil. Bu hata aşağıdaki durumlarda ortaya çıkar:
  • Tüketici uygulamasının izinleri yok
  • Tüketici SDK'sı, Google Cloud Console'da proje için etkinleştirilmemiştir.
  • JWT jetonu eksik veya geçersiz.
  • JWT jetonu, istenen seyahatle eşleşmeyen bir seyahat kimliğiyle imzalandı.
RESOURCE_EXHAUSTED Kaynak kotası sıfırdır veya trafik akış hızı hız sınırını aşıyordur.
UNAUTHENTICATED Geçersiz JWT jetonu nedeniyle istek kimlik doğrulamasını geçemedi. Bu hata, JWT jetonu seyahat kimliği olmadan imzalandığında veya JWT jetonunun süresi dolduğunda ortaya çıkar.