Android'de bir geziyi takip etme

Platform seçin: Android iOS JavaScript

Bir geziyi takip ettiğinizde, tüketici uygulamanız seyahatin konumunu yardımcı olacak bir araçtır. Bunun için uygulamanızın başlatılması gerekiyor geziyi takip etme, gezi seyrini güncelleme ve gezi sırasında takip etmeyi bırakma gerekir.

Bu dokümanda, bu sürecin nasıl işlediği açıklanmaktadır.

Başlamadan önce

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

  • Tüketici uygulamanız için arka uç hizmetleri hazır ve hizmetleriniz hazır buluşturmaya başlandı.

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

Bir geziyi takip etmeye başlayın

Arka uç sunucunuz bir tüketiciyle araçla eşleştiğinde Yolculuk paylaşımını kullanarak seyahati takip etmeye başlamak için JourneySharingSession.

Aşağıdaki örnek kod, görünüm yüklemeleri.

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 seyrini güncelle

Yolculuk ilerlemesi ayrıntılarını (ör. aracın geçmesi gereken mesafe) güncellemek için ve tahmini varış saatini öğrenmek isterseniz uygulamanız 24 saat boyunca aşağıdaki örneklerde gösterildiği gibi bir işleyiciyi kaydedin ve yapılandırın.

  1. Bir TripModel nesnesine işleyici 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 geziniz için işleyiciyi 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 ihtiyaç duyulmayan bir geziyi takip etmeyi bıraktığından emin olun, örneğin Bu durum, sürücü tarafından arka uçta TAMAMLANDI olarak işaretlenmesine neden olur. Yolculuk durduruluyor paylaşım, Fleet Engine'e yapılan gereksiz ağ isteklerini önler ve belleği önler sızdır.

Gezintiyi şurada gösterildiği gibi takip etmeyi bırakmak için JourneySharingSession öğesini kullanın: aşağıdaki örnek kodu kullanabilirsiniz.

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, gezi sırasında oluşan hataları gösterir takip eder. Hata mesajları Google Cloud Hata Standardı'nı uygular. Ayrıntılı hata mesajı tanımları ve tüm hata kodları için Google Cloud Hataları dokümanlarına göz atın.

Gezi izleme sırasında sık karşılaşılan bazı hatalar aşağıda verilmiştir:

HTTP TBG Açıklama
400 GEÇERSİZ_BAĞ_DEĞİŞKEN Müşteri, geçersiz bir gezi adı belirtti. Gezi adı providers/{provider_id}/trips/{trip_id} biçimindedir. İlgili içeriği oluşturmak için kullanılan provider_id, şuna ait Cloud projesinin kimliği olmalıdır: servis sağlayıcıyı da etkiler.
401 KİMLİK DOĞRULAMADI Geçerli bir kimlik doğrulama kimlik bilgisi yoksa bu hatayı alırsınız. Örneğin, JWT jetonu gezi kimliği veya JWT jetonu olmadan imzalanmışsa süresi doldu.
403 PERMISSION_DENIED İstemcinin yeterli izni yoksa bu hatayı alırsınız. (örneğin, tüketici rolüne sahip bir kullanıcı, güncellemeyi çağırmaya çalışırsa) JWT jetonu geçersiz veya istemci projesi için API etkin değil. JWT jetonu eksik olabilir veya jeton şu durumdaki bir gezi kimliğiyle imzalanmış olabilir: istenen gezi kimliğiyle eşleşmiyor.
429 RESOURCE_EXHAUSTED Kaynak kotası sıfırdı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 son tarihi aşıldı. Bu hata yalnızca çağrıda bulunan bir yöntemin varsayılan teslim tarihinden (yani istenen son tarihin sunucunun isteği işlemesi için yeterli olmaması) ve Talep, verilen süre zarfında tamamlanmamıştır.

Tüketici SDK'sı Hatalarını Ele Alma

Tüketici SDK'sı, gezi güncelleme hatalarını bir geri çağırma aracılığıyla tüketici uygulamasına gönderir. mekanizmasıdır. Geri çağırma parametresi platforma özgü bir dönüş türüdür ( TripUpdateError ve Android'de NSError .

Durum kodlarını çıkart

Geri çağırmaya iletilen hatalar genellikle gRPC hatalarıdır ve ek bilgileri durum kodu biçiminde ayıklamak için kullanılır. tam listesini görmek için Durum kodları ve gRPC'de kullanılmaları.

Java

Hatayla ilgili ayrıntılı bilgi sağlayan bir gRPC durum kodunu ayıklayabilir onTripUpdateError() tarafından döndürülen TripUpdateError.

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

Kotlin

Hatayla ilgili ayrıntılı bilgi sağlayan bir gRPC durum kodunu ayıklayabilir onTripUpdateError() tarafından döndürülen TripUpdateError.

// 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ğ ile ilgili hatalar ve hata düzeltmesi.

Sunucu ve ağ hataları

Aşağıdaki durum kodları ağ veya sunucu hataları içindir ve çözmek için bir işlem yapması gerekmez. Tüketici SDK'sı otomatik olarak bu değişimlerden kurtulursunuz.

Durum KoduAçıklama
İPTAL EDİLDİ Sunucu, yanıt göndermeyi durdurdu. Bu durum, normalde sunucu sorunu.
İPTAL EDİLDİ Sunucu giden yanıtı sonlandırdı. Bu, normalde şu durumda olur:
arka plana gönderildiğinde veya arka planda bir değişiklik olduğunda
Tüketici uygulaması.
INTERRUPTED
DEADLINE_EXCEEDED Sunucunun yanıt vermesi çok uzun sürdü.
UNAVAILABLE Sunucu kullanılamıyor. Bu durum genellikle ağdan kaynaklanır sorun.

İstemci hataları

Aşağıdaki durum kodları istemci hataları içindir ve aşağıdaki durumlarla ilgili olarak işlem yapmanız gerekir: çözer. Tüketici SDK'sı siz geçiş yapana kadar geziyi yenilemeyi yeniden denemeye devam eder yolculuk paylaşımı da iptal edilir. Bununla birlikte, siz işlem yapana kadar geri dönüş işlemi gerçekleşmez.

Durum KoduAçıklama
GEÇERSİZ_BAĞ_DEĞİŞKEN Tüketici uygulaması geçersiz bir gezi adı belirtti; Gezi adı providers/{provider_id}/trips/{trip_id} biçimine uyar.
NOT_FOUND Gezi hiç oluşturulmadı.
PERMISSION_DENIED Tüketici uygulamasının izinleri yeterli değil. Bu hata aşağıdaki durumlarda oluşur:
  • Tüketici uygulamasının izinleri yok
  • Google Cloud'daki proje için Tüketici SDK'sı etkinleştirilmemiş Konsol.
  • JWT jetonu yok veya geçersiz.
  • JWT jetonu, seyahat isteği.
RESOURCE_EXHAUSTED Kaynak kotası sıfırdır veya trafik akışı hızı hız sınırlaması var.
KİMLİK DOĞRULAMADI Geçersiz bir JWT jetonu nedeniyle isteğin kimlik doğrulaması başarısız oldu. Bu hatası, JWT jetonu bir seyahat kimliği olmadan imzalandığında veya JWT jetonunun süresi dolduğunda.