Dostosowywanie kamery

Kamera umożliwia zmianę punktu widzenia użytkownika na mapie. Tryby kamery umożliwiają kontrolowanie działania mapy podczas nawigacji. Aby ustawić tryb kamery, ustaw właściwość cameraMode widoku mapy, podając jedną z tych stałych wartości trybu kamery:

  • Śledzenie – domyślny tryb kamery do nawigacji. Zmienia kąt widzenia na 45 stopni i ustawia kamerę za aktualną pozycją, zwróconą w kierunku jazdy. Podczas nawigacji aparat automatycznie dostosowuje się do kierunku jazdy. W tym trybie możesz też przejść, naciskając przycisk Wyśrodkuj na mapie. Po wybraniu tego trybu przycisk Wyśrodkuj jest niewidoczny.

  • Ogólny – wyświetla ogólny widok całej trasy, przybliżając ją w razie potrzeby, aby zmieściła się na mapie. Po wybraniu tego widoku widoczny jest przycisk Wyśrodkuj.

  • Wolny – umożliwia użytkownikowi zmianę widoku mapy za pomocą gestyk. W tym widoku kamera pozostaje nieruchoma. Jeśli użytkownik przewinie mapę lub ją powiększy podczas nawigacji, automatycznie przełączy się ona na ten widok. Po wybraniu tego widoku widoczny jest przycisk Przenieś do środka.

Aby zmienić tryb kamery, ustaw właściwość cameraMode widoku mapy, jak pokazano poniżej:

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

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

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

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

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

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

Automatyczne wyśrodkowywanie mapy

Gdy użytkownicy przesuwają mapę w trybie nawigacji, tryb kamery mapy zmienia się z podążania na tryb swobodny. Kamera wraca do tego trybu, gdy użytkownik naciśnie Wyśrodkuj. Możesz zautomatyzować powrót do trybu śledzenia, używając timera do ustawienia przerwy między opuszczeniem trybu śledzenia a jego automatycznym włączeniem.

Przykład

Podany niżej przykład kodu sprawdza, czy użytkownik przesuwa mapę w trybie nawigacji. Jeśli tak, ustawia minutnik, aby przełączyć tryb kamery na tryb śledzenia, a po 5 sekundach wyśrodkowuje mapę.

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
  }
}

@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