Sau khi bật tính năng thanh toán và tạo khoá API, bạn có thể thiết lập dự án Xcode mà bạn dùng để phát triển ứng dụng.
Có Ghi chú phát hành cho từng bản phát hành.
Bước 1: Cài đặt phần mềm bắt buộc
Để tạo một dự án bằng SDK Maps cho iOS, bạn phải tải xuống và cài đặt:
- Xcode phiên bản 15.0 trở lên
Bước 2: Tạo dự án Xcode và cài đặt SDK Maps cho iOS
Trình quản lý gói Swift
Bạn có thể cài đặt SDK Maps cho iOS thông qua Trình quản lý gói Swift. Để thêm SDK, hãy đảm bảo bạn đã xoá mọi phần phụ thuộc SDK Maps hiện có cho iOS.
Để thêm SDK vào một dự án mới hoặc hiện có, hãy làm theo các bước sau:
-
Mở
project
hoặcworkspace
Xcode, sau đó chuyển đến File (Tệp) > Add Package Dependencies (Thêm phần phụ thuộc gói). - Nhập https://github.com/googlemaps/ios-maps-sdk làm URL, nhấn phím Enter để lấy gói rồi nhấp vào "Thêm gói".
-
Để cài đặt một
version
cụ thể, hãy đặt trường Dependency Rule (Quy tắc phần phụ thuộc) thành một trong các tuỳ chọn dựa trên phiên bản. Đối với các dự án mới, bạn nên chỉ định phiên bản mới nhất và sử dụng tuỳ chọn "Phiên bản chính xác". Sau khi hoàn tất, hãy nhấp vào "Thêm gói".
Để cập nhật package
cho một dự án hiện có, hãy làm theo các bước sau:
Nếu đang nâng cấp từ phiên bản thấp hơn 9.0.0, bạn phải xoá các phần phụ thuộc sau:
GoogleMapsBase
,GoogleMapsCore
vàGoogleMapsM4B
sau khi nâng cấp. Không xoá phần phụ thuộc choGoogleMaps
. Để biết thêm thông tin, hãy xem Ghi chú phát hành phiên bản 9.0.0.Trong phần cài đặt cấu hình dự án Xcode, hãy tìm Khung, Thư viện và Nội dung nhúng. Sử dụng dấu trừ(-) để xoá khung sau:
GoogleMapsBase
(Chỉ dành cho các bản nâng cấp từ phiên bản cũ hơn 9.0.0)GoogleMapsCore
(Chỉ dành cho các bản nâng cấp từ phiên bản cũ hơn 9.0.0)GoogleMapsM4B
(Chỉ dành cho các bản nâng cấp từ phiên bản cũ hơn 9.0.0)
- Trong Xcode, hãy chuyển đến "File > Packages > Update To Latest Package Versions" (Tệp > Gói > Cập nhật lên phiên bản gói mới nhất).
- Để xác minh quá trình cài đặt, hãy chuyển đến phần Package Dependencies (Phần phụ thuộc gói) của Project Navigator (Trình điều hướng dự án) để xác minh gói và phiên bản của gói.
Để xoá các phần phụ thuộc SDK Maps cho iOS hiện có được thêm bằng CocoaPods
, hãy làm theo các bước sau:
- Đóng không gian làm việc Xcode. Mở cửa sổ dòng lệnh và thực thi lệnh sau:
sudo gem install cocoapods-deintegrate cocoapods-clean pod deintegrate pod cache clean --all
-
Xoá
Podfile
,Podfile.resolved
và Xcodeworkspace
nếu bạn không sử dụng các tệp này cho bất kỳ mục đích nào khác ngoài CocoaPods.
-
Trong phần cài đặt cấu hình dự án Xcode, hãy tìm Khung, Thư viện và Nội dung nhúng. Sử dụng dấu trừ(-) để xoá khung sau:
GoogleMaps
GoogleMapsBase
(Chỉ dành cho các bản cài đặt trước phiên bản 9.2.0)GoogleMapsCore
(Chỉ dành cho các bản cài đặt trước phiên bản 9.2.0)GoogleMapsM4B
(Chỉ dành cho các bản cài đặt trước phiên bản 9.0.0)
-
Trong thư mục cấp cao nhất của dự án Xcode, hãy xoá gói
GoogleMaps
.
Cài đặt thủ công
Hướng dẫn này cho biết cách thêm XCFrameworks chứa SDK Maps cho iOS vào dự án theo cách thủ công và định cấu hình chế độ cài đặt bản dựng trong Xcode. XCFramework là một gói nhị phân mà bạn có thể sử dụng trên nhiều nền tảng, bao gồm cả các máy sử dụng silicon của Apple.
- Tải các tệp nhị phân và tài nguyên SDK sau đây xuống:
- Giải nén các tệp để truy cập vào XCFrameworks và tài nguyên.
- Nếu bạn chưa có dự án Xcode, hãy tạo một dự án ngay và lưu dự án đó vào máy của bạn. Nếu bạn mới bắt đầu phát triển ứng dụng iOS:
- Tạo dự án mới.
- Chọn mẫu iOS > Ứng dụng.
- Trên màn hình tuỳ chọn dự án:
- Nhập Project Name (Tên dự án).
- Ghi lại giá trị của trường Bundle identifier (Mã nhận dạng gói). Bạn có thể sử dụng giá trị đó để hạn chế khoá API của mình ở bên dưới.
- Đặt Giao diện của dự án thành Bảng phân cảnh.
- Đặt Language (Ngôn ngữ) thành Swift hoặc Objective-C.
-
Mở thẻ Chung. Kéo XCFramework sau vào dự án của bạn trong phần Khung, Thư viện và Nội dung nhúng. Hãy nhớ chọn Do Not Embed (Không nhúng):
GoogleMaps.xcframework
-
Sao chép
GoogleMaps.bundle
từ GoogleMapsResources mà bạn đã tải xuống vào thư mục cấp cao nhất của dự án Xcode. Hãy nhớ chọn Sao chép các mục vào thư mục của nhóm đích khi được nhắc. - Chọn dự án của bạn trong Project Navigator (Trình điều hướng dự án) rồi chọn mục tiêu của ứng dụng.
-
Mở thẻ Build Phases (Giai đoạn xây dựng) cho mục tiêu của ứng dụng.
Trong phần Link Binary with Libraries (Liên kết tệp nhị phân với thư viện), hãy thêm các khung và thư viện sau:
Accelerate.framework
Contacts.framework
CoreData.framework
CoreGraphics.framework
CoreImage.framework
CoreLocation.framework
CoreTelephony.framework
CoreText.framework
GLKit.framework
ImageIO.framework
libc++.tbd
libz.tbd
Metal.framework
OpenGLES.framework
(Chỉ khi bạn đang sử dụng OpenGL)QuartzCore.framework
Security.framework
SystemConfiguration.framework
UIKit.framework
-
Chọn dự án thay vì một mục tiêu cụ thể và mở thẻ Build Settings (Cài đặt bản dựng). Trong phần Linking - General -> Other Linker Flags (Liên kết – Chung –> Cờ trình liên kết khác), hãy thêm
-ObjC
vào "Debug" (Gỡ lỗi) và "Release" (Phát hành). Nếu bạn không thấy các chế độ cài đặt này, hãy thay đổi bộ lọc trong thanh Build Settings (Cài đặt bản dựng) từ Basic (Cơ bản) thành All (Tất cả). -
Để cài đặt SDK Địa điểm cho iOS XCFramework, hãy xem bài viết Bắt đầu sử dụng SDK Địa điểm cho iOS.
CocoaPods
SDK Maps cho iOS có sẵn dưới dạng pod CocoaPods. CocoaPods là một trình quản lý phần phụ thuộc nguồn mở cho các dự án Cocoa Swift và Objective-C.
Nếu bạn chưa có công cụ CocoaPods, hãy cài đặt công cụ này trên macOS bằng cách chạy lệnh sau từ dòng lệnh. Để biết thông tin chi tiết, hãy xem Hướng dẫn bắt đầu sử dụng CocoaPods.
sudo gem install cocoapods
Tạo Podfile
cho SDK Bản đồ dành cho iOS và sử dụng SDK này để cài đặt API và các phần phụ thuộc của API:
- Nếu bạn chưa có dự án Xcode, hãy tạo một dự án ngay và lưu dự án đó vào máy của bạn. Nếu bạn mới bắt đầu phát triển ứng dụng iOS:
- Tạo dự án mới.
- Chọn mẫu iOS > Ứng dụng.
- Trên màn hình tuỳ chọn dự án:
- Nhập Project Name (Tên dự án).
- Ghi lại giá trị của trường Bundle identifier (Mã nhận dạng gói). Bạn có thể sử dụng giá trị đó để hạn chế khoá API của mình ở bên dưới.
- Đặt Giao diện của dự án thành Bảng phân cảnh.
- Đặt Language (Ngôn ngữ) thành Swift hoặc Objective-C.
- Tạo một tệp có tên là
Podfile
trong thư mục dự án. Tệp này xác định các phần phụ thuộc của dự án. - Chỉnh sửa
Podfile
và thêm các phần phụ thuộc cùng với phiên bản của các phần phụ thuộc đó. Sau đây là ví dụ về phần phụ thuộc bạn cần cho SDK Maps dành cho iOS: Hãy nhớ thường xuyên chạysource 'https://github.com/CocoaPods/Specs.git' platform :ios, '15.0' target 'YOUR_APPLICATION_TARGET_NAME_HERE' do pod 'GoogleMaps', '9.2.0' end
pod outdated
để phát hiện thời điểm có phiên bản mới hơn nhằm đảm bảo bạn luôn sử dụng phiên bản mới nhất. Nếu cần, hãy nâng cấp lên phiên bản mới nhất. - Lưu
Podfile
. Mở một cửa sổ dòng lệnh và chuyển đến thư mục chứa
Podfile
:cd <path-to-project>
Chạy lệnh
pod install
. Thao tác này sẽ cài đặt các API được chỉ định trongPodfile
, cùng với mọi phần phụ thuộc mà các API đó có thể có.pod install
Đóng Xcode, sau đó mở (nhấp đúp) tệp
.xcworkspace
của dự án để chạy Xcode. Từ thời điểm này trở đi, bạn phải sử dụng tệp.xcworkspace
để mở dự án.
Để cập nhật API cho một dự án hiện có, hãy làm theo các bước sau:
- Mở một cửa sổ dòng lệnh rồi chuyển đến thư mục dự án chứa
Podfile
. - Chạy lệnh
pod update
. Thao tác này sẽ cập nhật tất cả các API được chỉ định trongPodfile
lên phiên bản mới nhất.
Bước 3: Thêm khoá API vào dự án
Trong phần Lấy khoá API, bạn đã tạo một khoá API cho ứng dụng của mình. Bây giờ, hãy thêm khoá đó vào dự án Xcode.
Trong các ví dụ sau, hãy thay thế YOUR_API_KEY
bằng khoá API của bạn.
Swift
Thêm khoá API vào AppDelegate.swift
như sau:
- Thêm câu lệnh nhập sau:
import GoogleMaps
- Thêm nội dung sau vào phương thức
application(_:didFinishLaunchingWithOptions:)
bằng khoá API:GMSServices.provideAPIKey("YOUR_API_KEY")
- Nếu bạn cũng đang sử dụng API Địa điểm, hãy thêm lại khoá của bạn như sau:
GMSPlacesClient.provideAPIKey("YOUR_API_KEY")
Objective-C
Thêm khoá API vào AppDelegate.m
như sau:
- Thêm câu lệnh nhập sau:
@import GoogleMaps;
- Thêm nội dung sau vào phương thức
application:didFinishLaunchingWithOptions:
bằng khoá API:[GMSServices provideAPIKey:@"YOUR_API_KEY"];
- Nếu bạn cũng đang sử dụng API Địa điểm, hãy thêm lại khoá của bạn như sau:
[GMSPlacesClient provideAPIKey:@"YOUR_API_KEY"];
Bước 4 (không bắt buộc): Kiểm tra tệp Tuyên bố về quyền riêng tư của Apple
Apple yêu cầu thông tin chi tiết về quyền riêng tư trong ứng dụng đối với các ứng dụng trên App Store. Hãy truy cập vào trang Thông tin chi tiết về quyền riêng tư trên App Store của Apple để biết thông tin cập nhật và thông tin khác.
Tệp Tuyên bố về quyền riêng tư của Apple có trong gói tài nguyên của SDK. Để xác minh rằng Tệp kê khai quyền riêng tư đã được đưa vào và để kiểm tra nội dung của tệp này, hãy tạo bản lưu trữ ứng dụng và tạo báo cáo quyền riêng tư từ bản lưu trữ đó.
Bước 5 (không bắt buộc): Khai báo lược đồ URL mà API sử dụng
Kể từ iOS 9 và Xcode 7, các ứng dụng có thể khai báo giao thức URL mà chúng dự định mở bằng cách chỉ định giao thức trong tệp Info.plist
của ứng dụng. SDK Maps cho iOS sẽ mở ứng dụng Google Maps dành cho thiết bị di động khi người dùng nhấp vào biểu trưng Google trên bản đồ. Do đó, ứng dụng của bạn có thể khai báo các giao thức URL liên quan.
Để khai báo các giao thức URL mà SDK Maps dành cho iOS sử dụng, hãy thêm các dòng sau vào Info.plist
:
<key>LSApplicationQueriesSchemes</key>
<array>
<string>googlechromes</string>
<string>comgooglemaps</string>
</array>
Ảnh chụp màn hình sau đây cho thấy cấu hình trong giao diện người dùng Xcode:
Nếu không có nội dung khai báo ở trên, các lỗi sau có thể xảy ra khi người dùng nhấn vào biểu trưng Google trên bản đồ:
-canOpenURL: failed for URL: "comgooglemaps://" - error: "This app is not allowed to query for scheme comgooglemaps"
-canOpenURL: failed for URL: "googlechromes://" - error: "This app is not allowed to query for scheme googlechromes"
Để loại bỏ các lỗi này, hãy thêm nội dung khai báo vào Info.plist
.
Bước tiếp theo
Giờ đây, khi đã có khoá API và dự án Xcode, bạn có thể tạo và chạy ứng dụng. Navigation SDK cho iOS cung cấp nhiều hướng dẫn và ứng dụng mẫu có thể giúp bạn bắt đầu. Để biết thêm thông tin chi tiết, hãy xem:
- Bạn nên bắt đầu từ các hướng dẫn sau:
- Hãy xem các mã mẫu và codelabs hiện có.
- Đối với các giải pháp toàn diện, hãy xem Giải pháp Maps hiện có.