Android में यात्रा को फ़ॉलो करें

प्लैटफ़ॉर्म चुनें: Android iOS JavaScript

किसी यात्रा को फ़ॉलो करने पर, आपका उपभोक्ता ऐप्लिकेशन उपभोक्ता को सही वाहन की जगह दिखाता है. ऐसा करने के लिए, आपके ऐप्लिकेशन को किसी यात्रा को ट्रैक करना शुरू करना होगा, यात्रा की प्रोग्रेस अपडेट करनी होगी, और यात्रा पूरी होने पर उसे ट्रैक करना बंद करना होगा.

इस दस्तावेज़ में बताया गया है कि यह प्रोसेस कैसे काम करती है.

शुरू करने से पहले

पक्का करें कि आपने ये चीज़ें सेट अप कर ली हों:

  • आपके उपभोक्ता ऐप्लिकेशन के लिए बैकएंड सेवाएं चालू हों और उपभोक्ताओं को वाहनों से मैच करने वाली आपकी सेवाएं काम करती हों.

  • आपने अपने ऐप्लिकेशन के लिए मैप सेट अप किया हो.

किसी यात्रा को फ़ॉलो करना

जब आपका बैकएंड सर्वर, किसी उपभोक्ता को वाहन से मैच करता है, तो यात्रा को ट्रैक करने के लिए JourneySharingSession का इस्तेमाल करें.

यहां दिए गए सैंपल कोड में, व्यू लोड होने के बाद किसी ट्रिप को फ़ॉलो करने का तरीका बताया गया है.

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()
  }
}

यात्रा की प्रोग्रेस अपडेट करना

यात्रा की प्रोग्रेस की जानकारी अपडेट करने के लिए, आपके ऐप्लिकेशन को एक लिसनर को रजिस्टर और कॉन्फ़िगर करना होगा. जैसे, वाहन को पहुंचने से पहले कितनी दूरी तय करनी है और पहुंचने का अनुमानित समय. यहां दिए गए उदाहरणों में यह तरीका बताया गया है.

  1. TripModel ऑब्जेक्ट पर लिसनर रजिस्टर करें.

    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 का इस्तेमाल करके, अपनी यात्रा के लिए लिसनर को कॉन्फ़िगर करें.

    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)
    

किसी यात्रा को फ़ॉलो करना बंद करना

पक्का करें कि आपका ऐप्लिकेशन, किसी यात्रा को ट्रैक करना तब बंद कर दे, जब इसकी ज़रूरत न हो. जैसे, जब ड्राइवर ने बैकएंड पर यात्रा को 'पूरा हो गया' के तौर पर मार्क कर दिया हो. प्रोसेस के दौरान हुई गतिविधियों को शेयर करने की सुविधा बंद करने से, Fleet Engine को नेटवर्क के ग़ैर-ज़रूरी अनुरोधों से बचा जा सकता है. साथ ही, इससे मेमोरी लीक होने से भी बचा जा सकता है.

नीचे दिए गए सैंपल कोड में दिखाए गए तरीके के मुताबिक, JourneySharingSession का इस्तेमाल करके यात्रा को फ़ॉलो करना बंद करें.

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()
  }
}

यात्रा से जुड़ी गड़बड़ियां ठीक करना

onTripRefreshError तरीका, यात्रा की निगरानी के दौरान होने वाली गड़बड़ियों को दिखाता है. गड़बड़ी के मैसेज, Google Cloud के गड़बड़ी के मानक के मुताबिक होते हैं. गड़बड़ी के मैसेज की परिभाषाओं और गड़बड़ी के सभी कोड के बारे में ज़्यादा जानने के लिए, Google Cloud की गड़बड़ियों से जुड़ा दस्तावेज़ देखें.

यहां कुछ सामान्य गड़बड़ियां बताई गई हैं, जो यात्रा की निगरानी के दौरान हो सकती हैं:

HTTP RPC ब्यौरा
400 INVALID_ARGUMENT क्लाइंट ने ट्रिप का अमान्य नाम दिया है. ट्रिप का नाम, providers/{provider_id}/trips/{trip_id} फ़ॉर्मैट में होना चाहिए. provider_id, सेवा देने वाली कंपनी के मालिकाना हक वाले Cloud प्रोजेक्ट का आईडी होना चाहिए.
401 UNAUTHENTICATED अगर पुष्टि करने के लिए मान्य क्रेडेंशियल नहीं हैं, तो आपको यह गड़बड़ी दिखेगी. उदाहरण के लिए, अगर JWT टोकन पर ट्रिप आईडी के बिना हस्ताक्षर किया गया है या JWT टोकन की समयसीमा खत्म हो गई है.
403 PERMISSION_DENIED आपको यह गड़बड़ी तब दिखती है, जब क्लाइंट के पास ज़रूरी अनुमति न हो (उदाहरण के लिए, जब उपभोक्ता की भूमिका वाला कोई उपयोगकर्ता, updateTrip को कॉल करने की कोशिश करता है), जब JWT टोकन अमान्य हो या क्लाइंट प्रोजेक्ट के लिए एपीआई चालू न हो. हो सकता है कि JWT टोकन मौजूद न हो या टोकन पर उस ट्रिप आईडी के साथ हस्ताक्षर किया गया हो जो अनुरोध किए गए ट्रिप आईडी से मेल नहीं खाता.
429 RESOURCE_EXHAUSTED संसाधन कोटा शून्य है या ट्रैफ़िक की दर तय सीमा से ज़्यादा है.
503 हवा की क्वालिटी की जानकारी उपलब्ध नहीं है सेवा उपलब्ध नहीं है. आम तौर पर, ऐसा तब होता है, जब सर्वर काम नहीं कर रहा हो.
504 DEADLINE_EXCEEDED अनुरोध की समयसीमा खत्म हो गई. यह गड़बड़ी सिर्फ़ तब होती है, जब कॉल करने वाला व्यक्ति, समयसीमा को मेथड की डिफ़ॉल्ट समयसीमा से कम सेट करता है. इसका मतलब है कि अनुरोध की गई समयसीमा, सर्वर के लिए अनुरोध को प्रोसेस करने के लिए ज़रूरत के मुताबिक नहीं है और अनुरोध समयसीमा के अंदर पूरा नहीं हुआ.

