يوضّح لك هذا الدليل كيفية استرداد بيانات الرحلات مباشرةً من Fleet Engine، كبديل لاستخدام Consumer SDK. يمكنك استخدام هذا الأسلوب للتحكّم بشكل أكبر في تجربة المستخدم النهائي مع الاستفادة في الوقت نفسه من ميزات Fleet Engine الدقيقة وفي الوقت الفعلي، مثل الموقع الجغرافي للمركبة ووقت الوصول المقدَّر والمسار.
لمعرفة تفاصيل حول استخدام Consumer SDK، يُرجى الاطّلاع على مشاركة الرحلات عند الطلب.
استرداد معلومات الرحلة
لاسترداد معلومات الرحلة من Fleet Engine مباشرةً، استدعِ طريقة GetTrip، مع تحديد طريقة العرض JOURNEY_SHARING_V1S. راجِع المرجع الخاص بـ RPC أو REST.
عادةً ما يطلب الخادم من خدمة الرحلات معرفة حالة كل رحلة
بينما يتتبّع الراكب تقدّم المركبة. يتم عادةً تحديث بيانات الموقع الجغرافي للمركبة كل 10 ثوانٍ، ويجب أن يطلب نظامك البيانات بالمعدل نفسه. يمكن مراقبة الحقل Trip.last_location.update_time لمعرفة ما إذا كانت قد حدثت أي تعديلات منذ الطلب السابق إلى GetTrip.
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "trip-A";
String tripName = "providers/" + PROJECT_ID + "/trips/" + TRIP_ID;
GetTripRequest getTripRequest =
GetTripRequest.newBuilder()
.setName(tripName)
.setView(JOURNEY_SHARING_V1S)
.build();
Trip trip = tripService.getTrip(getTripRequest);
يحتوي عنصر Trip الناتج على الحقول التالية التي تم ملؤها بأحدث المعلومات المتاحة حول الرحلة:
name |
trip_status |
remaining_waypoints |
vehicle_id |
trip_type |
last_location |
number_of_passengers |
pickup_point |
view (== JOURNEY_SHARING_V1S) |
actual_pickup_point |
intermediate_destinations |
intermediate_destination_index |
pickup_time |
intermediate_destinations_version |
dropoff_point |
actual_dropoff_point |
dropoff_time |
|
استرداد نقاط الطريق المتبقية في الرحلة
يحتوي كيان الرحلة على حقل متكرّر من النوع TripWaypoint. يتضمّن هذا الحقل جميع نقاط المرور التي ستنتقل إليها المركبة، بالترتيب، قبل نقطة التسليم النهائية لهذه الرحلة. يؤدي تحديد طريقة عرض "مشاركة الرحلة" إلى توجيه Fleet Engine لوضع المعلومات المعدَّلة في remaining_waypoints[0]
TripWaypoint. في طرق العرض الأخرى غير "مشاركة الرحلة"، لا تشير نقطة الطريق هذه عادةً إلى آخر موقع جغرافي للمركبة المحدّدة. راجِع المرجع الخاص بـ RPC أو REST.
لمزيد من المعلومات، يُرجى الاطّلاع على حالة الرحلة ونقاط الطريق المتبقية للمركبة في دليل مقدمة عن الرحلات.
في ما يلي مثال على حقل remaining_waypoints لرحلة، الرحلة (أ):
| |||||||||||||||||||||
| |||||||||||||||||||||
في رحلات مشاركة المسار ورحلات التجميع المتتالية، قد تحتوي هذه القائمة على نقاط توقّف من رحلات أخرى يجب المرور بها قبل هذه الرحلة. على سبيل المثال، لنفترض أنّ الرحلة (ب) مخصّصة للمركبة نفسها التي تم تخصيص الرحلة (أ) لها. سيتم بعد ذلك ملء حقل
remaining_waypoints الخاص بالرحلة (أ) على النحو التالي.
تم حذف معظم الحقول للاختصار، ولكن سيتم ملؤها بما يتوافق مع المثال السابق.
| [0] | trip_id = "trip_A" |
|---|---|
| waypoint_type = PICKUP_WAYPOINT_TYPE | |
| [1] | trip_id = "trip_B" |
| waypoint_type = PICKUP_WAYPOINT_TYPE | |
| [2] | trip_id = "trip_B" |
| waypoint_type = DROP_OFF_WAYPOINT_TYPE | |
| [3] | trip_id = "trip_A" |
| waypoint_type = DROP_OFF_WAYPOINT_TYPE |
سيتم ملء حقل remaining_waypoint للرحلة B بشكل مشابه، ولكن ستظهر فيه ثلاث إدخالات فقط، لأنّ نقطة التوقّف في الرحلة A ليست جزءًا من مسار الرحلة B.