
Chế độ xem đường phố của Google Maps cho phép bạn khám phá các địa điểm trên khắp thế giới thông qua hình ảnh 360 độ ở cấp đường phố. Bạn có thể khám phá các địa danh trên thế giới, xem các kỳ quan thiên nhiên, lên kế hoạch cho một chuyến đi hoặc cho thấy bên ngoài doanh nghiệp của bạn.
Tổng quan
Chế độ xem phố của Google cung cấp chế độ xem toàn cảnh 360 độ từ các con đường được chỉ định trong khu vực phủ sóng. Phạm vi phủ sóng có sẵn
thông qua SDK cũng giống như phạm vi phủ sóng của ứng dụng Google Maps dành cho iOS hoặc
https://maps.google.com/. Bạn
có thể đọc thêm về Chế độ xem phố và xem các khu vực được hỗ trợ
trên bản đồ tương tác tại bài viết Giới thiệu về Chế độ xem phố
.
SDK Bản đồ dành cho iOS cung cấp dịch vụ Chế độ xem đường phố để thu thập và thao tác với hình ảnh được dùng trong Chế độ xem đường phố của Google Maps. Hình ảnh trong Chế độ xem đường phố
được trả về dưới dạng ảnh toàn cảnh và được xem trong
trình xem Chế độ xem đường phố – một đối tượng thuộc loại
GMSPanoramaView.
Ảnh toàn cảnh trong Chế độ xem phố
Mỗi ảnh toàn cảnh trong Chế độ xem đường phố là một hình ảnh hoặc tập hợp hình ảnh cung cấp chế độ xem 360 độ đầy đủ từ một vị trí. Hình ảnh tuân theo phép chiếu hình chữ nhật đều (Plate Carrée), chứa 360 độ chế độ xem ngang (bao trọn) và 180 độ chế độ xem dọc (từ trên xuống dưới). Ảnh toàn cảnh 360 độ kết quả xác định phép chiếu trên một hình cầu có hình ảnh được bao bọc vào bề mặt hai chiều của hình cầu đó.
Bạn có thể xem ảnh toàn cảnh trong Chế độ xem phố bằng đối tượng GMSPanoramaView. Đối tượng này cung cấp một trình xem sẽ kết xuất ảnh toàn cảnh dưới dạng hình cầu, với một camera ở trung tâm. Bạn có thể kiểm soát hướng của camera theo phương thức lập trình, cũng như một số thuộc tính tuỳ chỉnh trình xem.
Truy cập vào dữ liệu Chế độ xem đường phố
Ảnh toàn cảnh trong Chế độ xem phố được xác định bằng một trong hai phần siêu dữ liệu sau:
panoramaID- Mã nhận dạng duy nhất của Ảnh toàn cảnh trong Chế độ xem đường phố. This
panoramaIDcó thể thay đổi theo thời gian và không phù hợp làm tài liệu tham khảo dài hạn hoặc được mã hoá cứng, reference. Bạn nên sử dụngpanoramaIDđể cung cấp quyền truy cập theo phương thức lập trình vào các hình ảnh khác nhau trong Chế độ xem phố. coordinate- Vị trí chính xác của hình ảnh này, được biểu thị dưới dạng
CLLocationCoordinate2D. Sử dụngcoordinateđể lưu trữ vĩnh viễn vị trí của ảnh toàn cảnh hoặc để chuyển đổi hành động của người dùng trên bản đồ thành hình ảnh trong Chế độ xem phố.
Cả panoramaID và coordinate đều được lưu trữ dưới dạng thuộc tính của đối tượng GMSPanorama. Bạn có thể yêu cầu GMSPanorama từ
GMSPanoramaService bằng cách sử dụng coordinate hoặc panoramaID. Đối tượng kết quả sẽ bao gồm cả hai phần siêu dữ liệu, cũng như một mảng các đường liên kết đến ảnh toàn cảnh ở gần đó.
Đặt vị trí của ảnh toàn cảnh
Bạn có thể đặt vị trí của ảnh toàn cảnh trong Chế độ xem đường phố dựa trên toạ độ.
Phương thức
moveNearCoordinateyêu cầu ảnh toàn cảnh ở gần toạ độ.Phương thức
moveNearCoordinate:radiustương tự, nhưng cho phép bạn chỉ định bán kính tìm kiếm (tính bằng mét) xung quanh toạ độ.Phương thức
moveNearCoordinate:sourcecho phép bạn chỉ định một nguồn. Nguồn rất hữu ích nếu bạn chỉ muốn Chế độ xem đường phố tìm ảnh toàn cảnh ở bên ngoài. Theo mặc định, ảnh toàn cảnh của các vị trí ở bên trong hoặc bên ngoài. Xin lưu ý rằng có thể không có ảnh toàn cảnh ở bên ngoài cho vị trí được chỉ định.Phương thức
moveNearCoordinate:radius:sourcecho phép bạn chỉ định cả bán kính và nguồn.
Xem hình ảnh trong Chế độ xem phố
Thêm trình xem Chế độ xem đường phố
Các bước cơ bản để thêm trình xem là:
- (Một lần) Làm theo các bước trong phần Bắt đầu để tải SDK, lấy khoá và thêm các khung cần thiết.
- Tạo hoặc cập nhật
ViewController. Nếu ảnh toàn cảnh sẽ xuất hiện khi bộ điều khiển chế độ xem này hiển thị, hãy nhớ tạo ảnh toàn cảnh trong phương thứcloadView. - Tạo và khởi tạo lớp
GMSPanoramaViewbằng phương thứcGMSPanoramaViewinitWithFrame:. Nếu bạn muốn sử dụng lớp này làm chế độ xem duy nhất của bộ điều khiển chế độ xem, thì bạn có thể sử dụngCGRectZerolàm khung của bản đồ – bản đồ sẽ tự động đổi kích thước. - Đặt đối tượng
GMSPanoramaViewlàm chế độ xem của bộ điều khiển chế độ xem. Ví dụ:self.view = panoView;. - Đặt vị trí của hình ảnh trong Chế độ xem phố bằng một phương thức như
moveNearCoordinate:.
Ví dụ bên dưới thêm trình xem Chế độ xem đường phố vào một ứng dụng.
Swift
import GoogleMaps class StreetView: UIViewController { override func loadView() { let panoView = GMSPanoramaView(frame: .zero) self.view = panoView panoView.moveNearCoordinate(CLLocationCoordinate2D(latitude: -33.732, longitude: 150.312)) } }
Objective-C
#import "StreetView.h" @import GoogleMaps; @interface StreetView () @end @implementation StreetView - (void)loadView { GMSPanoramaView *panoView = [[GMSPanoramaView alloc] initWithFrame:CGRectZero]; self.view = panoView; [panoView moveNearCoordinate:CLLocationCoordinate2DMake(-33.732, 150.312)]; } @end
Tuỳ chỉnh trình xem
Bạn có thể tuỳ chỉnh trình xem bằng cách hạn chế các cử chỉ có sẵn. Theo mặc định, tất cả các thao tác di chuyển, thu phóng và di chuyển đến ảnh toàn cảnh liền kề đều được bật.
Các cử chỉ riêng lẻ được kiểm soát thông qua các thuộc tính của GMSPanoramaView.
Các thuộc tính này bật hoặc tắt cử chỉ do người dùng kiểm soát; bạn vẫn có thể thay đổi theo phương thức lập trình khi cử chỉ bị tắt.
orientationGestures- Liệu người dùng có thể định hướng lại camera bằng cách nhấn hoặc
kéo hay không. Đặt thành
NOđể tắt các thay đổi về hướng đối với camera. zoomGestures- Liệu người dùng có thể chụm để thu phóng hay không. Đặt thành
NOđể tắt tính năng thu phóng. navigationGestures- Liệu người dùng có thể thay đổi ảnh toàn cảnh đang hiển thị hay không. Người dùng
có thể nhấn một lần vào các đường liên kết điều hướng hoặc nhấn đúp vào chế độ xem để thay đổi
ảnh toàn cảnh. Đặt thành
NOđể tắt các thay đổi về điều hướng.
Bạn có thể bật hoặc tắt tất cả các cử chỉ cùng một lúc bằng phương thức setAllGesturesEnabled:.
Swift
panoView.setAllGesturesEnabled(false)
Objective-C
[panoView setAllGesturesEnabled:NO];
Khởi chạy Chế độ xem đường phố bằng Lược đồ URL
Bạn có thể xem hình ảnh trong Chế độ xem đường phố của Google trong ứng dụng Google Maps dành cho iOS. Bạn có thể khởi chạy ứng dụng Google Maps dành cho iOS ở chế độ xem phố bằng Lược đồ URL comgooglemaps bằng cách đặt tham số mapmode thành streetview. Ví dụ về URL sẽ khởi chạy Chế độ xem đường phố xuất hiện bên dưới. Để biết thêm thông tin, hãy tham khảo tài liệu về Lược đồ URL.
comgooglemaps://?center=46.414382,10.013988&mapmode=streetview
Vị trí và điểm quan sát (POV) trong Chế độ xem phố
GMSPanoramaCamera cho phép bạn đặt điểm quan sát của camera trong Chế độ xem đường phố dưới dạng tổ hợp tiêu đề, độ nghiêng và mức thu phóng.
Đoạn mã bên dưới sẽ định hướng camera về phía nam và hơi xuống dưới.
Swift
panoView.camera = GMSPanoramaCamera(heading: 180, pitch: -10, zoom: 1)
Objective-C
panoView.camera = [GMSPanoramaCamera cameraWithHeading:180 pitch:-10 zoom:1];
Hướng
Vị trí trong Chế độ xem đường phố xác định vị trí tiêu điểm của camera cho một hình ảnh, nhưng không xác định hướng của camera cho hình ảnh đó.
Vì mục đích đó, đối tượng GMSOrientation xác định 2 thuộc tính:
headingxác định góc xoay quanh vị trí của camera theo độ tương đối so với hướng bắc thực. Tiêu đề được đo theo chiều kim đồng hồ: hướng bắc thực là 0, hướng đông là 90, hướng nam là 180, hướng tây là 270.pitch(mặc định là0) xác định phương sai góc "lên" hoặc "xuống" so với độ nghiêng mặc định ban đầu của camera, thường là (nhưng không phải lúc nào cũng) nằm ngang. (Ví dụ: hình ảnh được chụp trên một ngọn đồi có thể sẽ có độ nghiêng mặc định không nằm ngang.) Góc nghiêng được đo bằng các giá trị dương khi nhìn lên (tối đa là 90 độ thẳng lên và vuông góc với độ nghiêng mặc định) và các giá trị âm khi nhìn xuống (tối đa là -90 độ thẳng xuống và vuông góc với độ nghiêng mặc định).
Zoom (thu phóng)
Chế độ xem đường phố hỗ trợ nhiều mức độ chi tiết hình ảnh thông qua việc sử dụng tính năng thu phóng. Bạn có thể đặt mức thu phóng theo phương thức lập trình hoặc người dùng có thể thay đổi mức này trong trình xem bằng cách chụm để thu phóng.
Di chuyển camera
Sau khi tạo GMSPanoramaView và có camera đã định cấu hình hoặc camera mặc định, bạn có thể thay đổi camera theo một trong nhiều cách. Khi thay đổi camera, bạn có thể chọn tạo ảnh động cho chuyển động của camera kết quả. Ảnh động nội suy giữa các thuộc tính hiện tại của camera và các thuộc tính mới của camera.
Bạn có thể sửa đổi đối tượng GMSPanoramaCamera và đặt đối tượng này trên thuộc tính camera của GMSPanoramaView. Thao tác này sẽ chuyển camera sang điểm quan sát mới mà không có ảnh động. Bạn có thể tạo GMSCameraPosition để định cấu hình mọi tổ hợp hướng và mức thu phóng.
Swift
panoView.camera = GMSPanoramaCamera(heading: 180, pitch: -10, zoom: 1)
Objective-C
panoView.camera = [GMSPanoramaCamera cameraWithHeading:180 pitch:-10 zoom:1];
Bạn có thể tạo ảnh động cho quá trình chuyển đổi bằng cách gọi phương thức animateToCamera:animationDuration: của GMSPanoramaView.
Ngoài ra, bạn có thể kiểm soát camera bằng Core Animation. Tính năng này được cung cấp thông qua CALayer tuỳ chỉnh trên GMSPanoramaView, GMSPanoramaLayer.
Điểm đánh dấu trong Chế độ xem đường phố
Đối tượng GMSPanoramaView có thể hiển thị điểm đánh dấu trên bản đồ. Bạn có thể sử dụng cùng một đối tượng GMSMarker trên đối tượng GMSMapView hoặc GMSPanoramaView bằng cách đặt các thuộc tính tương ứng:
Swift
// Create a marker at the Eiffel Tower let position = CLLocationCoordinate2D(latitude: 48.858, longitude: 2.294) let marker = GMSMarker(position: position) // Add the marker to a GMSPanoramaView object named panoView marker.panoramaView = panoView // Add the marker to a GMSMapView object named mapView marker.map = mapView
Objective-C
// Create a marker at the Eiffel Tower CLLocationCoordinate2D position = CLLocationCoordinate2DMake(48.858,2.294); GMSMarker *marker = [GMSMarker markerWithPosition:position]; // Add the marker to a GMSPanoramaView object named panoView marker.panoramaView = panoView; // Add the marker to a GMSMapView object named mapView marker.map = mapView;
Điểm đánh dấu sẽ thay đổi kích thước theo khoảng cách giữa vị trí của điểm đánh dấu và vị trí của GMSCameraView. Nếu khoảng cách này trở nên quá lớn, điểm đánh dấu sẽ trở nên quá nhỏ để hiển thị và sẽ bị ẩn khỏi chế độ xem.
Đặt thuộc tính panoramaView thành nil để xoá thuộc tính này khỏi GMSPanoramaView.
Swift
marker.panoramaView = nil
Objective-C
marker.panoramaView = nil;
Sự kiện
Bạn có thể theo dõi các sự kiện xảy ra trên ảnh toàn cảnh trong Chế độ xem đường phố, chẳng hạn như khi người dùng nhấn vào ảnh toàn cảnh. Để theo dõi các sự kiện, bạn phải triển khai giao thức
GMSPanoramaViewDelegate. Xem hướng dẫn tổng thể về các sự kiện và danh sách phương thức trên
GMSPanoramaViewDelegate.