Consumer SDK टूल से जुड़ी गड़बड़ियां ठीक करना

Consumer SDK टूल, कॉलबैक मैकेनिज्म का इस्तेमाल करके, ट्रिप अपडेट से जुड़ी गड़बड़ियों की जानकारी, Consumer ऐप्लिकेशन को भेजता है. कॉलबैक पैरामीटर, प्लैटफ़ॉर्म के हिसाब से रिटर्न टाइप होता है. जैसे, Android पर TripUpdateError और iOS पर NSError.

स्टेटस कोड निकालना

आम तौर पर, कॉलबैक में भेजी गई गड़बड़ियां gRPC गड़बड़ियां होती हैं. साथ ही, इनसे स्टेटस कोड के तौर पर ज़्यादा जानकारी भी निकाली जा सकती है. स्टेटस कोड की पूरी सूची के लिए, स्टेटस कोड और gRPC में उनका इस्तेमाल देखें.

Java

onTripUpdateError() से मिले TripUpdateError से, गड़बड़ी के बारे में जानकारी देने वाला gRPC स्टेटस कोड निकाला जा सकता है.

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

Kotlin

onTripUpdateError() से मिले TripUpdateError से, गड़बड़ी के बारे में जानकारी देने वाला gRPC स्टेटस कोड निकाला जा सकता है.

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

स्टेटस कोड समझना

स्टेटस कोड में दो तरह की गड़बड़ियां शामिल होती हैं: सर्वर और नेटवर्क से जुड़ी गड़बड़ियां और क्लाइंट-साइड गड़बड़ियां.

सर्वर और नेटवर्क से जुड़ी गड़बड़ियां

यहां दिए गए स्टेटस कोड, नेटवर्क या सर्वर से जुड़ी गड़बड़ियों के लिए हैं. इन्हें ठीक करने के लिए, आपको कोई कार्रवाई करने की ज़रूरत नहीं है. Consumer SDK टूल, इन गड़बड़ियों से अपने-आप ठीक हो जाता है.

स्थिति कोडब्यौरा
ABORTED सर्वर ने जवाब भेजना बंद कर दिया. आम तौर पर, ऐसा सर्वर की समस्या की वजह से होता है.
रद्द कर दी गई सर्वर ने आउटगोइंग रिस्पॉन्स को बंद कर दिया. आम तौर पर, ऐसा तब होता है, जब ऐप्लिकेशन को बैकग्राउंड में भेजा जाता है या
consumer ऐप्लिकेशन की स्थिति में बदलाव होता है.
INTERRUPTED
DEADLINE_EXCEEDED सर्वर को जवाब देने में बहुत ज़्यादा समय लगा.
हवा की क्वालिटी की जानकारी उपलब्ध नहीं है सर्वर उपलब्ध नहीं था. आम तौर पर, ऐसा नेटवर्क की समस्या की वजह से होता है.

क्लाइंट से जुड़ी गड़बड़ियां

यहां दिए गए स्टेटस कोड, क्लाइंट से जुड़ी गड़बड़ियों के लिए हैं. इन्हें ठीक करने के लिए, आपको कार्रवाई करनी होगी. जब तक यात्रा की जानकारी शेयर करने की सुविधा बंद नहीं की जाती, तब तक Consumer SDK टूल, यात्रा की जानकारी को रीफ़्रेश करने की कोशिश करता रहता है. हालांकि, जब तक आप कोई कार्रवाई नहीं करते, तब तक यह सुविधा वापस नहीं आएगी.

स्थिति कोडब्यौरा
INVALID_ARGUMENT उपभोक्ता ऐप्लिकेशन ने यात्रा का अमान्य नाम दिया है. यात्रा का नाम, providers/{provider_id}/trips/{trip_id} फ़ॉर्मैट में होना चाहिए.
NOT_FOUND यात्रा कभी बनी ही नहीं.
PERMISSION_DENIED Consumer ऐप्लिकेशन के पास ज़रूरी अनुमतियां नहीं हैं. यह गड़बड़ी तब होती है, जब:
  • उपभोक्ता ऐप्लिकेशन के पास अनुमतियां नहीं हैं
  • Google Cloud Console में, प्रोजेक्ट के लिए Consumer SDK टूल चालू नहीं है.
  • JWT टोकन मौजूद नहीं है या अमान्य है.
  • JWT टोकन पर ऐसे ट्रिप आईडी से हस्ताक्षर किया गया है जो अनुरोध किए गए ट्रिप से मेल नहीं खाता.
RESOURCE_EXHAUSTED संसाधन कोटा शून्य है या ट्रैफ़िक फ़्लो की दर, स्पीड की सीमा से ज़्यादा है.
UNAUTHENTICATED अमान्य JWT टोकन की वजह से, अनुरोध की पुष्टि नहीं हो सकी. यह गड़बड़ी तब होती है, जब JWT टोकन पर ट्रिप आईडी के बिना हस्ताक्षर किया जाता है या JWT टोकन की समयसीमा खत्म हो जाती है.