Chế độ xem đường phố trên Google Maps giú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 độ ở tầm đườ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, chỉ đường cho một chuyến đi hoặc giới thiệu bên ngoài doanh nghiệp của mình.
Tổng quan
Chế độ xem đường phố của Google cung cấp hình ảnh toàn cảnh 360 độ từ các con đường được chỉ định trong phạm vi phủ sóng. Phạm vi cung cấp thông tin thông qua SDK giống như phạm vi cung cấp thông tin cho ứng dụng Google Maps cho iOS hoặc https://maps.google.com/
. Bạn có thể đọc thêm về Chế độ xem đường 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 đường phố.
Maps SDK cho iOS cung cấp dịch vụ Chế độ xem đường phố để lấy và thao tác với hình ảnh dùng trong Chế độ xem đường phố của Google Maps.
Hình ảnh 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 đường phố
Mỗi ảnh toàn cảnh trên Chế độ xem đường phố là một hình ảnh hoặc một nhóm hình ảnh cung cấp chế độ xem toàn cảnh 360 độ từ một vị trí. Hình ảnh tuân theo phép chiếu hình chữ nhật đồng dạng (Plate Carrée), trong đó chứa chế độ xem ngang 360 độ (bao quanh toàn bộ) và chế độ xem dọc 180 độ (từ trên xuống dưới). Ảnh toàn cảnh 360 độ thu được xác định một hình chiếu trên một hình cầu với hình ảnh được bao bọc trên bề mặt hai chiều của hình cầu đó.
Bạn có thể xem hình ảnh toàn cảnh trên Chế độ xem đường 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áy ảnh ở chính giữa. Bạn có thể kiểm soát hướng của máy ảnh bằng cách 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 trên Chế độ xem đường phố được xác định bằng một trong hai siêu dữ liệu:
panoramaID
- Mã nhận dạng duy nhất của ảnh toàn cảnh trong Chế độ xem đường phố.
panoramaID
này có thể thay đổi theo thời gian và không phù hợp để tham chiếu lâu dài hoặc được mã hoá cứng. Bạn nên sử dụngpanoramaID
để cung cấp quyền truy cập có lập trình vào nhiều hình ảnh trong Chế độ xem đường 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ữ liên tục vị trí toàn cảnh hoặc để dịch các hành động của người dùng trên bản đồ thành hình ảnh Chế độ xem đường 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 thu được sẽ bao gồm cả hai phần siêu dữ liệu, cũng như một mảng đường liên kết đến các ảnh toàn cảnh lân cậ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 Chế độ xem đường phố dựa trên tọa độ.
Phương thức
moveNearCoordinate
yêu cầu một ảnh toàn cảnh gần toạ độ.Phương thức
moveNearCoordinate:radius
cũng tươ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:source
cho phép bạn chỉ định một nguồn. Nguồn sẽ hữu ích nếu bạn muốn hạn chế Chế độ xem đường phố chỉ tìm kiếm ảnh toàn cảnh ở bên ngoài. Theo mặc định, ảnh toàn cảnh của các địa điểm là ở bên trong hoặc bên ngoài. Xin lưu ý rằng có thể không có ảnh toàn cảnh ngoài trời cho vị trí được chỉ định.Phương thức
moveNearCoordinate:radius:source
cho phép bạn chỉ định cả bán kính và nguồn.
Xem hình ảnh trong Chế độ xem đường phố
Thêm trình xem Chế độ xem đường phố
Sau đây là các bước cơ bản để thêm người xem:
- (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 bắt buộc.
- Tạo hoặc cập nhật
ViewController
. Nếu ảnh toàn cảnh sẽ hiển thị 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à tạo bản sao của lớp
GMSPanoramaView
bằng phương thứcinitWithFrame:
GMSPanoramaView
. Nếu bạn muốn sử dụng thành phần hiển thị này làm thành phần hiển thị duy nhất của bộ điều khiển chế độ xem, thì bạn có thể sử dụngCGRectZero
làm khung của bản đồ — bản đồ sẽ tự động đổi kích thước. - Đặt đối tượng
GMSPanoramaView
làm thành phần hiển thị của trình điều khiển thành phần hiển thị, ví dụ:self.view = panoView;
. - Đặt vị trí của hình ảnh Chế độ xem đường phố bằng một phương thức như
moveNearCoordinate:
.
Ví dụ dưới đây 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ính năng kéo, 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ể thực hiện các thay đổi theo lập trình khi cử chỉ bị tắt.
orientationGestures
- Liệu người dùng có thể định hướng lại máy ảnh 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 máy ảnh. 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 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];
Chạy Chế độ xem đường phố bằng Lược đồ URL
Bạn có thể xem hình ảnh của Google Street View trong ứng dụng Google Maps dành cho iOS. Bạn có thể chạy ứng dụng Google Maps cho iOS ở chế độ xem đường phố bằng Lược đồ URL comgooglemaps
bằng cách đặt tham số mapmode
thành streetview
. Dưới đây là ví dụ về URL sẽ khởi chạy Chế độ xem đường phố. Để 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à góc nhìn (POV) trong Chế độ xem đường phố
GMSPanoramaCamera
cho phép bạn đặt điểm nhìn của máy ảnh Chế độ xem đường phố dưới dạng tổ hợp hướng, độ dốc và độ thu phóng.
Các tập hợp đoạn mã dưới đây sẽ hướng máy ảnh về phía nam và hơi hướng 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í trên Chế độ xem đường phố xác định vị trí đặt tiêu điểm của máy ảnh cho một hình ảnh, nhưng không xác định hướng của máy ảnh cho hình ảnh đó.
Để thực hiện mục đích đó, đối tượng GMSOrientation
xác định hai thuộc tính:
heading
xác định góc xoay xung quanh vị trí máy ảnh tính theo độ so với hướng bắc thực. Hướng đượ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 độ lệch góc "lên" hoặc "xuống" so với độ dốc mặc định ban đầu của máy ảnh, thường (nhưng không phải lúc nào cũng) nằm ngang phẳng. (Ví dụ: hình ảnh được chụp trên một ngọn đồi có thể hiển thị độ dốc mặc định không phải là theo chiều ngang.) Góc nghiêng được đo bằng các giá trị dương khi nhìn lên (đến +90 độ thẳng lên và vuông góc với độ dốc mặc định) và các giá trị âm khi nhìn xuống (đến -90 độ thẳng xuống và vuông góc với độ dốc mặc định).
Zoom (thu phóng)
Chế độ xem đường phố hỗ trợ nhiều cấp độ chi tiết hình ảnh thông qua 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 thu phóng trong trình xem bằng cách chụm để thu phóng.
Di chuyển máy ảnh
Sau khi tạo GMSPanoramaView
và GMSPanoramaView
có máy ảnh được định cấu hình hoặc mặc định, bạn có thể thay đổi máy ảnh theo một trong nhiều cách. Khi thay đổi máy ảnh, bạn có thể tạo ảnh động cho chuyển động của máy ảnh. Ảnh động nội suy giữa các thuộc tính máy ảnh hiện tại và các thuộc tính máy ảnh mới.
Bạn có thể sửa đổi đối tượng GMSPanoramaCamera
và đặt đối tượng đó trên thuộc tính camera
của GMSPanoramaView
. Thao tác này sẽ chuyển máy ảnh sang góc nhìn mới mà không có ảnh động. Bạn có thể tạo GMSCameraPosition
để định cấu hình bất kỳ tổ hợp hướng và thu phóng nào.
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 hiệu ứng 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ể điều khiển máy ảnh 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 thiết lập các thuộc tính tương ứng của đối tượ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ẽ điều chỉnh theo tỷ lệ kích thước theo hàm của 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 đó khỏi GMSPanoramaView
.
Swift
marker.panoramaView = nil
Objective-C
marker.panoramaView = nil;
Sự kiện
Bạn có thể nghe các sự kiện xảy ra trên ảnh toàn cảnh 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 sự kiện, bạn phải triển khai giao thức GMSPanoramaViewDelegate
. Xem hướng dẫn tổng quan về sự kiện và danh sách các phương thức trên GMSPanoramaViewDelegate
.