गाड़ियां खोजें

मांग के हिसाब से यात्रा की सेवा के तहत, SearchVehicles तरीके का इस्तेमाल करके, आस-पास के वाहन ढूंढे जा सकते हैं.

SearchVehicles तरीके से, आपको अपने उपभोक्ता मोबाइल ऐप्लिकेशन में आस-पास उपलब्ध ऐसे वाहन ढूंढने में मदद मिलती है जो किसी खास राइड या डिलीवरी के अनुरोध के लिए सबसे सही हों. SearchVehicles एपीआई, रैंक के हिसाब से वाहनों की लिस्ट दिखाता है. इन वाहनों के एट्रिब्यूट, यात्रा के लिए अनुरोध किए गए एट्रिब्यूट से मेल खाते हैं. रैंकिंग, आपके चुने गए विकल्प के हिसाब से तय होती है. जैसे, पहुंचने का अनुमानित समय, दूरी या पिकअप पॉइंट से सीधी दूरी.

एट्रिब्यूट खोजें वाहन की विशेषताएं
  • पिकअप और ड्रॉप-ऑफ़ की जगहें
  • वाहन और यात्रा के टाइप के लिए अनुरोध किया गया
  • ज़रूरी क्षमता
  • मिलान करने के लिए इस्तेमाल किए जाने वाले अन्य ज़रूरी एट्रिब्यूट
  • किसी वाहन की आखिरी लोकेशन
  • वाहन की स्थिति, टाइप या क्षमता
  • अन्य कस्टम एट्रिब्यूट

SearchVehicles तरीके का इस्तेमाल करना

SearchVehicles का इस्तेमाल करने के लिए, यह सामान्य तरीका अपनाएं:

  1. यात्रा के लिए असाइन किए जाने वाले SearchVehiclesRequest को बनाएं.
  2. बनाए गए अनुरोध के साथ SearchVehicles एपीआई (vehicleService.searchVehicles) को कॉल करें.
  3. एपीआई से मिले SearchVehicleResponse को प्रोसेस करें.

SearchVehiclesRequest फ़ील्ड

SearchVehiclesRequest बनाने के लिए, इन ज़रूरी एट्रिब्यूट फ़ील्ड का इस्तेमाल करें:

फ़ील्ड ब्यौरा
अभिभावक ज़रूरी है. यह providers/{provider} फ़ॉर्मैट में होना चाहिए. प्रोवाइडर, उस Google Cloud प्रोजेक्ट का प्रोजेक्ट आईडी होना चाहिए जिसका सेवा खाता यह कॉल कर रहा है.
vehicle_types ज़रूरी है. अनुरोध किए गए वाहनों के टाइप. ये AUTO, TWO_WHEELER, TAXI, TRUCK, BICYCLE या PEDESTRIAN में से कोई एक हो सकता है.
trip_types ज़रूरी है. यह EXCLUSIVE (हर ड्राइवर के लिए एक बार में एक यात्रा) या SHARED (हर ड्राइवर के लिए एक बार में एक या उससे ज़्यादा यात्राएं) हो सकता है.
minimum_capacity ज़रूरी है. नई यात्रा के लिए वाहन की कम से कम बची हुई क्षमता. यह क्षमता, यात्रियों या डिलीवरी के लिए हो सकती है.
pickup_point ज़रूरी है. यात्रा के लिए पिकअप की जगह की जानकारी, अक्षांश/देशांतर के निर्देशांकों में.
dropoff_point ज़रूरी नहीं. यात्रा के खत्म होने की जगह की जानकारी, अक्षांश/देशांतर के कोऑर्डिनेट में. अगर trip_types में TripType.SHARED शामिल है, तो यह फ़ील्ड ज़रूरी है.
pickup_radius_meters ज़रूरी है. पिकअप पॉइंट से वाहन की खोज के दायरे की त्रिज्या, मीटर में.
order_by ज़रूरी है. वाहनों को इनमें से किसी एक के हिसाब से क्रम में लगाएं:
  • PICKUP_POINT_ETA, पिकअप पॉइंट पर वाहन के पहुंचने का अनुमानित समय.
  • PICKUP_POINT_DISTANCE, वाहन और पिकअप पॉइंट के बीच की दूरी.
  • DROPOFF_POINT_ETA, वाहन के ड्रॉप-ऑफ़ पॉइंट पर पहुंचने का अनुमानित समय.
  • PICKUP_POINT_STRAIGHT_DISTANCE, वाहन और पिकअप पॉइंट के बीच सीधी दूरी (रास्ते में नहीं).
