सभी डिवाइसों को देखना

इस सेक्शन में, फ़्लीट देखने के लिए JavaScript फ़्लीट ट्रैकिंग लाइब्रेरी का इस्तेमाल करने का तरीका बताया गया है. इन तरीकों के मुताबिक, आपने फ़्लीट ट्रैकिंग लाइब्रेरी सेट अप कर ली है और मैप लोड कर लिया है. ज़्यादा जानकारी के लिए, JavaScript फ़्लीट ट्रैकिंग लाइब्रेरी सेट अप करना लेख पढ़ें.

इस दस्तावेज़ में, फ़्लीट देखने के दौरान की जा सकने वाली इन कार्रवाइयों के बारे में बताया गया है:

  1. फ़्लीट को ट्रैक करना शुरू करें.
  2. इवेंट सुनना और गड़बड़ियों को मैनेज करना.
  3. ट्रैकिंग बंद करें.
  4. फ़्लीट देखते समय, किसी एक वाहन को ट्रैक करना.

फ़्लीट को ट्रैक करना शुरू करना

किसी फ़्लीट को ट्रैक करने के लिए, आपको फ़्लीट की जगह की जानकारी देने वाली कंपनी का उदाहरण देना होगा. साथ ही, मैप व्यूपोर्ट के लिए जगह की जानकारी से जुड़ी पाबंदियां सेट करनी होंगी. इन पाबंदियों के बारे में यहां बताया गया है.

फ़्लीट की जगह की जानकारी देने वाली सेवा को इंस्टैंशिएट करना

JavaScript फ़्लीट ट्रैकिंग लाइब्रेरी में जगह की जानकारी देने वाली ऐसी सेवा शामिल होती है जो Fleet Engine से कई वाहनों की जानकारी फ़ेच करती है.

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

  1. अपने प्रोजेक्ट आईडी के साथ-साथ, अपने टोकन फ़ेचर का रेफ़रंस भी इस्तेमाल करें.

  2. वाहन की फ़िल्टर क्वेरी का इस्तेमाल करना वाहन की फ़िल्टर क्वेरी से यह कंट्रोल होता है कि मैप पर कौनसे वाहन दिखाए जाएं. फ़िल्टर को Fleet Engine को भेजा जाता है.

    • ऑन-डिमांड सेवाओं के लिए, vehicleFilter का इस्तेमाल करें और ListVehiclesRequest.filter देखें
    • शेड्यूल किए गए टास्क के लिए, deliveryVehicleFilter का इस्तेमाल करें और ListDeliveryVehiclesRequest.filter की समीक्षा करें
  3. वाहन के डिसप्ले के लिए बाउंडिंग एरिया सेट करें. मैप पर वाहनों को दिखाने के लिए, locationRestriction का इस्तेमाल करके, उस इलाके की सीमा तय करें. यह सेट होने तक, जगह की जानकारी देने वाली सेवा चालू नहीं होती. जगह की सीमाओं को कॉन्स्ट्रक्टर में या कॉन्स्ट्रक्टर के बाद सेट किया जा सकता है.

  4. मैप व्यू को शुरू करें.

यहां दिए गए उदाहरणों में, मांग पर और शेड्यूल किए गए टास्क, दोनों के लिए फ़्लीट की जगह की जानकारी देने वाली सेवा देने वाली कंपनी को इंस्टैंशिएट करने का तरीका बताया गया है. इन उदाहरणों में यह भी दिखाया गया है कि जगह की जानकारी देने वाली सेवा को चालू करने के लिए, कॉन्स्ट्रक्टर में locationRestriction का इस्तेमाल कैसे किया जाता है.

मांग पर यात्राएं

JavaScript

locationProvider =
    new google.maps.journeySharing
        .FleetEngineFleetLocationProvider({
          projectId,
          authTokenFetcher,

          // Optionally, specify location bounds to
          // limit which vehicles are
          // retrieved and immediately start tracking.
          locationRestriction: {
            north: 37.3,
            east: -121.8,
            south: 37.1,
            west: -122,
          },
          // Optionally, specify a filter to limit
          // which vehicles are retrieved.
          vehicleFilter:
            'attributes.foo = "bar" AND attributes.baz = "qux"',
        });

TypeScript

locationProvider =
    new google.maps.journeySharing
        .FleetEngineFleetLocationProvider({
          projectId,
          authTokenFetcher,

          // Optionally, specify location bounds to
          // limit which vehicles are
          // retrieved and immediately start tracking.
          locationRestriction: {
            north: 37.3,
            east: -121.8,
            south: 37.1,
            west: -122,
          },
          // Optionally, specify a filter to limit
          // which vehicles are retrieved.
          vehicleFilter:
            'attributes.foo = "bar" AND attributes.baz = "qux"',
        });

