Ajustar a câmera

A câmera permite mudar o ponto de vista do usuário do mapa. Você pode usar os modos de câmera para controlar o comportamento do mapa durante a navegação. Para configurar o modo da câmera, defina a propriedade cameraMode da visualização de mapa, especificando uma das seguintes constantes do modo:

  • Seguindo: o modo de câmera padrão para navegação. Muda o ângulo de visualização para 45 graus e coloca a câmera atrás da posição atual, voltada na direção da viagem. Durante a navegação, a câmera se ajusta automaticamente para o rosto na direção da viagem. Pressionar o botão Recentralizar do mapa muda para esse modo. O botão Re-center não fica visível quando esse modo está selecionado.

  • Visão geral: mostra uma visão geral de todo o trajeto, aumentando o zoom conforme necessário para ajustá-lo à visualização de mapa. Quando essa visualização é selecionada, o botão Recentralizar fica visível.

  • Livre: permite que o usuário altere a visualização do mapa com gestos. A câmera permanece parada nessa visualização. O mapa entrará automaticamente nessa visualização se o usuário movimentar ou aplicar zoom durante a navegação. Quando essa visualização é selecionada, o botão Re-center fica visível.

Para mudar o modo da câmera, defina a propriedade cameraMode da visualização de mapa, como mostrado aqui:

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;

Recentralizar o mapa automaticamente

Quando os usuários movem o mapa no modo de navegação, o modo de câmera da visualização de mapa muda do modo de acompanhamento para o modo livre. A câmera retorna ao modo a seguir quando o usuário pressiona Recentralizar explicitamente. É possível automatizar o retorno ao modo seguinte usando um timer para definir um intervalo entre sair e retornar automaticamente a ele.

Exemplo

O exemplo de código a seguir verifica se o mapa está sendo movido pelo usuário no modo de navegação. Se estiver, ele define um timer para mudar o modo da câmera para o modo seguinte, centralizando o mapa após cinco segundos.

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