调整摄像头

借助摄像头,您可以更改用户查看地图的视角。您可以使用相机模式来控制导航期间地图的行为。如需设置相机模式,请设置地图视图的 cameraMode 属性,并指定以下某个相机模式常量:

  • 跟随 - 导航的默认摄像头模式。将视图角度更改为 45 度,并将相机放置在当前位置后方,朝向行进方向。在导航期间,摄像头会自动调整为朝向行驶方向。按地图的重新居中按钮也会切换到此模式。选择此模式后,系统不会显示重新居中按钮。

  • 概览 - 显示整个路线的概览,并根据需要缩放以使路线适合地图视图。选择此视图后,系统会显示重新居中按钮。

  • 自由 - 允许用户使用手势更改地图视图。在此视图中,摄像头会保持静止。如果用户在导航期间平移或缩放地图,地图将自动进入此视图。选择此视图后,系统会显示重新居中按钮。

如需更改相机模式,请设置地图视图的 cameraMode 属性,如下所示:

Swift

// Set the mode to "overview":
mapView.cameraMode = .overview

// Set the mode to "free":
mapView.cameraMode = .free

// Set the mode to "following":
mapView.cameraMode = .following

Objective-C

// Set the mode to "overview":
mapView.cameraMode = GMSNavigationCameraModeOverview;

// Set the mode to "free":
mapView.cameraMode = GMSNavigationCameraModeFree;

// Set the mode to "following":
mapView.cameraMode = GMSNavigationCameraModeFollowing;

自动将当前位置设为地图的中心

当用户在导航模式下移动地图时,地图视图的相机模式会从跟随模式更改为自由模式。当用户明确按下重新居中时,摄像头会返回跟随模式。您可以使用计时器设置退出跟踪模式和自动返回跟踪模式之间的间隔时间,以自动返回跟踪模式。

示例

以下代码示例用于检查确定地图在导航模式下是否由用户移动。如果是,则会设置一个计时器,以将相机模式切换为跟随模式,并在 5 秒后将地图居中。

Swift

class YourViewController: UIViewController {

  @IBOutlet weak var mapView: GMSMapView!
  var autoFollowTimer: Timer!

  override func viewDidLoad() {
    super.viewDidLoad()
    mapView.delegate = self
    ...
  }

  ...
}

/** Implements the GMSMapViewDelegate protocol. */
extension YourViewController: GMSMapViewDelegate {
  func mapView(_ mapView: GMSMapView, willMove gesture: Bool) {
    if mapView.navigator?.isGuidanceActive == false {return}
    if !gesture {return}

    autoFollowTimer?.invalidate()
    autoFollowTimer = Timer(
      timeInterval: TimeInterval(5.0),
      target: self,
      selector: #selector(recenterMap),
      userInfo: nil,
      repeats: false)
    RunLoop.current.add(autoFollowTimer, forMode: .default)
  }

  /** Centers the map in guidance mode. */
  @objc private func recenterMap() {
    if mapView.navigator?.isGuidanceActive == true {
       mapView.cameraMode = .following
    }

    autoFollowTimer.invalidate()
    autoFollowTimer = nil
  }
}

Objective-C

@interface YourViewController : UIViewController<GMSMapViewDelegate>
...
@end


@implementation YourViewController {
  GMSMapView *_mapView;
  NSTimer *_autoFollowTimer;
  ...
}

...

- (void)viewDidLoad {
  [super viewDidLoad];
  ...
  _mapView.delegate = self;
  ...
}

...

/** Implements the GMSMapViewDelegate protocol. */
- (void)mapView:(GMSMapView *)mapView willMove:(BOOL)gesture {
  if (!_mapView.navigator.guidanceActive) return;
  if (!gesture) return;

  [_autoFollowTimer invalidate];
  _autoFollowTimer = [NSTimer scheduledTimerWithTimeInterval:5.0
                                                      target:self
                                                    selector:@selector(recenterMap)
                                                    userInfo:nil
                                                     repeats:NO];
}

/** Centers the map in guidance mode. */
- (void)recenterMap {
  if (_mapView.navigator.guidanceActive) {
    _mapView.cameraMode = GMSNavigationCameraModeFollowing;
  }

  [_autoFollowTimer invalidate];
  _autoFollowTimer = nil;
}

@end