शेड्यूल किए गए टास्क

JavaScript

locationProvider =
    new google.maps.journeySharing
        .FleetEngineDeliveryFleetLocationProvider({
          projectId,
          authTokenFetcher,

          // Optionally, specify location bounds to
          // limit which delivery vehicles are
          // retrieved and immediately make the location provider active.
          locationRestriction: {
            north: 37.3,
            east: -121.8,
            south: 37.1,
            west: -122,
          },
          // Optionally, specify a filter to limit
          // which delivery vehicles are retrieved.
          deliveryVehicleFilter:
            'attributes.foo = "bar" AND attributes.baz = "qux"',
        });

TypeScript

locationProvider =
    new google.maps.journeySharing
        .FleetEngineDeliveryFleetLocationProvider({
          projectId,
          authTokenFetcher,

          // Optionally, specify location bounds to
          // limit which delivery vehicles are
          // retrieved and immediately make the location provider active.
          locationRestriction: {
            north: 37.3,
            east: -121.8,
            south: 37.1,
            west: -122,
          },
          // Optionally, specify a filter to limit
          // which delivery vehicles are retrieved.
          deliveryVehicleFilter:
            'attributes.foo = "bar" AND attributes.baz = "qux"',
        });

कन्स्ट्रक्टर के बाद locationRestriction सेट करने के लिए, अपने कोड में बाद में locationProvider.locationRestriction जोड़ें, जैसा कि यहां दिए गए JavaScript उदाहरण में दिखाया गया है.

   // You can choose to not set locationRestriction in the constructor.
   // In this case, the location provider *DOES NOT START* after this line, because
   // no locationRestriction is set.
   locationProvider = new google.maps.journeySharing.DeliveryFleetLocationProvider({
   ... // not setting locationRestriction here
   });

   // You can then set the locationRestriction *after* the constructor.
   // After this line, the location provider is active.
   locationProvider.locationRestriction = {
     north: 1,
     east: 2,
     south: 0,
     west: 1,
   };

मैप व्यूपोर्ट का इस्तेमाल करके, जगह की जानकारी से जुड़ी पाबंदी सेट करना

मैप व्यू में दिख रहे इलाके से मैच करने के लिए, locationRestriction सीमाएं भी सेट की जा सकती हैं.

मांग पर यात्राएं

JavaScript

google.maps.event.addListenerOnce(
  mapView.map, 'bounds_changed', () => {
    const bounds = mapView.map.getBounds();
    if (bounds) {
      // If you did not specify a location restriction in the
      // location provider constructor, you may do so here.
      // Location tracking will start as soon as this is set.
      locationProvider.locationRestriction = bounds;
    }
  });

TypeScript

google.maps.event.addListenerOnce(
  mapView.map, 'bounds_changed', () => {
    const bounds = mapView.map.getBounds();
    if (bounds) {
      // If you did not specify a location restriction in the
      // location provider constructor, you may do so here.
      // Location tracking will start as soon as this is set.
      locationProvider.locationRestriction = bounds;
    }
  });

शेड्यूल किए गए टास्क

JavaScript

google.maps.event.addListenerOnce(
  mapView.map, 'bounds_changed', () => {
    const bounds = mapView.map.getBounds();
    if (bounds) {
      // If you did not specify a location restriction in the
      // location provider constructor, you may do so here.
      // Location provider will start as soon as this is set.
      locationProvider.locationRestriction = bounds;
    }
  });

TypeScript

google.maps.event.addListenerOnce(
  mapView.map, 'bounds_changed', () => {
    const bounds = mapView.map.getBounds();
    if (bounds) {
      // If you did not specify a location restriction in the
      // location provider constructor, you may do so here.
      // Location provider will start as soon as this is set.
      locationProvider.locationRestriction = bounds;
    }
  });

मैप व्यू को शुरू करना

जगह की जानकारी देने वाली सेवा बनाने के बाद, मैप व्यू को उसी तरह से शुरू करें जिस तरह किसी एक वाहन को फ़ॉलो करते समय किया जाता है.

JavaScript Journey Sharing लाइब्रेरी लोड करने के बाद, मैप व्यू को शुरू करें और उसे एचटीएमएल पेज में जोड़ें. आपके पेज में ऐसा <div> एलिमेंट होना चाहिए जिसमें मैप व्यू हो. यहां दिए गए उदाहरणों में, <div> एलिमेंट का नाम map_canvas है.=

