कैमरा अडजस्ट करें

कैमरा का इस्तेमाल करके, मैप पर उपयोगकर्ता के व्यूपॉइंट को बदला जा सकता है. नेविगेशन के दौरान मैप के व्यवहार को कंट्रोल करने के लिए, कैमरे के मोड का इस्तेमाल किया जा सकता है. कैमरा मोड सेट करने के लिए, मैप व्यू की 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;

मैप को अपने-आप बीच में लाना

जब उपयोगकर्ता नेविगेशन मोड में मैप को घुमाते हैं, तो मैप व्यू के लिए कैमरा मोड, फ़ॉलो मोड से फ़्री मोड में बदल जाता है. जब उपयोगकर्ता फिर से बीच में लाएं को दबाता है, तो कैमरा फ़ॉलोिंग मोड पर वापस आ जाता है. टाइमर का इस्तेमाल करके, फ़ॉलो मोड से बाहर निकलने और फिर अपने-आप उसमें वापस आने के बीच का इंटरवल सेट किया जा सकता है.

उदाहरण

नीचे दिए गए कोड के उदाहरण से यह पता चलता है कि नेविगेशन मोड में उपयोगकर्ता, मैप को मूव कर रहा है या नहीं. अगर ऐसा है, तो यह कैमरा मोड को फ़ॉलो मोड पर स्विच करने के लिए एक टाइमर सेट करता है. साथ ही, पांच सेकंड के बाद मैप को बीच में दिखाता है.

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