इस सेक्शन में, शेड्यूल किए गए टास्क के लिए वाहन को तैयार करने का तरीका बताया गया है. आपका बैकएंड किसी वाहन को किसी टास्क से मैच कर सके, इसके लिए आपको यहां दिए गए हर चरण को पूरा करना होगा.
Listener को सेट अप करना
ड्राइवर 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()
(ज़रूरी नहीं) अपडेट का इंटरवल सेट करना
ड्राइवर SDK डिफ़ॉल्ट रूप से, 10 सेकंड के इंटरवल पर जगह की जानकारी के अपडेट भेजता है. जगह की जानकारी का हर अपडेट यह भी बताता है कि वाहन ऑनलाइन है. reporter.setLocationReportingInterval(long, TimeUnit)
का इस्तेमाल करके, इस इंटरवल को बदला जा सकता है. अपडेट करने के लिए, कम से कम पांच सेकंड का इंटरवल होना चाहिए. ज़्यादा बार अपडेट करने की वजह से, अनुरोध धीमे हो सकते हैं और गड़बड़ियां हो सकती हैं.