मांग पर यात्राएं

JavaScript

const mapView = new
    google.maps.journeySharing.JourneySharingMapView({
  element: document.getElementById('map_canvas'),
  locationProviders: [locationProvider],
});

// If you did not specify a vehicle ID in the
// location provider constructor, you may do so here.
// Location tracking will start as soon as this is set.
locationProvider.vehicleId
                        = 'your-vehicle-id';

// Give the map an initial viewport to allow it to
// initialize; otherwise the 'ready' event above may
// not fire. The user also has access to the mapView
// object to customize as they want.
mapView.map.setCenter('Times Square, New York, NY');
mapView.map.setZoom(14);

TypeScript

const mapView = new
    google.maps.journeySharing.JourneySharingMapView({
  element: document.getElementById('map_canvas'),
  locationProviders: [locationProvider],
});

// If you did not specify a vehicle ID in the
// location provider constructor, you may do so here.
// Location tracking will start as soon as this is set.
locationProvider.VehicleId
                        = 'your-vehicle-id';

// Give the map an initial viewport to allow it to
// initialize; otherwise the 'ready' event above may
// not fire. The user also has access to the mapView
// object to customize as they want.
mapView.map.setCenter('Times Square, New York, NY');
mapView.map.setZoom(14);

शेड्यूल किए गए टास्क

JavaScript

const mapView = new
    google.maps.journeySharing.JourneySharingMapView({
  element: document.getElementById('map_canvas'),
  locationProviders: [locationProvider],
});

// If you did not specify a delivery vehicle ID in the
// location provider constructor, you may do so here.
// Location tracking will start as soon as this is set.
locationProvider.deliveryVehicleId
                        = 'your-delivery-vehicle-id';

// Give the map an initial viewport to allow it to
// initialize; otherwise the 'ready' event above may
// not fire. The user also has access to the mapView
// object to customize as they want.
mapView.map.setCenter('Times Square, New York, NY');
mapView.map.setZoom(14);

TypeScript

const mapView = new
    google.maps.journeySharing.JourneySharingMapView({
  element: document.getElementById('map_canvas'),
  locationProviders: [locationProvider],
});

// If you did not specify a delivery vehicle ID in the
// location provider constructor, you may do so here.
// Location tracking will start as soon as this is set.
locationProvider.deliveryVehicleId
                        = 'your-delivery-vehicle-id';

// Give the map an initial viewport to allow it to
// initialize; otherwise the 'ready' event above may
// not fire. The user also has access to the mapView
// object to customize as they want.
mapView.map.setCenter('Times Square, New York, NY');
mapView.map.setZoom(14);

इवेंट सुनना और गड़बड़ियों को मैनेज करना

फ़्लीट को फ़ॉलो करने के बाद, आपको इवेंट में हुए बदलावों को सुनना होगा और नीचे दिए गए सेक्शन में बताए गए तरीके से, आने वाली गड़बड़ियों को मैनेज करना होगा.

बदलाव से जुड़े इवेंट के लिए सुनना

जगह की जानकारी देने वाली सेवा का इस्तेमाल करके, वाहन ऑब्जेक्ट से फ़्लीट के बारे में मेटा जानकारी हासिल की जा सकती है. मेटा जानकारी में बदलाव करने पर, अपडेट इवेंट ट्रिगर होता है. मेटा जानकारी में, गाड़ी की प्रॉपर्टी शामिल होती हैं. जैसे, नेविगेशन की स्थिति, बाकी दूरी, और कस्टम एट्रिब्यूट.

ज़्यादा जानकारी के लिए, यहां जाएं:

नीचे दिए गए उदाहरणों में, इन बदलाव इवेंट को सुनने का तरीका बताया गया है.

मांग पर यात्राएं

JavaScript

locationProvider.addListener('update', e => {
  // e.vehicles contains data that may be
  // useful to the rest of the UI.
  for (vehicle of e.vehicles) {
    console.log(vehicle.navigationStatus);
  }
});

TypeScript

locationProvider.addListener('update',
    (e: google.maps.journeySharing.FleetEngineFleetLocationProviderUpdateEvent) => {
  // e.vehicles contains data that may be
  // useful to the rest of the UI.
  if (e.vehicles) {
    for (vehicle of e.vehicles) {
      console.log(vehicle.navigationStatus);
    }
  }
});

शेड्यूल किए गए टास्क

JavaScript