सोलर पैनलों की संख्या ज़रूरी है. ज्यादा से ज्यादा 1 से 50 वाहन लौटाए जा सकते हैं.
फ़िल्टर करें Optional. वाहन खोजते समय लागू की जाने वाली फ़िल्टर क्वेरी.
maximum_staleness Optional. इस फ़िल्टर से, खोज के नतीजे सिर्फ़ उन वाहनों तक सीमित हो जाते हैं जिन्होंने तय की गई अवधि में Fleet Engine को जगह की जानकारी के अपडेट भेजे हैं. अगर इस फ़ील्ड को सेट नहीं किया जाता है, तो सर्वर पांच मिनट को डिफ़ॉल्ट वैल्यू के तौर पर इस्तेमाल करता है.

SearchVehicleRequest फ़ील्ड का पूरा सेट देखने के लिए, रेफ़रंस दस्तावेज़ देखें.

खोजवाहनअनुरोध परिदृश्य

यह अनुभाग SearchVehiclesRequest बनाने के उदाहरण दिखाता है.

उदाहरण के लिए, मान लीजिए कि कोई ग्राहक रेस्टोरेंटएक्स से आना चाहता है, और आपके पास चार वाहन हैं:

  • वाहन 1: रेस्टोरेंटX से 3500 मीटर दूर.
  • वाहन 2: रेस्टोरेंटX से 100 मीटर की दूरी पर, स्थान A और B पर पिकअप और ड्रॉप के साथ एक सक्रिय यात्रा.
  • वाहन 3: रेस्टोरेंटX से 200 मीटर दूर, और एक ड्रॉप-ऑफ़ बहुत दूर है.
  • वाहन 4: RestaurantX से 1000 मीटर की दूरी पर है.

यहां वाहन के हिसाब से, अलग-अलग अनुरोध दिखाए गए हैं.

वाहन 4 लौटाता है

     Pickup at RestaurantX, radius = 1200m, order by PICKUP_POINT_ETA
    

वाहन 3 और 4 लौटाता है

     Pickup at RestaurantX, radius = 1200m, order by PICKUP_POINT_ETA, is_back_to_back enabled
    

वाहन 2, 3, और 4 की जानकारी दिखाता है

     Pickup at RestaurantX, radius = 1200m, order by PICKUP_POINT_ETA, current_trips_present = ALL
    

खोजवाहनप्रतिक्रिया फ़ील्ड

SearchVehiclesResponse में VehicleMatch इकाइयों की सूची होती है, जिन्हें SearchVehiclesRequest में निर्दिष्ट order_by विशेषता के अनुसार रैंक किया जाता है. प्रत्येक VehicleMatch इकाई में निम्नलिखित फ़ील्ड होते हैं:

फ़ील्ड ब्यौरा
गाड़ी Vehicle ऑब्जेक्ट, जिसमें vehicle_id और Vehicle विशेषताएं शामिल हैं.
vehicle_pickup_eta यदि यह यात्रा वाहन को अभी सौंपी जाए तो पिकअप स्थान पर वाहन का ETA.
vehicle_pickup_distance_meter वाहन और नई यात्रा के पिकअप स्थान के बीच मीटर में दूरी.
vehicle_pickup_straight_line_distance_meter वाहन और नई यात्रा के पिकअप स्थान के बीच मीटर में सीधी रेखा की दूरी.
vehicle_dropoff_eta अगर इस यात्रा को अभी वाहन को असाइन किया जाता है, तो ड्रॉप-ऑफ़ की जगह पर वाहन के पहुंचने का अनुमानित समय.
vehicle_trips_waypoints वर्तमान में वाहन को सौंपी गई सक्रिय यात्राओं के लिए पिकअप और ड्रॉप-ऑफ बिंदुओं सहित शेष मार्ग बिंदुओं की सूची.
vehicle_match_type वाहन की यात्रा का टाइप. यह EXCLUSIVE, BACK_TO_BACK, CARPOOL या CARPOOL_BACK_TO_BACK हो सकता है.

