كجزء من خدمة الرحلات عند الطلب، يمكنك العثور على المركبات القريبة باستخدام طريقة SearchVehicles.
تتيح لك طريقة SearchVehicles العثور على المركبات القريبة المتاحة في تطبيقك المتوافق مع الأجهزة الجوّالة، والتي تكون الأنسب لرحلة معيّنة أو طلب تسليم. تعرض واجهة برمجة التطبيقات SearchVehicles قائمة بالمركبات مرتّبة حسب الأولوية، وتتطابق سماتها مع سمات الرحلة المطلوبة. يتم الترتيب حسب خيارك من وقت الوصول المقدَّر أو المسافة أو المسافة بخط مستقيم من نقطة الاستلام.
| سمات البحث | سمات المركبات |
|---|---|
|
|
استخدام طريقة SearchVehicles
لاستخدام SearchVehicles، اتّبِع هذه العملية العامة:
- أنشئ
SearchVehiclesRequestاستنادًا إلى الرحلة التي سيتم تعيينها. - استدعِ واجهة برمجة التطبيقات
SearchVehicles(vehicleService.searchVehicles) باستخدام الطلب الذي تم إنشاؤه. - عالِج
SearchVehicleResponseالذي يتم عرضه من واجهة برمجة التطبيقات.
حقول SearchVehiclesRequest
استخدِم حقول السمات المطلوبة التالية لإنشاء SearchVehiclesRequest:
| الحقل | الوصف |
|---|---|
| parent | مَعلمة مطلوبة. يجب أن يكون التنسيق 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 | مَعلمة مطلوبة. ترتيب المركبات حسب أحد الخيارات التالية:
|
| count | مَعلمة مطلوبة. الحد الأقصى لعدد المركبات التي سيتم عرضها، ويتراوح بين 1 و50 |
| filter | اختياريّ. طلب فلتر لتطبيقه عند البحث عن المركبات |
| maximum_staleness | اختياريّ. يقتصر البحث على المركبات التي أرسلت تحديثات الموقع الجغرافي إلى Fleet Engine خلال المدة المحدّدة فقط. إذا لم يتم ضبط هذا الحقل، يستخدم الخادم خمس دقائق كقيمة تلقائية. |
يُرجى الرجوع إلى المستندات المرجعية للاطّلاع على المجموعة الكاملة من SearchVehicleRequest.
سيناريوهات SearchVehiclesRequest
يعرض هذا القسم أمثلة على كيفية إنشاء SearchVehiclesRequest.
على سبيل المثال، لنفترض أنّ أحد العملاء يريد استلامه من مطعم RestaurantX، ولديك أربع مركبات:
- المركبة 1: على بُعد 3500 متر من مطعم RestaurantX.
- المركبة 2: على بُعد 100 متر من مطعم RestaurantX، ولديها رحلة نشطة مع استلام وتسليم في الموقعَين A وB
- المركبة 3: على بُعد 200 متر من مطعم RestaurantX، ولديها عملية تسليم واحدة متبقية بعيدة جدًا
- المركبة 4: على بُعد 1000 متر من مطعم RestaurantX
تعرض القائمة التالية طلبات مختلفة حسب المركبة التي يتم عرضها.
عرض المركبة 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
يتألف SearchVehiclesResponse من قائمة بكيانات VehicleMatch، مرتّبة حسب سمة order_by المحدّدة في SearchVehiclesRequest. يحتوي كل كيان VehicleMatch على الحقول التالية:
| الحقل | الوصف |
|---|---|
| vehicle | كائن Vehicle، بما في ذلك vehicle_id وسمات Vehicle |
| vehicle_pickup_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، يُرجى مراجعة:
VehicleMatch message(gRPC)VehicleMatch resource(REST)
استخدام طلبات الفلتر
تتيح الطريقتان SearchVehicles وListVehicles إمكانية الفلترة حسب سمات المركبة باستخدام طلب فلتر.
لا تتيح طلبات الفلتر سوى الفلترة حسب السمات المخصّصة للمركبات، ولا يمكن استخدامها للحقول الأخرى. عند استخدامها في عملية بحث تتضمّن معايير حقول أخرى، مثل minimum_capacity أو vehicle_types، تعمل طلبات الفلتر كعبارة AND.
على سبيل المثال، إذا كنت تبحث عن مركبة بسعة لا تقل عن 6 ركاب وتفلتر attributes مثل "مسموح بالحيوانات الأليفة"، لن تعرض المعايير سوى المركبات التي تسمح بالحيوانات الأليفة ويمكنها استيعاب 6 ركاب على الأقل.
بالنسبة إلى بنية طلبات الفلتر، يُرجى الاطّلاع على AIP-160 للحصول على أمثلة. لمعرفة تفاصيل إنشاء سمات المركبة، يُرجى الاطّلاع على حقل سمات المركبة في دليل تعديل حقول المركبة.
مثال على SearchVehicles
يوضّح المثال التالي كيفية استخدام واجهة برمجة التطبيقات SearchVehicles باستخدام
مكتبة Java gRPC. للاطّلاع على قائمة كاملة باللغات المتاحة، يُرجى مراجعة
مكتبات العملاء لخدمات الرحلات عند الطلب.
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.