Điều khiển và cử chỉ

Chọn nền tảng: Android iOS JavaScript

Khi sử dụng SDK Maps dành cho iOS, bạn có thể tuỳ chỉnh cách người dùng tương tác với bản đồ, bằng cách xác định thành phần giao diện người dùng tích hợp nào xuất hiện trên bản đồ và cử chỉ nào được cho phép.

Bảng điều khiển bản đồ

SDK bản đồ dành cho iOS cung cấp một số điều khiển giao diện người dùng tích hợp tương tự như các điều khiển có trong ứng dụng Google Maps dành cho iOS. Bạn có thể bật/tắt chế độ hiển thị của các chế độ điều khiển này bằng cách sử dụng lớp GMSUISettings. Những thay đổi đối với lớp này sẽ được phản ánh ngay lập tức trên bản đồ.

La bàn

SDK Maps dành cho iOS cung cấp đồ hoạ la bàn xuất hiện ở góc trên bên phải bản đồ trong một số trường hợp nhất định. La bàn sẽ chỉ xuất hiện khi máy ảnh được định hướng sao cho có góc phương vị khác 0. Khi người dùng nhấp vào la bàn, máy ảnh sẽ chuyển động trở lại vị trí có phương hướng bằng 0 (hướng mặc định) và la bàn biến mất ngay sau đó.

Theo mặc định, la bàn bị tắt. Bạn có thể bật la bàn bằng cách đặt thuộc tính compassButton của GMSUISettings thành YES. Tuy nhiên, bạn không thể buộc la bàn luôn hiển thị.

Swift

let camera = GMSCameraPosition(latitude: 37.757815, longitude: -122.50764, zoom: 12)
let mapView = GMSMapView(frame: .zero, camera: camera)
mapView.settings.compassButton = true
      

Objective-C

GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:37.757815
                                                        longitude:-122.50764
                                                             zoom:12];
GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera];
mapView.settings.compassButton = YES;
      

Nút Vị trí của tôi

Nút Vị trí của tôi xuất hiện ở góc dưới bên phải màn hình chỉ khi nút Vị trí của tôi được bật. Khi người dùng nhấp vào nút đó, máy ảnh sẽ tạo ảnh động để tập trung vào vị trí hiện tại của người dùng nếu vị trí của người dùng hiện đã biết. Bạn có thể bật nút này bằng cách đặt thuộc tính myLocationButton của GMSUISettings thành YES.

Swift

mapView.settings.myLocationButton = true
      

Objective-C

mapView.settings.myLocationButton = YES;
      

Bộ chọn sàn

Nút điều khiển bộ chọn tầng xuất hiện gần phía dưới cùng bên phải màn hình bất cứ khi nào bản đồ trong nhà xuất hiện nổi bật. Khi có hai hoặc nhiều sơ đồ trong nhà hiển thị, bộ chọn sàn sẽ liên quan đến toà nhà gần giữa màn hình nhất. Mỗi toà nhà có một tầng mặc định được chọn khi bộ chọn xuất hiện lần đầu tiên. Bạn có thể chọn một tầng khác bằng cách chọn trong bộ chọn.

Bạn có thể tắt tính năng kiểm soát bộ chọn sàn bằng cách đặt thuộc tính indoorPicker của GMSUISettings thành NO.

Swift

mapView.settings.indoorPicker = false
      

Objective-C

mapView.settings.indoorPicker = NO;
      

Cử chỉ ánh xạ

Bạn có thể tắt các cử chỉ mặc định trên bản đồ bằng cách đặt các thuộc tính của lớp GMSUISettings (có sẵn dưới dạng thuộc tính của GMSMapView). Bạn có thể bật và tắt các cử chỉ sau theo phương thức lập trình. Lưu ý rằng việc tắt cử chỉ sẽ không giới hạn quyền truy cập có lập trình vào các chế độ cài đặt máy ảnh.

  • scrollGestures – kiểm soát việc bật hay tắt các cử chỉ cuộn. Nếu chế độ này được bật, người dùng có thể vuốt để lia máy ảnh.
  • zoomGestures – kiểm soát việc bật hay tắt các cử chỉ thu phóng. Nếu được bật, người dùng có thể nhấn đúp, nhấn bằng 2 ngón tay hoặc chụm để thu phóng máy ảnh. Lưu ý rằng thao tác nhấn đúp hoặc chụm khi scrollGestures đang bật có thể xoay máy ảnh đến điểm đã chỉ định.
  • tiltGestures – kiểm soát việc bật hay tắt cử chỉ nghiêng. Nếu được bật, người dùng có thể sử dụng thao tác vuốt xuống hoặc vuốt lên bằng hai ngón tay để nghiêng máy ảnh.
  • rotateGestures – kiểm soát việc bật hay tắt các cử chỉ xoay. Nếu được bật, người dùng có thể sử dụng cử chỉ xoay bằng hai ngón tay để xoay máy ảnh.

Trong ví dụ bên dưới, cả cử chỉ kéo và thu phóng đều bị tắt.

Swift

override func loadView() {
  let camera = GMSCameraPosition.camera(
    withLatitude: 1.285,
    longitude: 103.848,
    zoom: 12
  )

  let mapView = GMSMapView.map(withFrame: .zero, camera: camera)
  mapView.settings.scrollGestures = false
  mapView.settings.zoomGestures = false
  self.view = mapView
}
      

Objective-C

- (void)loadView {
  GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:1.285
                                                          longitude:103.848
                                                               zoom:12];
  GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera];
  mapView.settings.scrollGestures = NO;
  mapView.settings.zoomGestures = NO;
  self.view = mapView;
}