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 ilerleme durumunu güncelleme
Yolculuk ilerlemesi ayrıntılarını (ör. aracın geçmesi gereken mesafe) güncellemek için ve tahmini varış zamanını öğrendiğiniz için, uygulamanızın aşağıdaki örneklerde gösterildiği gibi bir işleyiciyi kaydedin ve yapılandırın.
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?, ) { // ... } // ... })
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)
Gezi takibini durdurma
Uygulamanızın artık ihtiyaç duyulmayan bir geziyi takip etmeyi bıraktığından emin olun, örneğin Örneğin, seyahat sürücü tarafından arka uçta TAMAMLANDI olarak işaretlenir. 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ı izler. 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 | INVALID_ARGUMENT | Müşteri, geçersiz bir gezi adı belirtti. Gezi adı
providers/{provider_id}/trips/{trip_id} biçimindedir. provider_id, hizmet sağlayıcının sahip olduğu Cloud projesinin kimliği olmalıdır. |
401 | KİMLİK DOĞRULAMADI | Geçerli kimlik doğrulama kimlik bilgileri 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 (ö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 ş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şıyordur. |
503 | UNAVAILABLE | Hizmet kullanılamıyor. Genellikle sunucu kapalıdır. |
504 | DEADLINE_EXCEEDED | İstek bitiş 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ı, 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 (
TripUpdateError
ve Android'de
NSError
.
Durum kodlarını çıkart
Geri çağırma işlevine iletilen hatalar genellikle gRPC hatalarıdır ve bu hatalardan durum kodu biçiminde ek bilgiler de alabilirsiniz. tam listesini görmek için Durum kodları ve gRPC'de kullanılmaları.
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
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ğla ilgili hatalar ve istemci tarafı hatalar.
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 Kodu | Açı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ı, yolculuk paylaşımını sonlandırana kadar geziyi yenilemeyi denemeye devam eder ancak siz bir işlem yapana kadar kurtarılamaz.
Durum Kodu | Açıklama |
---|---|
INVALID_ARGUMENT | 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:
|
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. |