الحصول على معلومات المسار

اتبع هذا الدليل لإعداد تطبيقك لاسترداد الأوقات والمسافات وأرجل المسار للمسار الحالي.

نظرة عامة

للحصول على معلومات حول المسار الحالي، احصل على السمة المناسبة من مثيل navigator:

الاطّلاع على الرمز

الحصول على الوقت للوجهة التالية

لمعرفة الوقت للوصول إلى الوجهة التالية، اتصل بالرقم timeToNextDestination(). ويكون ناتج هذه العملية قيمة NSTimeInterval. يوضح المثال التالي تسجيل الوقت إلى الوجهة التالية:

Swift

if let navigator = mapView.navigator {
  let time = navigator.timeToNextDestination
  let minutes = floor(time/60)
  let seconds = round(time - minutes * 60)
  NSLog("Time to next destination: %.0f:%.0f", minutes, seconds)
}

Objective-C

NSTimeInterval time = _mapView.navigator.timeToNextDestination;
int minutes = floor(time/60);
int seconds = round(time - minutes * 60);
NSLog(@"%@", [NSString stringWithFormat:@"Time to next destination: %i:%i.", minutes, seconds]);

جارٍ الحصول على المسافة إلى الوجهة التالية

لمعرفة المسافة إلى الوجهة التالية، اتصل بالرقم distanceToNextDestination(). ويكون ناتج هذه العملية قيمة CLLocationDistance. يتم تحديد الوحدات بالمتر.

Swift

if let navigator = mapView.navigator {
  let distance = navigator.distanceToNextDestination
  let miles = distance * 0.00062137
  NSLog("Distance to next destination: %.2f miles.", miles)
}

Objective-C

CLLocationDistance distance = _mapView.navigator.distanceToNextDestination;
double miles = distance * 0.00062137;
NSLog(@"%@", [NSString stringWithFormat:@"Distance to next destination: %.2f.", miles]);

جارٍ الحصول على أحوال حركة المرور إلى الوجهة التالية

للحصول على قيمة تشير إلى تدفق حركة المرور إلى الوجهة التالية، اطلب delayCategoryToNextDestination. تعرض هذه المَعلمة GMSNavigationDelayCategory. يوضّح المثال التالي تقييم النتيجة وتسجيل رسالة بشأن الزيارات:

Swift

if let navigator = mapView.navigator {
  // insert sample for evaluating traffic value
  let delay = navigator.delayCategoryToNextDestination
  let traffic = "unavailable"
  switch delay {
    case .noData:
      traffic = "unavailable"
    case .heavy:
      traffic = "heavy"
    case .medium:
      traffic = "moderate"
    case .light:
      traffic = "light"
    default:
      traffic = "unavailable"
  }
  print("Traffic is \(traffic).")
}

Objective-C

GMSNavigationDelayCategory delay = mapView.navigator.delayCategoryToNextDestination;
NSString *traffic = @"";

switch (delayCategory) {
    case GMSNavigationDelayCategoryNoData:
      traffic = @"No Data";
      break;
    case GMSNavigationDelayCategoryHeavy:
      traffic = @"Heavy";
      break;
    case GMSNavigationDelayCategoryMedium:
      traffic = @"Medium";
      break;
    case GMSNavigationDelayCategoryLight:
      traffic = @"Light";
      break;
    default:
      NSLog(@"Invalid delay category: %zd", delayCategory);
 }

NSLog(@"%@", [NSString stringWithFormat:@"Traffic is %@.", traffic]);

الحصول على معلومات حول الساق الحالية

للحصول على معلومات عن مرحلة المسار الحالية، اتصل بالرقم currentRouteLeg. يعرض هذا مثيل GMSRouteLeg، يمكنك من خلاله الحصول على:

  • تمثّل هذه السمة وجهة الساق.
  • الإحداثيات النهائية في الساق.
  • المسار الذي يحتوي على الإحداثيات التي تشكل ساق المسار.

يوضح المثال التالي تسجيل العنوان وإحداثيات خطوط الطول والعرض لمرحلة المسار التالية:

Swift

if let navigator = mapView.navigator {
  let currentLeg = navigator.currentRouteLeg
  let nextDestination = currentLeg?.destinationWaypoint?.title
  let lat = currentLeg?.destinationCoordinate.latitude.description
  let lng = currentLeg?.destinationCoordinate.longitude.description
  NSLog(nextDestination! + ", " + lat! + "/" + lng!)
}

Objective-C

GMSRouteLeg *currentSegment = _mapView.navigator.currentRouteLeg;
NSString *nextDestination = currentSegment.destinationWaypoint.title;
CLLocationDegrees lat = currentSegment.destinationCoordinate.latitude;
CLLocationDegrees lng = currentSegment.destinationCoordinate.longitude;
NSLog(@"%@", [NSString stringWithFormat:@"%@, %f/%f", nextDestination, lat, lng]);

الحصول على أحدث مسار تم الانتقال إليه

للحصول على آخر مسار تم قطعه، اتصل بالرقم traveledPath. يؤدي ذلك إلى عرض مثيل GMSPath الذي تم تبسيطه لإزالة النقاط المكرّرة (مثلاً، تحويل النقاط الخطية المتتالية إلى جزء مستقيم واحد). سيكون هذا المسار فارغًا حتى تبدأ التوجيه. يوضح المثال التالي الحصول على أحدث مسار تم قطعه:

Swift

if let navigator = mapView.navigator {
  let latestPath = navigator.traveledPath
  if latestPath.count() > 0 {
    let begin: CLLocationCoordinate2D = latestPath.coordinate(at: 0)
    let current: CLLocationCoordinate2D = latestPath.coordinate(at: latestPath.count() - 1)
    print("Path from (\(begin.latitude),\(begin.longitude)) to (\(current.latitude),\(current.longitude))")
  }
}

Objective-C

GMSPath *latestPath = mapView.navigator.traveledPath;
if (latestPath.count > 0) {
  CLLocationCoordinate2D begin = [latestPath coordinateAtIndex:0];
  CLLocationCoordinate2D current = [latestPath coordinateAtIndex:latestPath.count - 1];
  NSLog(@"Path from %f/%f to %f/%f",
        begin.latitude,
        begin.longitude,
        current.latitude,
        current.longitude);
}