AI-generated Key Takeaways
-
After enabling billing and creating an API key, set up an Xcode project with Xcode version 15.0 or later to develop your app using the Places SDK for iOS.
-
Install the Places SDK for iOS using Swift Package Manager, CocoaPods, or manual installation, following the detailed steps provided for each method.
-
Add your API key to your app's AppDelegate file (Swift, Objective-C, or GooglePlacesSwift) using the provided code snippets and replacing "YOUR_API_KEY" with your actual key.
-
Optionally, for App Store deployment, inspect the Apple Privacy Manifest file included in the SDK's resources bundle to ensure compliance with Apple's privacy requirements.
After you enable billing and create an API key, you're ready to set up the Xcode project that you use to develop your app.
Release notes are available for each release.
Step 1: Install the required software
To build a project using the Places SDK for iOS, you need:
- Xcode version 16.0 or later
Step 2: Create the Xcode project and install the Places SDK for iOS
Swift Package Manager
The Places SDK for iOS can be installed via Swift Package Manager. To add the SDK, ensure you have removed any existing Places SDK for iOS dependencies.
To add the SDK to a new or existing project, follow these steps:
-
Open your Xcode
projectorworkspace, then go to File > Add Package Dependencies. - Enter https://github.com/googlemaps/ios-places-sdk as the URL, press Enter to pull in the package, and click "Add Package".
-
To install a specific
version, set the Dependency Rule field to one of the version-based options. For new projects, we recommend specifying the latest version and using the "Exact Version" option. Once complete, click "Add Package". - From the Choose Package Products window, verify that
GooglePlaces,GooglePlacesSwift, or both, will be added to your designated main target. Once complete, click Add Package.If you are updating Google Places Swift from the deprecated GitHub URL
Important: The GitHub URL to access Google Places Swift has changed starting with version 0.3.0. If you are updating a version of GooglePlacesSwift that was accessed through the old URL,
https://github.com/googlemaps/ios-places-swift-sdk, remove it from your Xcode's package dependencies section. - To verify your installation, navigate to your target's General pane. In Frameworks, Libraries, and Embedded Content, you should see the installed packages. You can also view the Package Dependencies section of Project Navigator to verify the package and its version.
To update the package for an existing project, follow these steps:
-
From Xcode, go to "File > Packages > Update To Latest Package Versions".
If you are updating Google Places Swift from the deprecated GitHub URL
Important: The GitHub URL to access Google Places Swift has changed starting with version 0.3.0. If you are updating a version of GooglePlacesSwift that was accessed through the old URL,
https://github.com/googlemaps/ios-places-swift-sdk, remove it from your Xcode's package dependencies section. - To verify your installation, go to the Package Dependencies section of Project Navigator to verify the package and its version.
To remove existing Places SDK for iOS installed manually, follow these steps:
-
From your Xcode project configuration settings, find Frameworks, Libraries,
and Embedded Content. Use the minus sign(-) to remove the following frameworks:
GooglePlaces.xcframeworkGooglePlacesSwift.xcframework
-
From the top level directory of your Xcode project, remove the
GooglePlacesbundle.
Manual installation
This guide shows how to manually add the XCFrameworks containing the Places SDK for iOS and Places Swift SDK for iOS to your project and configure your build settings in Xcode. An XCFramework is a binary package that you can >use on multiple platforms, including machines using Apple silicon. You can choose to add Places SDK for iOS, Places Swift SDK for iOS, or both.
- Download the following SDK binary and resource files:
- If you are installing Places Swift SDK for iOS, install the following files:
- Extract the files to access the XCFramework and resources.
- Launch Xcode and either open an existing project, or create a new project. If you're newer to iOS development, create a new project and select the iOS App template.
- Remove any Maps bundles from previous releases from your project.
-
Open the General tab. Drag the following XCFramework into your project
under Frameworks, Libraries, and Embedded Content. Make sure
to select Do Not Embed:
GooglePlaces.xcframework
GooglePlacesSwift.xcframework
-
Copy the
GooglePlaces.bundlefrom the GooglePlacesResources you downloaded into your Xcode project's top level directory. Make sure to select Copy items into destination group's folder when prompted.
If you are installing Places Swift SDK, copy theGooglePlacesSwift.bundlefrom the GooglePlacesSwiftResources you downloaded into your Xcode project's top level directory. Make sure to select Copy items into destination group's folder when prompted. - Select your project from the Project Navigator, and choose your application's target.
-
Open the Build Phases tab. Within Link Binary with
Libraries, add the following frameworks and libraries:
CoreGraphics.frameworkCoreLocation.frameworklibc++.tbdlibz.tbdQuartzCore.frameworkUIKit.framework
-
Choose your project, rather than a specific target, and open the Build Settings tab. In the Linking - General -> Other Linker Flags section, add
-ObjCto "Debug" and "Release". If these settings aren't visible, change the filter in the Build Settings bar from Basic to All.
CocoaPods
The Places SDK for iOS and Places Swift SDK for iOS are available as CocoaPod pods, GooglePlaces and GooglePlacesSwift.
CocoaPods is an open source dependency manager for Swift and Objective-C Cocoa projects. If you don't already have the CocoaPods tool, install it on macOS by running the following command from the terminal. For details, see the CocoaPods Getting Started guide.
sudo gem install cocoapods
Create a Podfile to install the SDKs and their dependencies:
- If you don't have an Xcode project yet, create one now and save it to your local machine. If you're newer to iOS development, create a new project and select the iOS App template.
- Create a file named
Podfilein your project directory. This file defines your project's dependencies. - Edit the
Podfileand add your dependencies along with their versions. Here is an example that specifies your application target name, and the names of theGooglePlacesandGooglePlacesSwiftpods: Make sure to regularly runsource 'https://github.com/CocoaPods/Specs.git' platform :ios, '16.0' target 'YOUR_APPLICATION_TARGET_NAME_HERE' do pod 'GooglePlaces', '10.4.0' pod 'GooglePlacesSwift', '10.4.0' end
pod outdatedto detect when there is a newer version to ensure you're always on the latest. - Save the
Podfile. Open a terminal and go to the directory containing the
Podfile:cd <path-to-project>
Run the
pod installcommand. This will install the APIs specified in thePodfile, along with any dependencies they may have.pod install
Close Xcode, and then open (double-click) your project's
.xcworkspacefile to launch Xcode. From this time onwards, you must use the.xcworkspacefile to open the project.
To update the API for an existing project, follow these steps:
- Open a terminal and go to the project directory containing the
Podfile. - Run the
pod updatecommand. This will update all of the APIs specified in thePodfileto the latest version.
Step 3: Add the API key to your app
In the following examples, replace YOUR_API_KEY with your API key.
GooglePlacesSwift
Add your API key to your AppDelegate.swift as follows:
- Add the following import statement:
import GooglePlacesSwift
- Add the following to your
application(_:didFinishLaunchingWithOptions:)method, replacing YOUR_API_KEY with your API key:PlacesClient.provideAPIKey("YOUR_API_KEY")
Swift
Add your API key to your AppDelegate.swift as follows:
- Add the following import statement:
import GooglePlaces
- Add the following to your
application(_:didFinishLaunchingWithOptions:)method, replacing YOUR_API_KEY with your API key:GMSPlacesClient.provideAPIKey("YOUR_API_KEY")
Objective-C
Add your API key to your AppDelegate.m as follows:
- Add the following import statement:
@import GooglePlaces;
- Add the following to your
application:didFinishLaunchingWithOptions:method, replacing YOUR_API_KEY with your API key:[GMSPlacesClient provideAPIKey:@"YOUR_API_KEY"];
Step 4 (optional): Inspect Apple Privacy Manifest file
Apple requires app privacy details for apps on the App Store. Visit the Apple App Store Privacy Details page for updates and more information.
The Apple Privacy Manifest file is included in the resources bundle for the SDK. To verify that the Privacy Manifest File has been included, and to inspect its contents, create an archive of your app and generate a privacy report from the archive.
Next steps
- Start writing code. A recommended starting point is implementing a starter app that get the user's current place.
- After your project is configured, you can explore the sample apps.
- Use App Check to secure your API key.