Nghe sự kiện điều hướng

Hãy sử dụng hướng dẫn này để cho phép ứng dụng của bạn nghe và phản hồi nhiều sự kiện thay đổi khi người dùng di chuyển dọc theo một tuyến đường. Hướng dẫn này không đề cập đến việc xác định tuyến đường, chỉ phản hồi các sự kiện dọc theo tuyến đường.

Tổng quan

Navigation SDK cho iOS cung cấp cho bạn trình nghe liên kết với vị trí của người dùng và các điều kiện dọc theo tuyến đường, cũng như dữ liệu quan trọng về thời gian và khoảng cách. Trên trình điều khiển thành phần hiển thị của bản đồ, ứng dụng của bạn cần sử dụng các giao thức cho các trình nghe này: GMSRoadSnappedLocationProviderListenerGMSNavigatorListener.

Danh sách này cho thấy các phương thức trình nghe có sẵn cho các sự kiện điều hướng:

Xem mã

Khai báo tuân thủ các giao thức bắt buộc

Trước khi triển khai các phương thức điều hướng, trình điều khiển thành phần hiển thị phải sử dụng các giao thức sau:

Swift

class ViewController: UIViewController, GMSNavigatorListener,
GMSRoadSnappedLocationProviderListener {

Objective-C

@interface ViewController () <GMSNavigatorListener,
GMSRoadSnappedLocationProviderListener>

@end

Sau khi áp dụng các giao thức điều hướng, hãy đặt trình nghe thành trình điều khiển chế độ xem. Ví dụ: bạn có thể thêm mã sau vào phương thức viewDidLoad().

Swift

mapView.navigator?.add(self) mapView.roadSnappedLocationProvider?.add(self)

Objective-C

[_mapView.navigator addListener:self]; [_mapView.roadSnappedLocationProvider
addListener:self];

Nhận hoặc dừng thông tin cập nhật vị trí

Bạn cần cập nhật thông tin vị trí để hiển thị tiến trình của người dùng trên bản đồ.

Phiên bản location hiển thị các thuộc tính sau:

Thuộc tính vị trí Mô tả
độ cao Độ cao hiện tại.
coordinate.latitude Toạ độ vĩ độ hiện tại được chụp nhanh trên đường.
coordinate.longitude Toạ độ theo kinh độ hiện tại được chụp nhanh trên đường.
khoá học Vị trí hiện tại tính bằng độ.
tốc độ Tốc độ hiện tại.
dấu thời gian Ngày/giờ đọc hiện tại.

Để nhận thông tin cập nhật liên tục về vị trí, hãy gọi mapView.roadSnappedLocationProvider.startUpdatingLocation và sử dụng GMSRoadSnappedLocationProviderListener để xử lý sự kiện didUpdateLocation.

Ví dụ sau đây cho thấy cách gọi startUpdatingLocation:

Swift

mapView.roadSnappedLocationProvider.startUpdatingLocation()

Objective-C

[_mapView.roadSnappedLocationProvider startUpdatingLocation];

Mã sau đây tạo một GMSRoadSnappedLocationProviderListener để xử lý sự kiện didUpdateLocation.

Swift

func locationProvider(_ locationProvider: GMSRoadSnappedLocationProvider,
didUpdate location: CLLocation) { print("Location: \(location.description)") }

Objective-C

-   (void)locationProvider:(GMSRoadSnappedLocationProvider *)locationProvider
    didUpdateLocation:(CLLocation *)location { NSLog(@"Location: %@",
    location.description); }

Để nhận thông tin cập nhật vị trí khi ứng dụng đang chạy ở chế độ nền, hãy đặt allowsBackgroundLocationUpdates thành true:

Swift

mapView.roadSnappedLocationProvider.allowsBackgroundLocationUpdates = true

Objective-C

 _mapView.roadSnappedLocationProvider.allowsBackgroundLocationUpdates = YES;

Phát hiện sự kiện đến

Ứng dụng của bạn sử dụng sự kiện didArriveAtWaypoint để phát hiện thời điểm đạt đến một đích đến. Bạn có thể tiếp tục chỉ dẫn và chuyển đến điểm trung gian tiếp theo bằng cách gọi continueToNextDestination(), sau đó bật lại chỉ dẫn. Ứng dụng của bạn phải bật lại hướng dẫn sau khi gọi continueToNextDestination().

Sau khi ứng dụng gọi continueToNextDestination, trình điều hướng sẽ không còn dữ liệu về đích đến trước đó. Nếu muốn phân tích thông tin về một chặng đường, bạn phải truy xuất thông tin này từ trình điều hướng trước khi gọi continueToNextDestination().

Ví dụ về mã sau đây cho thấy một phương thức để xử lý sự kiện didArriveAtWaypoint:

Swift

func navigator(_ navigator: GMSNavigator, didArriveAt waypoint:
GMSNavigationWaypoint) { print("You have arrived at: \(waypoint.title)")
mapView.navigator?.continueToNextDestination()
mapView.navigator?.isGuidanceActive = true }

Objective-C

-   (void)navigator:(GMSNavigator *)navigator
    didArriveAtWaypoint:(GMSNavigationWaypoint *)waypoint { NSLog(@"You have
    arrived at: %@", waypoint.title); [_mapView.navigator
    continueToNextDestination]; _mapView.navigator.guidanceActive = YES; }

Nhận thông tin cập nhật về thay đổi tuyến đường

Để nhận thông báo mỗi khi tuyến đường thay đổi, hãy tạo một phương thức để xử lý sự kiện navigatorDidChangeRoute. Bạn có thể truy cập vào tuyến mới bằng cách sử dụng thuộc tính routeLegscurrentRouteLeg của GMSNavigator.

Swift

func navigatorDidChangeRoute(_ navigator: GMSNavigator) { print("The route has
changed.") }

Objective-C

-   (void)navigatorDidChangeRoute:(GMSNavigator *)navigator { NSLog(@"The route
    has changed."); }

Thời gian nhận thông tin cập nhật về đích đến

Để nhận thông tin cập nhật liên tục về thời gian đến đích, hãy tạo một phương thức để xử lý sự kiện didUpdateRemainingTime. Tham số time cung cấp thời gian dự kiến (tính bằng giây) cho đến khi đến đích tiếp theo.

Swift

func navigator(_ navigator: GMSNavigator, didUpdateRemainingTime time:
TimeInterval) { print("Time to next destination: \(time)") }

Objective-C

-   (void)navigator:(GMSNavigator *)navigator
    didUpdateRemainingTime:(NSTimeInterval)time { NSLog(@"Time to next
    destination: %f", time); }

Để đặt mức thay đổi tối thiểu về thời gian dự kiến đến điểm đến tiếp theo, hãy đặt thuộc tính timeUpdateThreshold trên GMSNavigator. Giá trị được chỉ định bằng giây. Nếu bạn không đặt thuộc tính này, các dịch vụ sẽ sử dụng giá trị mặc định là một giây.

Swift

navigator?.timeUpdateThreshold = 10

Objective-C

navigator.timeUpdateThreshold = 10;

Nhận thông tin cập nhật về khoảng cách đến đích

Để nhận thông tin cập nhật liên tục về khoảng cách đến đích, hãy tạo một phương thức để xử lý sự kiện didUpdateRemainingDistance. Tham số distance cung cấp khoảng cách ước tính (tính bằng mét) đến đích tiếp theo.

Swift

func navigator(_ navigator: GMSNavigator, didUpdateRemainingDistance distance:
CLLocationDistance) { let miles = distance * 0.00062137 print("Distance to next
destination: \(miles) miles.") }

Objective-C

-   (void)navigator:(GMSNavigator *)navigator
    didUpdateRemainingDistance:(CLLocationDistance)distance { double miles =
    distance * 0.00062137; NSLog(@"%@", [NSString stringWithFormat:@"Distance to
    next destination: %.2f.", miles]); }

Để đặt mức thay đổi tối thiểu trong khoảng cách ước tính đến đích tiếp theo, hãy đặt thuộc tính distanceUpdateThreshold trên GMSNavigator (giá trị được chỉ định bằng mét). Nếu bạn không đặt thuộc tính này, các dịch vụ sẽ sử dụng giá trị mặc định là một mét.

Swift

navigator?.distanceUpdateThreshold = 100

Objective-C

navigator.distanceUpdateThreshold = 100;

Nhận thông tin cập nhật về lưu lượng truy cập

Để nhận thông tin cập nhật liên tục về lưu lượng truy cập cho tuyến còn lại, hãy tạo một phương thức để xử lý sự kiện didUpdateDelayCategory. Lệnh gọi đến delayCategoryToNextDestination sẽ trả về GMSNavigationDelayCategory, cung cấp giá trị từ 0 đến 3. Nội dung cập nhật cho danh mục này dựa trên vị trí hiện tại của người dùng ứng dụng. Nếu không có dữ liệu lưu lượng truy cập, GMSNavigationDelayCategory sẽ trả về 0. Các con số từ 1 đến 3 cho biết lưu lượng tăng dần từ ít đến nhiều.

Swift

func navigator(_ navigator: GMSNavigator, didUpdate delayCategory:
GMSNavigationDelayCategory) { print("Traffic flow to next destination:
\(delayCategory)") }

Objective-C

-   (void)navigator:(GMSNavigator *)navigator
    didUpdateDelayCategory:(GMSNavigationDelayCategory)delayCategory {
    NSLog(@"Traffic flow to next destination: %ld", (long)delayCategory); }

Thuộc tính GMSNavigationDelayCategory hiển thị các mức độ trễ sau:

Danh mục độ trễ Mô tả
GMSNavigationDelayCategoryNoData 0 – Không có sẵn, không có dữ liệu về lưu lượng truy cập hoặc :
tuyến đường.
GMSNavigationDelayCategoryHeavy 1 – Nặng.
GMSNavigationDelayCategoryMedium 2 – Trung bình.
GMSNavigationDelayCategoryLight 3 – Ánh sáng.

Nhận thông tin cập nhật về tốc độ

Để nhận thông tin cập nhật khi người lái xe vượt quá giới hạn tốc độ, hãy tạo một phương thức để xử lý sự kiện didUpdateSpeedingPercentage.

Swift

// Listener to handle speeding events. func navigator( _ navigator:
GMSNavigator, didUpdateSpeedingPercentage percentageAboveLimit: CGFloat ) {
print("Speed is \(percentageAboveLimit) above the limit.") }

Objective-C

// Listener to handle speeding events. - (void)navigator:(GMSNavigator
*)navigator didUpdateSpeedingPercentage:(CGFloat)percentageAboveLimit {
NSLog(@"Speed is %f percent above the limit.", percentageAboveLimit); }

Thay đổi chế độ chiếu sáng được đề xuất

Để nhận thông tin cập nhật về những thay đổi ước tính về ánh sáng, hãy tạo một phương thức để xử lý sự kiện didChangeSuggestedLightingMode.

Swift

// Define a listener for suggested changes to lighting mode. func navigator(_
navigator: GMSNavigator, didChangeSuggestedLightingMode lightingMode:
GMSNavigationLightingMode) { print("Suggested lighting mode has changed:
\(String(describing: lightingMode))")

 // Make the suggested change. mapView.lightingMode = lightingMode }

Objective-C

// Define a listener for suggested changes to lighting mode.
-(void)navigator:(GMSNavigator *)navigator didChangeSuggestedLightingMode:
(GMSNavigationLightingMode)lightingMode { NSLog(@"Suggested lighting mode has
changed: %ld", (long)lightingMode);

 // Make the suggested change. _mapView.lightingMode = lightingMode; }