ट्रांज़िट रूट, सार्वजनिक परिवहन के उन विकल्पों का इस्तेमाल करके नेविगेशन के निर्देश देता है जो उस इलाके में उपलब्ध हैं. ट्रांज़िट के विकल्पों में बसें, मेट्रो, और ट्रेनें वगैरह शामिल हो सकती हैं. ट्रांज़िट रूट में, आम तौर पर ट्रांज़िट स्टेशनों तक पैदल जाने, वहां से आने, और एक स्टेशन से दूसरे स्टेशन तक पैदल जाने के निर्देश भी शामिल होते हैं. ट्रांज़िट रूट के लिए, आम तौर पर आपको यात्रा के एक से ज़्यादा मोड का इस्तेमाल करना पड़ता है. इसलिए, रूट का अनुरोध करने का तरीका और जवाब के कुछ हिस्से अलग-अलग होते हैं.
ट्रांज़िट रूट, अन्य रूट से कैसे अलग होते हैं
ट्रांज़िट रूट का अनुरोध, travelMode को TRANSIT पर सेट करके किया जाता है. यह अलग-अलग travelMode विकल्पों का इस्तेमाल करने वाले रूट से अलग होता है. अन्य रूट की तुलना में, एक ही तरह के सभी ऑब्जेक्ट और विकल्पों का अनुरोध नहीं किया जा सकता. साथ ही, जवाब में अलग-अलग फ़ील्ड दिखते हैं.
Routes API में, सभी तरह की यात्राओं के लिए, हर चरण में नेविगेशन का एक निर्देश होता है. इसलिए, नेविगेशन का हर निर्देश एक चरण होता है. ट्रांज़िट रूट का जवाब, यात्रा के अन्य मोड वाले रूट के जवाब से काफ़ी मिलता-जुलता होता है. हालांकि, इन दोनों के बीच कुछ मुख्य अंतर हैं:
| अनुरोध में अंतर | जवाब में अंतर |
|---|---|
| इंटरमीडिएट वेपॉइंट तय नहीं किए जा सकते. | इसमें ट्रांज़िट की जानकारी शामिल होती है. |
| ईको-फ़्रेंडली रूट नहीं पाए जा सकते | इसमें यात्रा के हर मोड के लिए मेटाडेटा शामिल होता है. इसमें `stepsOverview` में, यात्रा के उस मोड के चरणों की खास जानकारी होती है. इस मेटाडेटा का अनुरोध करने के लिए, `routes.legs.stepsOverview` फ़ील्ड मास्क का इस्तेमाल करें. |
| यह तय नहीं किया जा सकता कि ट्रैफ़िक डेटा को कैसे और शामिल करना है या नहीं | |
| उन रूट की सुविधाओं के बारे में नहीं बताया जा सकता जिनसे बचना है | |
के लिए, सिर्फ़ transitPreferences तय की जा सकती हैंroutingPreference. ज़्यादा जानकारी के लिए, TransitPreferences देखें. |
Routes API से मिले जवाब के बारे में ज़्यादा जानकारी के लिए, ट्रांज़िट रूट के जवाबों की समीक्षा करना देखें.
ट्रांज़िट रूट पाने के लिए
शुरुआत की जगह और मंज़िल सेट करें.
यात्रा के मोड को ट्रांज़िट पर सेट करें:
travelMode: "TRANSIT"जवाब के वे फ़ील्ड पाने के लिए फ़ील्ड मास्क जोड़ें जो आपको चाहिए. ट्रांज़िट रूट के वे फ़ील्ड पाने का अनुरोध करना देखें जिनकी आपको ज़रूरत है.
ज़रूरत पड़ने पर, ज़रूरी नहीं वाले पैरामीटर सेट करें. ट्रांज़िट रूट के लिए पैरामीटर सेट करना देखें.
ट्रांज़िट रूट के वे फ़ील्ड पाने का अनुरोध करना जिनकी आपको ज़रूरत है
फ़ील्ड मास्क का इस्तेमाल करके, ट्रांज़िट रूट के वे फ़ील्ड पाने का अनुरोध करें जिनकी आपको ज़रूरत है. यहां दी गई टेबल में, ट्रांज़िट रूट के लिए कुछ सुझाए गए जवाब और उनका अनुरोध करने के लिए इस्तेमाल किया जाने वाला फ़ील्ड मास्क शामिल है.
| यह जानकारी पाने के लिए | यह फ़ील्ड मास्क इस्तेमाल करें |
|---|---|
| रूट की पूरी जानकारी | routes.* |
| ट्रांज़िट की पूरी जानकारी | routes.legs.steps.transitDetails |
| हर लेग के लिए, शुरुआती जगह | routes.legs.steps.startLocation |
| हर लेग के लिए, मंज़िल | routes.legs.steps.endLocation |
| हर चरण के लिए, रूट पॉलीलाइन | routes.legs.steps.polyline |
| हर चरण के लिए, इस्तेमाल किए गए ट्रांज़िट का टाइप | routes.legs.steps.travelMode |
| हर चरण और रूट के लिए अनुमानित किराया, और स्थानीय भाषा में अनुमानित किराया | routes.travel_advisory.transitFare
localized routes.localizedValues.transitFare
ध्यान दें: |
| अवधि और दूरी के लिए, स्थानीय भाषा में टेक्स्ट | routes.localizedValues |
फ़ील्ड मास्क सेट करने के बारे में ज़्यादा जानकारी के लिए, दिखाए जाने वाले फ़ील्ड चुनना देखें.
ट्रांज़िट रूट के लिए पैरामीटर सेट करना
यहां ट्रांज़िट रूट के लिए काम के पैरामीटर दिए गए हैं:
| यह करने के लिए | यह पैरामीटर इस्तेमाल करें | नोट |
|---|---|---|
| ट्रांज़िट मोड चुनना | travelMode: "TRANSIT" |
ज़रूरी है. ज़्यादा जानें. |
| पहुंचने या जाने का समय सेट करना | "arrivalTime": "yyyy-mm-ddThh:mm:ssZ"
या "departureTime": "yyyy-mm-ddThh:mm:ssZ" |
ज़रूरी नहीं. arrival_time या departure_time में से कोई एक समय तय किया जा सकता है. अगर कोई भी समय तय नहीं किया जाता है, तो departure_time की डिफ़ॉल्ट वैल्यू, मौजूदा समय (now) होती है. पहुंचने और जाने का समय, सिर्फ़ इस समय विंडो में सेट किया जा सकता है. इसमें मौजूदा समय (now) को रेफ़रंस के तौर पर इस्तेमाल किया जाता है:
ध्यान दें: ट्रांज़िट के शेड्यूल में अक्सर बदलाव होता रहता है. साथ ही, उपलब्ध ट्रांज़िट यात्राओं में समय के साथ बदलाव हो सकता है और बहुत पहले से किए गए अनुमानों के लिए, लगातार एक जैसे नतीजे मिलने की कोई गारंटी नहीं है . |
| वैकल्पिक रूट शामिल करना | "computeAlternativeRoutes": true |
ज़रूरी नहीं. अगर उपलब्ध हो, तो Compute Routes को तीन अतिरिक्त रूट की जानकारी देने के लिए, इसे 'सही' पर सेट करें. ज़्यादा जानें |
| ट्रांज़िट के टाइप के लिए प्राथमिकताएं तय करना | "transitPreferences": { allowedTravelModes: ["BUS","SUBWAY","TRAIN","LIGHT_RAIL","RAIL"]}
ध्यान दें: अगर यात्रा का कोई पसंदीदा मोड तय किया जाता है, तो दिखाए गए रूट में ट्रांज़िट के अन्य मोड का इस्तेमाल किया जा सकता है. यहां तक कि सिर्फ़ ट्रांज़िट के अन्य मोड का इस्तेमाल भी किया जा सकता है. यह इस बात पर निर्भर करता है कि पसंदीदा यात्रा के मोड की उपलब्धता और रूट की क्षमता कैसी है. |
ज़रूरी नहीं. ट्रांज़िट के पसंदीदा मोड तय करें. ज़्यादा जानें |
| ट्रांज़िट रूट के लिए प्राथमिकताएं तय करना | "transitPreferences": {routingPreference: "LESS_WALKING|FEWER_TRANSFERS"} |
ज़रूरी नहीं. ट्रांज़िट रूटिंग की प्राथमिकताएं तय करें. ज़्यादा जानें |
उदाहरण: ट्रांज़िट के लिए रूट पाना
यहां दिए गए उदाहरण में, ट्रांज़िट के लिए रूट पाया जाता है. इसके लिए, इन पैरामीटर का इस्तेमाल किया जाता है:
ट्रेन से यात्रा करने और कम दूरी वाले पैदल रास्ते को प्राथमिकता देने के लिए प्राथमिकताएं तय करता है.
वैकल्पिक रूट का अनुरोध करता है.
एक फ़ील्ड मास्क उपलब्ध कराता है, जिससे ट्रांज़िट की जानकारी मिलती है:
curl -X POST -H 'content-type: application/json' -d '{ "origin": { "address": "Humberto Delgado Airport, Portugal" }, "destination": { "address": "Basílica of Estrela, Praça da Estrela, 1200-667 Lisboa, Portugal" }, "travelMode": "TRANSIT", "computeAlternativeRoutes": true, "transitPreferences": { routingPreference: "LESS_WALKING", allowedTravelModes: ["TRAIN"] }, }' \ -H 'Content-Type: application/json' \ -H 'X-Goog-Api-Key: YOUR_API_KEY' \ -H 'X-Goog-FieldMask: routes.legs.steps.transitDetails' \ 'https://routes.googleapis.com/directions/v2:computeRoutes'
जवाब में, दोनों रूट के लिए route.legs.steps.transitDetails फ़ील्ड दिखते हैं:
{ "routes": [ { "legs": [ { "steps": [ {}, {}, {}, { "transitDetails": { "stopDetails": { "arrivalStop": { "name": "Saldanha", "location": { "latLng": { "latitude": 38.73532, "longitude": -9.14543 } } }, "arrivalTime": "2023-08-26T10:49:42Z", "departureStop": { "name": "Aeroporto", "location": { "latLng": { "latitude": 38.769047799999996, "longitude": -9.1284593 } } }, "departureTime": "2023-08-26T10:32:10Z" }, "localizedValues": { "arrivalTime": { "time": { "text": "11:49" }, "timeZone": "Europe/Lisbon" }, "departureTime": { "time": { "text": "11:32" }, "timeZone": "Europe/Lisbon" } }, "headsign": "São Sebastião", "transitLine": { "agencies": [ { "name": "Metropolitano de Lisboa, E.P.E.", "phoneNumber": "+351 21 350 0115", "uri": "https://www.metrolisboa.pt/" } ], "name": "Vermelha", "color": "#f23061", "nameShort": "Vm", "textColor": "#000000", "vehicle": { "name": { "text": "Metrô" }, "type": "SUBWAY", "iconUri": "//maps.gstatic.com/mapfiles/transit/iw2/6/subway2.png" } }, "stopCount": 11 } }, {}, { "transitDetails": { "stopDetails": { "arrivalStop": { "name": "Rato", "location": { "latLng": { "latitude": 38.7201022, "longitude": -9.1540562 } } }, "arrivalTime": "2023-08-26T11:01:37Z", "departureStop": { "name": "Saldanha", "location": { "latLng": { "latitude": 38.73527, "longitude": -9.1455200000000012 } } }, "departureTime": "2023-08-26T10:57:57Z" }, "localizedValues": { "arrivalTime": { "time": { "text": "12:01" }, "timeZone": "Europe/Lisbon" }, "departureTime": { "time": { "text": "11:57" }, "timeZone": "Europe/Lisbon" } }, "headsign": "Rato", "transitLine": { "agencies": [ { "name": "Metropolitano de Lisboa, E.P.E.", "phoneNumber": "+351 21 350 0115", "uri": "https://www.metrolisboa.pt/" } ], "name": "Amarela", "color": "#f2c200", "nameShort": "Am", "textColor": "#000000", "vehicle": { "name": { "text": "Metrô" }, "type": "SUBWAY", "iconUri": "//maps.gstatic.com/mapfiles/transit/iw2/6/subway2.png" } }, "stopCount": 4 } }, {}, {}, {}, {}, {}, {} ] } ] } ] }