जब आप किसी यात्रा को फ़ॉलो करते हैं, तो आपका उपभोक्ता ऐप्लिकेशन उसके लिए सही वाहन चुन सकते हैं. ऐसा करने के लिए, आपके ऐप्लिकेशन को किसी यात्रा को ट्रैक करना शुरू करना होगा, यात्रा की प्रोग्रेस अपडेट करनी होगी, और यात्रा पूरी होने पर उसे ट्रैक करना बंद करना होगा.
इस दस्तावेज़ में बताया गया है कि यह प्रोसेस कैसे काम करती है.
शुरू करने से पहले
पक्का करें कि आपने ये चीज़ें सेट अप कर ली हों:
आपके उपभोक्ता ऐप्लिकेशन के लिए बैकएंड सेवाएं उपलब्ध हैं. साथ ही, आपकी सेवाएं भी उपलब्ध हैं ग्राहकों के मेल खाने वाले ग्राहकों के लिए, हमारी सेवा का इस्तेमाल किया जा रहा है.
आपने अपने ऐप्लिकेशन के लिए मैप सेट अप किया हो.
किसी यात्रा को फ़ॉलो करना शुरू करें
जब आपका बैकएंड सर्वर, किसी उपभोक्ता को वाहन से मैच करता है, तो यात्रा को ट्रैक करने के लिए
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()
}
}
यात्रा की प्रोग्रेस अपडेट करें
यात्रा की जानकारी अपडेट करने के लिए, जैसे कि वाहन को कितनी दूरी की ज़रूरत है पहुंचने से पहले ही यात्रा कर सकते हैं और पहुंचने के अनुमानित समय की जानकारी देते हैं, तो आपके ऐप्लिकेशन के लिए ज़रूरी है कि लिसनर को रजिस्टर और कॉन्फ़िगर करें, जैसा कि नीचे दिए गए उदाहरणों में दिखाया गया है.
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?, ) { // ... } // ... })
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)
किसी यात्रा को फ़ॉलो करना बंद करना
पक्का करें कि ज़रूरत न होने पर आपका ऐप्लिकेशन, यात्रा के बाद रुक जाए, जैसे कि जब ड्राइवर की तरफ़ से बैकएंड पर, यात्रा को पूरा हुआ के तौर पर मार्क किया जाता है. यात्रा खत्म की जा रही है शेयर करने से, फ़्लीट इंजन के ग़ैर-ज़रूरी नेटवर्क अनुरोधों से बचा जाता है और मेमोरी को रोका जाता है लीक हो जाता है.
इस यात्रा को फ़ॉलो करना बंद करने के लिए 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, उस क्लाउड प्रोजेक्ट का आईडी होना चाहिए जिसका मालिकाना हक
ऐप्लिकेशन है. |
401 | UNAUTHENTICATED | पुष्टि करने के लिए मान्य क्रेडेंशियल न होने पर, आपको गड़बड़ी का यह मैसेज मिलता है. उदाहरण के लिए, अगर JWT टोकन को ट्रिप आईडी या JWT टोकन के बिना साइन किया गया है यह खत्म हो गया है. |
403 | PERMISSION_DENIED | आपको यह गड़बड़ी तब दिखती है, जब क्लाइंट के पास ज़रूरी अनुमति न हो (उदाहरण के लिए, जब उपभोक्ता की भूमिका वाला कोई उपयोगकर्ता, updateTrip को कॉल करने की कोशिश करता है), जब JWT टोकन अमान्य हो या क्लाइंट प्रोजेक्ट के लिए एपीआई चालू न हो. ऐसा हो सकता है कि JWT टोकन मौजूद न हो या टोकन को किसी ऐसे ट्रिप आईडी से साइन किया गया हो जो अनुरोध की गई यात्रा के आईडी से मेल नहीं खाता. |
429 | RESOURCE_EXHAUSTED | संसाधन कोटा शून्य है या ट्रैफ़िक की दर तय सीमा से ज़्यादा है. |
503 | हवा की क्वालिटी की जानकारी उपलब्ध नहीं है | सेवा उपलब्ध नहीं है. आम तौर पर, सर्वर काम नहीं करता है. |
504 | DEADLINE_EXCEEDED | अनुरोध की समयसीमा खत्म हो गई है. यह गड़बड़ी सिर्फ़ तब होती है, जब कॉल करने वाला व्यक्ति, समयसीमा को मेथड की डिफ़ॉल्ट समयसीमा से कम सेट करता है. इसका मतलब है कि अनुरोध की गई समयसीमा, सर्वर के लिए अनुरोध को प्रोसेस करने के लिए ज़रूरत के मुताबिक नहीं है और अनुरोध समयसीमा के अंदर पूरा नहीं हुआ. |
Consumer SDK टूल से जुड़ी गड़बड़ियां ठीक करना
उपभोक्ता SDK टूल, कॉलबैक का इस्तेमाल करके उपभोक्ता ऐप्लिकेशन को यात्रा अपडेट करने से जुड़ी गड़बड़ियां भेजता है
मैकेनिज़्म. कॉलबैक पैरामीटर, प्लैटफ़ॉर्म के हिसाब से रिटर्न टाइप होता है (
TripUpdateError
Android पर और
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
gRPC स्टेटस कोड एक्सट्रैक्ट किया जा सकता है, जो गड़बड़ी के बारे में जानकारी देता है
onTripUpdateError()
से लौटाए गए TripUpdateError
से.
// Called when there is a trip update error.
override fun onTripUpdateError(tripInfo: TripInfo, error: TripUpdateError) {
val code = error.getStatusCode()
}
स्थिति कोड को समझना
स्थिति कोड दो तरह की गड़बड़ियों को कवर करते हैं: सर्वर और नेटवर्क से जुड़ी गड़बड़ियां, और क्लाइंट-साइड से जुड़ी गड़बड़ियां हो सकती हैं.
सर्वर और नेटवर्क की गड़बड़ियां
नीचे दिए गए स्टेटस कोड, नेटवर्क या सर्वर की गड़बड़ियों के लिए हैं और आपको उन्हें हल करने के लिए कोई कार्रवाई करने की ज़रूरत नहीं है. Consumer SDK टूल, इन गड़बड़ियों से अपने-आप ठीक हो जाता है.
स्थिति कोड | ब्यौरा |
---|---|
रद्द किया गया | सर्वर ने जवाब भेजना बंद कर दिया. आम तौर पर, ऐसा सर्वर की समस्या की वजह से होता है. |
रद्द कर दी गई | सर्वर ने आउटगोइंग रिस्पॉन्स को बंद कर दिया. आम तौर पर, ऐसा तब होता है, जब ऐप्लिकेशन को बैकग्राउंड में भेजा जाता है या consumer ऐप्लिकेशन की स्थिति में बदलाव होता है. |
INTERRUPTED | |
DEADLINE_EXCEEDED | सर्वर ने जवाब देने में काफ़ी समय लगाया. |
हवा की क्वालिटी की जानकारी उपलब्ध नहीं है | सर्वर उपलब्ध नहीं था. आम तौर पर, यह समस्या नेटवर्क से जुड़ी होती है. |
क्लाइंट से जुड़ी गड़बड़ियां
यहां दिए गए स्टेटस कोड, क्लाइंट से जुड़ी गड़बड़ियों के लिए हैं. इन्हें ठीक करने के लिए, आपको कार्रवाई करनी होगी. उपभोक्ता SDK टूल तब तक यात्रा को रीफ़्रेश करने की कोशिश करता रहता है, जब तक आप शेयर करना बंद कर दें, लेकिन यह तब तक वापस नहीं आएगा, जब तक आप कार्रवाई नहीं करते.
स्थिति कोड | ब्यौरा |
---|---|
INVALID_ARGUMENT | उपभोक्ता ऐप्लिकेशन ने यात्रा का अमान्य नाम दिया है. यात्रा का नाम, providers/{provider_id}/trips/{trip_id} फ़ॉर्मैट में होना चाहिए.
|
NOT_FOUND | यात्रा की जानकारी कभी नहीं बनाई गई. |
PERMISSION_DENIED | उपभोक्ता ऐप्लिकेशन के पास ज़रूरी अनुमतियां नहीं हैं. यह गड़बड़ी तब होती है, जब:
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
|
RESOURCE_EXHAUSTED | संसाधन कोटा शून्य है या ट्रैफ़िक फ़्लो की दर गति सीमा. |
UNAUTHENTICATED | अमान्य JWT टोकन के कारण अनुरोध प्रमाणीकरण विफल रहा. यह गड़बड़ी तब होती है, जब JWT टोकन पर ट्रिप आईडी के बिना हस्ताक्षर किया जाता है या JWT टोकन की समयसीमा खत्म हो जाती है. |