locationProvider.addListener('update', e => {
  // e.deliveryVehicles contains data that may be
  // useful to the rest of the UI.
  if (e.deliveryVehicles) {
    for (vehicle of e.deliveryVehicles) {
      console.log(vehicle.remainingDistanceMeters);
    }
  }
});

TypeScript

locationProvider.addListener('update',
    (e: google.maps.journeySharing.FleetEngineDeliveryFleetLocationProviderUpdateEvent) => {
  // e.deliveryVehicles contains data that may be
  // useful to the rest of the UI.
  if (e.deliveryVehicles) {
    for (vehicle of e.deliveryVehicles) {
      console.log(vehicle.remainingDistanceMeters);
    }
  }
});

गड़बड़ियों को सुनना

आपको किसी वाहन को फ़ॉलो करते समय होने वाली गड़बड़ियों को सुनना और उन्हें मैनेज करना है. वाहन की जानकारी का अनुरोध करने पर, गड़बड़ियां होने पर गड़बड़ी वाले इवेंट ट्रिगर होते हैं.

यहां दिए गए उदाहरण में, इन इवेंट को सुनने का तरीका बताया गया है, ताकि गड़बड़ियों को मैनेज किया जा सके.

JavaScript

locationProvider.addListener('error', e => {
  // e.error is the error that triggered the event.
  console.error(e.error);
});

TypeScript

locationProvider.addListener('error', (e: google.maps.ErrorEvent) => {
  // e.error is the error that triggered the event.
  console.error(e.error);
});

फ़्लीट को ट्रैक करना बंद करना

फ़्लीट को ट्रैक करना बंद करने के लिए, जगह की जानकारी देने वाली सेवा की सीमाओं को शून्य पर सेट करें. इसके बाद, मैप व्यू से जगह की जानकारी देने वाली सेवा को हटाएं. इसके बारे में यहां बताया गया है.

जगह की जानकारी देने वाली सेवा के दायरे को शून्य पर सेट करना

जगह की जानकारी देने वाली कंपनी को फ़्लीट को ट्रैक करने से रोकने के लिए, जगह की जानकारी देने वाली कंपनी के लिए तय किए गए सीमाओं को शून्य पर सेट करें.

मांग पर यात्राएं

JavaScript

locationProvider.locationRestriction = null;

TypeScript

locationProvider.locationRestriction = null;

शेड्यूल किए गए टास्क

JavaScript

locationProvider.locationRestriction = null;

TypeScript

locationProvider.locationRestriction = null;

मैप व्यू से जगह की जानकारी देने वाली कंपनी का नाम हटाना

इस उदाहरण में, मैप व्यू से जगह की जानकारी देने वाली सेवा को हटाने का तरीका बताया गया है.

JavaScript

mapView.removeLocationProvider(locationProvider);

TypeScript

mapView.removeLocationProvider(locationProvider);

डिलीवरी फ़्लीट देखते समय, डिलीवरी वाहन को ट्रैक करना

अगर शेड्यूल किए गए टास्क के लिए, मोबिलिटी सेवाओं का इस्तेमाल किया जा रहा है, तो एक ही मैप व्यू में फ़्लीट के साथ-साथ, किसी डिलीवरी वाहन का रास्ता और आने वाले टास्क भी देखे जा सकते हैं. ऐसा करने के लिए, डिलीवरी फ़्लीट की जगह की जानकारी देने वाली सेवा और डिलीवरी वाहन की जगह की जानकारी देने वाली सेवा, दोनों को इंस्टैंशिएट करें. इसके बाद, दोनों को मैप व्यू में जोड़ें. इंस्टैंशिएट होने के बाद, डिलीवरी फ़्लीट की जगह की जानकारी देने वाली सेवा, मैप पर डिलीवरी वाहन दिखाना शुरू कर देती है. नीचे दिए गए उदाहरणों में, दोनों जगह की जानकारी देने वाली सेवाओं को इंस्टैंशिएट करने का तरीका बताया गया है:

JavaScript

deliveryFleetLocationProvider =
    new google.maps.journeySharing
        .FleetEngineDeliveryFleetLocationProvider({
          projectId,
          authTokenFetcher,

          // Optionally, specify location bounds to
          // limit which delivery vehicles are
          // retrieved and immediately start tracking.
          locationRestriction: {
            north: 37.3,
            east: -121.8,
            south: 37.1,
            west: -122,
          },
          // Optionally, specify a filter to limit
          // which delivery vehicles are retrieved.
          deliveryVehicleFilter:
            'attributes.foo = "bar" AND attributes.baz = "qux"',
        });

