इस सेक्शन में, शेड्यूल किए गए टास्क के लिए वाहन को तैयार करने का तरीका बताया गया है. आपका बैकएंड किसी वाहन को किसी टास्क से मैच कर सके, इसके लिए आपको यहां दिए गए हर चरण को पूरा करना होगा.
Listener को सेट अप करना
Driver SDK टूल, बैकग्राउंड में कार्रवाइयां करता है. इसलिए, गड़बड़ियां, चेतावनियां या डीबग मैसेज जैसे कुछ इवेंट होने पर सूचनाएं ट्रिगर करने के लिए, DriverStatusListener
का इस्तेमाल करें. गड़बड़ियां कुछ समय के लिए हो सकती हैं (जैसे, BACKEND_CONNECTIVITY_ERROR
). इसके अलावा, इनकी वजह से जगह की जानकारी के अपडेट हमेशा के लिए बंद हो सकते हैं. उदाहरण के लिए, अगर आपको VEHICLE_NOT_FOUND
गड़बड़ी का मैसेज मिलता है, तो इसका मतलब है कि कॉन्फ़िगरेशन में कोई गड़बड़ी है.
यहां दिए गए उदाहरण में, DriverStatusListener
को लागू करने का तरीका बताया गया है:
class MyStatusListener implements DriverStatusListener {
/** Called when background status is updated, during actions such as location reporting. */
@Override
public void updateStatus(
StatusLevel statusLevel, StatusCode statusCode, String statusMsg, @Nullable Throwable cause) {
// Existing implementation
if (cause != null && cause instanceof StatusRuntimeException) {
if (Status.NOT_FOUND.getCode().equals(cause.getStatus().getCode())) {
// NOT_FOUND gRPC exception thrown by Fleet Engine.
}
}
}
}
DriverContextBuilder.setDriverStatusListener(new MyStatusListener());
जगह की जानकारी के अपडेट पाने की सुविधा चालू करना
*VehicleReporter
इंस्टेंस बनाने के बाद, जगह की जानकारी के अपडेट पाने की सुविधा को इस तरह चालू करें:
Java
DeliveryVehicleReporter reporter = ...;
reporter.enableLocationTracking();
Kotlin
val reporter = ...
reporter.enableLocationTracking()
(ज़रूरी नहीं) अपडेट इंटरवल सेट करना
डिफ़ॉल्ट रूप से, Driver SDK टूल, जगह की जानकारी 10 सेकंड के अंतराल पर भेजता है. जगह की जानकारी का हर अपडेट यह भी बताता है कि वाहन ऑनलाइन है. reporter.setLocationReportingInterval(long, TimeUnit)
का इस्तेमाल करके, इस इंटरवल को बदला जा सकता है. अपडेट करने के लिए, कम से कम पांच सेकंड का इंटरवल होना चाहिए. बार-बार अपडेट करने से, अनुरोधों में ज़्यादा समय लग सकता है और गड़बड़ियां हो सकती हैं.