इस दस्तावेज़ में, एक के बाद एक दो सफ़र बनाने, सही फ़ील्ड सेट करने, और उसे किसी वाहन को असाइन करने का तरीका बताया गया है. यह माना जाता है कि आपने Fleet Engine सेट अप कर लिया है, आपने वाहन जोड़ लिए हैं, आपके पास चालक के लिए ऐप्लिकेशन है, और आपके पास उपभोक्ता के लिए ऐप्लिकेशन है. इसके अलावा, आपको ऑन-डिमांड यात्राओं के लिए उपलब्ध अलग-अलग यात्रा स्थितियों के बारे में भी पता होना चाहिए. इस बारे में ज़्यादा जानने के लिए, यहां दी गई गाइड देखें:
- Fleet Engine सेट अप करना
- वाहन बनाना
- यात्रा के अनुरोध की खास जानकारी में, यात्रा के अलग-अलग मामले
यात्रा की जानकारी बनाने के बारे में बुनियादी बातें
इस सेक्शन में, Fleet Engine में यात्रा बनाने के लिए ज़रूरी अनुरोध की जानकारी दी गई है. gRPC और REST, दोनों में से किसी एक का इस्तेमाल करके, कलेक्शन बनाने का अनुरोध किया जाता है.
यात्रा के फ़ील्ड
Fleet Engine में ट्रिप बनाने के लिए, नीचे दिए गए फ़ील्ड का इस्तेमाल करें. अलग-अलग तरह की यात्राओं के लिए, अलग-अलग फ़ील्ड का इस्तेमाल किया जा सकता है: एक या कई डेस्टिनेशन, एक के बाद एक या शेयर की गई पूलिंग वाली यात्राएं. ट्रिप बनाते समय, वैकल्पिक फ़ील्ड की वैल्यू दी जा सकती है. इसके अलावा, ट्रिप को अपडेट करते समय भी इन फ़ील्ड की वैल्यू दी जा सकती है.
नाम | ज़रूरी है? | ब्यौरा |
---|---|---|
parent | हां | प्रोजेक्ट आईडी वाली स्ट्रिंग. यह आईडी, आपके पूरे Fleet Engine इंटिग्रेशन में इस्तेमाल किए गए आईडी से मेल खाना चाहिए. साथ ही, इसमें सेवा खाते की भूमिकाएं भी एक ही होनी चाहिए. |
trip_id | हां | आपने जो स्ट्रिंग बनाई है वह इस ट्रिप की खास तौर पर पहचान करती है. ट्रिप आईडी पर कुछ पाबंदियां हैं, जैसा कि रेफ़रंस में बताया गया है. |
trip_type | हां | अपनी यात्रा के टाइप के लिए, TripType को इन वैल्यू पर सेट करें:
|
pickup_point | हां | यात्रा की शुरुआत की जगह. |
इंटरमीडिएट डेस्टिनेशन | हां | सिर्फ़ एक से ज़्यादा डेस्टिनेशन वाली यात्राओं के लिए: उन जगहों की सूची जहां ड्राइवर, पिकअप और ड्रॉप-ऑफ़ के बीच में जाता है. |
vehicle_waypoints | हां | सिर्फ़ शेयर की गई पूल की गई यात्राएं: इस फ़ील्ड की मदद से, एक से ज़्यादा यात्राओं के वे रास्ते जोड़े जा सकते हैं.
इसमें, असाइन किए गए वाहन के लिए बचे हुए सभी वेपॉइंट के साथ-साथ, इस यात्रा के लिए पिकअप और ड्रॉप-ऑफ़ वेपॉइंट भी शामिल होते हैं. इस फ़ील्ड को सेट करने के लिए,
|
number_of_passengers | नहीं | यात्रा में शामिल यात्रियों की संख्या. |
dropoff_point | नहीं | यात्रा की मंज़िल. |
vehicle_id | नहीं | यात्रा के लिए असाइन किए गए वाहन का आईडी. |
उदाहरण: एक के बाद एक दो यात्राएं बनाना
यहां, एक के बाद एक यात्राएं बनाने और उन्हें किसी वाहन को असाइन करने का तरीका बताया गया है. इस स्थिति में, यात्रा बनाने का तरीका एक ही डेस्टिनेशन वाली यात्रा के लिए इस्तेमाल किए जाने वाले तरीके जैसा ही होता है. इसके बाद ही, कोई दूसरी यात्रा बनाई जा सकती है और उसे किसी ऐसे वाहन को असाइन किया जा सकता है जिसमें पहले से ही कोई यात्रा चालू हो.
// A vehicle with ID 'my-vehicle' is already created and it is assigned to a trip with ID 'current-trip'.
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String VEHICLE_ID =" my-vehicle";
static final String TRIP_ID = "back-to-back-trip");
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
String parent = "providers/" + PROJECT_ID;
Trip trip = Trip.newBuilder()
.setTripType(TripType.EXCLUSIVE)
.setPickupPoint(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.195139).setLongitude(106.820826)))
.setDropoffPoint(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.1275).setLongitude(106.6537)))
.setVehicleId(VEHICLE_ID)
.build();
// Create trip request
CreateTripRequest createTripRequest = CreateTripRequest.newBuilder()
.setParent(parent)
.setTripId(TRIP_ID)
.setTrip(trip)
.build();
// Error handling.
try {
// Fleet Engine automatically assigns a 'waypoints' list to the trip containing
// the vehicle's current trip waypoints.
Trip createdTrip =
tripService.createTrip(createTripRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case ALREADY_EXISTS:
break;
case PERMISSION_DENIED:
break;
}
return;
}
एक के बाद एक होने वाली यात्राओं की जानकारी अपडेट करना
जब किसी वाहन को एक के बाद एक दो यात्राओं के लिए असाइन किया जाता है, तो उस वाहन को एक और यात्रा असाइन की जाती है. भले ही, उस वाहन को पहले ही एक यात्रा के लिए असाइन किया गया हो.
Fleet Engine में बनाई गई किसी भी यात्रा को किसी वाहन को असाइन करना ज़रूरी है, ताकि Fleet Engine, यात्रा के ईटीए का हिसाब लगा सके और उसे ट्रैक कर सके. ऐसा, यात्रा बनाने के दौरान या बाद में, यात्रा अपडेट करते समय किया जा सकता है.
किसी वाहन को यात्रा असाइन करने के बाद, Fleet Engine, वाहन के वॉइसपॉइंट फ़ील्ड में, एक के बाद एक होने वाली यात्राओं से जुड़े वॉइसपॉइंट अपने-आप जोड़ देता है. किसी यात्रा के remainingWaypoints
फ़ील्ड में, सभी वॉइसपॉइंट की सूची होती है. इसमें उन अन्य यात्राओं के वॉइसपॉइंट भी शामिल होते हैं जिन्हें यात्रा के ड्रॉप-ऑफ़ से पहले विज़िट किया जाएगा.
उदाहरण के लिए, एक के बाद एक दो यात्राएं: यात्रा A और यात्रा B. वाहन ने यात्रा A के लिए उपभोक्ता को पिक अप किया है और उसे छोड़ने की जगह के रास्ते में, ड्राइवर को अगली यात्रा, यात्रा B के लिए किसी दूसरे उपभोक्ता को पिकअप करने का अनुरोध मिलता है.
getVehicle()
को कॉल करने पर,remainingWaypoints
दिखता है जिसमें ये शामिल हैं:
A पिकअप → B पिकअप → B पिकअप.- यात्रा A के लिए,
getTrip()
याonTripRemainingWaypointsUpdated
कॉलबैक,remainingWaypoints
को दिखाता है. इसमें ये चीज़ें शामिल होती हैं:
एक ड्रॉप-ऑफ़. getTrip()
या यात्रा B के लिएonTripRemainingWaypointsUpdated
कॉलबैक,remainingWaypoints
को दिखाता है. इसमें ये शामिल हैं:
A ड्रॉप-ऑफ़ → B पिकअप → और B ड्रॉप-ऑफ़.