deliveryVehicleLocationProvider =
    new google.maps.journeySharing
        .FleetEngineDeliveryVehicleLocationProvider({
          projectId,
          authTokenFetcher
        });

const mapView = new
    google.maps.journeySharing.JourneySharingMapView({
  element: document.getElementById('map_canvas'),
  locationProviders: [
    deliveryFleetLocationProvider,
    deliveryVehicleLocationProvider,
  ],
  // Any other options
});

TypeScript

deliveryFleetLocationProvider =
    new google.maps.journeySharing
        .FleetEngineDeliveryFleetLocationProvider({
          projectId,
          authTokenFetcher,

          // Optionally, specify location bounds to
          // limit which delivery vehicles are
          // retrieved and immediately start tracking.
          locationRestriction: {
            north: 37.3,
            east: -121.8,
            south: 37.1,
            west: -122,
          },
          // Optionally, specify a filter to limit
          // which delivery vehicles are retrieved.
          deliveryVehicleFilter:
            'attributes.foo = "bar" AND attributes.baz = "qux"',
        });

deliveryVehicleLocationProvider =
    new google.maps.journeySharing
        .FleetEngineDeliveryVehicleLocationProvider({
          projectId,
          authTokenFetcher
        });

const mapView = new
    google.maps.journeySharing.JourneySharingMapView({
  element: document.getElementById('map_canvas'),
  locationProviders: [
    deliveryFleetLocationProvider,
    deliveryVehicleLocationProvider,
  ],
  // Any other options
});

डिलीवरी वाहन को ट्रैक करने के लिए, मार्कर को पसंद के मुताबिक बनाने की सुविधा का इस्तेमाल करना

फ़्लीट मार्कर पर क्लिक करने पर, डिलीवरी वाहन की जगह की जानकारी देने वाली कंपनी को वाहन को ट्रैक करने की अनुमति देने के लिए, यह तरीका अपनाएं:

  1. मार्कर को पसंद के मुताबिक बनाएं और क्लिक करने पर होने वाली कार्रवाई जोड़ें.

  2. डुप्लीकेट मार्कर से बचने के लिए, मार्कर छिपाएं.

इन चरणों के उदाहरण, नीचे दिए गए सेक्शन में दिए गए हैं.

मार्कर को पसंद के मुताबिक बनाना और क्लिक ऐक्शन जोड़ना

JavaScript

// Specify the customization function either separately, or as a field in
// the options for the delivery fleet location provider constructor.
deliveryFleetLocationProvider.deliveryVehicleMarkerCustomization =
  (params) => {
    if (params.isNew) {
      params.marker.addListener('click', () => {
        // params.vehicle.name follows the format
        // "providers/{provider}/deliveryVehicles/{vehicleId}".
        // Only the vehicleId portion is used for the delivery vehicle
        // location provider.
        deliveryVehicleLocationProvider.deliveryVehicleId =
            params.vehicle.name.split('/').pop();
      });
    }
  };

TypeScript

// Specify the customization function either separately, or as a field in
// the options for the delivery fleet location provider constructor.
deliveryFleetLocationProvider.deliveryVehicleMarkerCustomization =
  (params: google.maps.journeySharing.DeliveryVehicleMarkerCustomizationFunctionParams) => {
    if (params.isNew) {
      params.marker.addListener('click', () => {
        // params.vehicle.name follows the format
        // "providers/{provider}/deliveryVehicles/{vehicleId}".
        // Only the vehicleId portion is used for the delivery vehicle
        // location provider.
        deliveryVehicleLocationProvider.deliveryVehicleId =
            params.vehicle.name.split('/').pop();
      });
    }
  };

डुप्लीकेट मार्कर से बचने के लिए मार्कर छिपाना

डिलीवरी वाहन की जगह की जानकारी देने वाली कंपनी से मार्कर छिपाएं, ताकि एक ही वाहन के लिए दो मार्कर रेंडर न हों:

JavaScript

// Specify the customization function either separately, or as a field in
// the options for the delivery vehicle location provider constructor.
deliveryVehicleLocationProvider.deliveryVehicleMarkerCustomization =
  (params) => {
    if (params.isNew) {
      params.marker.setVisible(false);
    }
  };

TypeScript

// Specify the customization function either separately, or as a field in
// the options for the delivery vehicle location provider constructor.
deliveryVehicleLocationProvider.deliveryVehicleMarkerCustomization =
  (params: deliveryVehicleMarkerCustomizationFunctionParams) => {
    if (params.isNew) {
      params.marker.setVisible(false);
    }
  };

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