VehicleMatch फ़ील्ड की पूरी सूची देखने के लिए, यहां जाएं:

फ़िल्टर क्वेरी का इस्तेमाल करना

SearchVehicles और ListVehicles, फ़िल्टर क्वेरी का इस्तेमाल करके, वाहन की विशेषताओं के आधार पर फ़िल्टर करने की सुविधा देते हैं.

फ़िल्टर क्वेरी, सिर्फ़ वाहनों के कस्टम एट्रिब्यूट के हिसाब से फ़िल्टर करने की सुविधा देती हैं. इनका इस्तेमाल अन्य फ़ील्ड के लिए नहीं किया जा सकता. अगर इस फ़िल्टर का इस्तेमाल ऐसी खोज में किया जाता है जिसमें minimum_capacity या vehicle_types जैसे अन्य फ़ील्ड के मानदंड शामिल हैं, तो फ़िल्टर क्वेरी AND क्लॉज़ के तौर पर काम करती है.

उदाहरण के लिए, अगर आपको कम से कम छह लोगों के बैठने की क्षमता वाला वाहन खोजना है और आपने attributes जैसे कि पालतू जानवरों को साथ ले जाने की अनुमति है वाला फ़िल्टर लगाया है, तो आपको सिर्फ़ ऐसे वाहन दिखेंगे जिनमें पालतू जानवरों को साथ ले जाने की अनुमति है और जिनमें कम से कम छह लोग बैठ सकते हैं.

फ़िल्टर क्वेरी के सिंटैक्स के बारे में जानने के लिए, AIP-160 देखें. वाहन के एट्रिब्यूट बनाने के बारे में जानकारी के लिए, वाहन के फ़ील्ड अपडेट करें गाइड में वाहन के एट्रिब्यूट फ़ील्ड देखें.

SearchVehicles का उदाहरण

इस उदाहरण में, Java gRPC लाइब्रेरी का इस्तेमाल करके, SearchVehicles API को इस्तेमाल करने का तरीका बताया गया है.

static final String PROJECT_ID = "project-id";

VehicleServiceBlockingStub vehicleService =
    VehicleService.newBlockingStub(channel);

String parent = "providers/" + PROJECT_ID;
SearchVehiclesRequest searchVehiclesRequest = SearchVehiclesRequest.newBuilder()
    .setParent(parent)
    .setPickupPoint( // Grand Indonesia East Mall
        TerminalLocation.newBuilder().setPoint(
            LatLng.newBuilder().setLatitude(-6.195139).setLongitude(106.820826)))
    .setDropoffPoint( // Balai Sidang Jkt Convention Center
        TerminalLocation.newBuilder().setPoint(
            LatLng.newBuilder().setLatitude(-6.213796).setLongitude(106.807195)))
    .setPickupRadiusMeters(2000)
    .setCount(10)
    .setMinimumCapacity(2)
    .addTripTypes(TripType.EXCLUSIVE)
    .addVehicleTypes(VehicleType.newBuilder().setCategory(Category.AUTO).build())
    .setCurrentTripsPresent(CurrentTripsPresent.ANY)
    .setFilter("attributes.on_trip=\"false\"")
    .setOrderBy(VehicleMatchOrder.PICKUP_POINT_ETA)
    .build();

try {
  SearchVehiclesResponse searchVehiclesResponse =
      vehicleService.searchVehicles(searchVehiclesRequest);
} catch (StatusRuntimeException e) {
  Status s = e.getStatus();
  switch (s.getCode()) {
    case NOT_FOUND:
      break;
    case PERMISSION_DENIED:
      break;
  }
  return;
}

List<VehicleMatch> vehicleMatches =
    searchVehicleResponse.getMatchesList();

// Each VehicleMatch contains a Vehicle entity and information about the
// distance and ETA to the pickup point and drop-off point.

आगे क्या करना है