ปรับกล้อง

กล้องช่วยให้คุณเปลี่ยนมุมมองแผนที่ของผู้ใช้ได้ คุณสามารถใช้โหมดกล้องเพื่อควบคุมลักษณะการทำงานของแผนที่ระหว่างการนำทางได้ หากต้องการตั้งค่าโหมดกล้อง ให้ตั้งค่าพร็อพเพอร์ตี้ 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