Starting with iOS 14, the operating system will now enforce new restrictions and permissions that affect the Cast user experience. It will also affect how you build the Cast SDK into your app. For your app to maintain Cast functionality with the latest versions of iOS, you must make updates to handle these permissions changes.
We are asking all developers to update their iOS Cast sender apps to the Google Cast SDK v4.6.0, which provides support for iOS 14.
Beginning with iOS 14, applications that scan for devices on the local network will now prompt users with a one-time permissions dialog to find and connect to local network devices. The Cast platform uses the local network to discover and control Cast devices, so if the user denies permission, they will not be able to cast.
To improve the user experience, we are making some UX modifications to the SDK for those apps that are using the standard device picker. These UX modifications make it more obvious to users why local network access permissions are needed, as well as how to enable casting if local network device access has been disabled.
Apps built with versions of the Cast SDK using v4.4.8 or earlier will continue to work as long as they are built with Xcode 11.7 or earlier. If you are building for iOS 14 with Xcode 12 or above, we recommend you update to the Cast SDK v4.6.0 to ensure that your Cast app will continue to work properly.
The Cast SDK v4.6.0 can be downloaded with CocoaPods by following the CocoaPods setup or manually by following the manual setup. This release includes changes to the underlying discovery mechanism to allow apps that are built with Xcode 12 to find Cast devices on the network. The Cast button should now always display. If no devices are available when the user taps on the Cast button, a dialog will be displayed providing guidance on why devices may not be available, including information on how to reenable local-network access permission.
Cast SDK changes
The first time a user attempts to Cast, a local network access (LNA) interstitial dialog will appear explaining why local networking access is needed, followed by the Apple-provided iOS local network access permissions prompt. The mocks below illustrate the flow:
Starting with iOS sender SDK 4.6.0, the Cast button always appears when the user is connected to Wi-Fi. When Cast devices are unavailable, tapping on the Cast button brings up a dialog that gives the user hints as to possible reasons Cast is unavailable, as shown in the mocks below:
Updating your app on iOS 14
Add the Cast iOS SDK 4.7.0 to your project
If using CocoaPods, use
pod updateto add the 4.7.0 SDK to your project.
Otherwise, pull in the SDK manually.
Info.plistto allow local network discovery to succeed on iOS 14.
You will need to add both
_<your-app-id>._googlecast._tcpas services for device discovery to work properly.
The appID is your receiverID, which is the same ID that is defined in your
Update the following example
NSBonjourServicesdefinition and replace "ABCD1234" with your appID.
We strongly recommend that you customize the message shown in the Local Network prompt by adding an app-specific permission string in your app's
Info.plistfile for the
NSLocalNetworkUsageDescriptionsuch as to describe Cast discovery and other discovery services, like DIAL.
This message will appear as part of the iOS Local Network Access dialog as shown in the mock.
Re-release your app to the Apple App Store
We recommend you also re-release your app using 4.7.0 as soon as possible.
Cast device discovery initiation
By default, Cast device discovery is initiated the first time the user taps the Cast button (
GCKUICastButton). If this is the first time the user has attempted to use the Cast app on the local network after upgrading to iOS 14, the new LNA interstitial will appear, followed by the iOS Local Network Access permissions dialog.
A new flag is available to allow you to control when device discovery starts and the behavior of certain elements of the UX:
The default value is
true. This flag is only applicable when the flag
GCKCastOptions::disableDiscoveryAutostartis set to
If set to
true, Cast device discovery starts when a user taps on the
GCKUICastButtonfor the first time. An informational message will be displayed to the user letting them know why local network permission is needed. Following that message, the iOS 14 LNA message will be displayed. Cast device discovery starts after the message is acknowledged.
In subsequent App launches,
If set to
false, device discovery will start based on the value of the flag
Frequently asked questions
What happens if I re-release my Cast sender app with the Cast SDK v4.4.8 and Xcode 12?
Your app may not be able to discover Cast devices on the local network unless you have obtained a networking multicast entitlement from Apple. Note that Apple will not be granting multicast entitlements solely for the purpose of supporting Cast. If you plan to build with Xcode 12, you should release your app with Cast 4.6.0.
If I re-release my app with the new Cast SDK, what will my users running on iOS 13 or earlier experience?
They will continue to see the same user experience they had prior to re-release of your app. User-visible changes are limited to users running on iOS 14.
What will I need to do to update my app once the new version of the Cast SDK is released?
- Update your app's
Info.plistto include a local network usage description.
NSBonjourServicesto your app's
Info.plistand provide the Bonjour service names for Cast and your app ID.
- Upgrade your sender app to use Cast SDK 4.6.0.
- Re-release your app to the Apple app store.
Why did devices stop showing up in my custom device picker after I upgraded to 4.6.0?
This is a known issue that can happen if you are using a custom device
picker instead of the standard device picker. In version 4.4.8 of the
Cast SDK and earlier, device scanning was automatic. Beginning in version
4.6.0, you will need to explicitly call the
method on the
GCKDiscoveryManager class to initiate device discovery.
The reason for this change is because the Local Network Access (LNA) permissions prompt will appear after the app has scanned for the first time. This could result in permissions dialogs appearing at random places in your app.
Developers who build a custom device picker for their app will be expected to provide an one-time interstitial prior to intiating device scanning for the first time in iOS 14.
With iOS 13, new permissions requirements were introduced which impact apps using the Google Cast SDK.
Starting with Google Cast SDK v4.4.3, an additional SDK is available without
guest mode support that does not require Bluetooth®
permission. This is available both on the
developer site and on the new
google-cast-sdk-no-bluetooth Cocoapods. As a reminder, the
guest mode feature is the ability for the sender app to
be able to detect cast devices within a certain physical proximity without being
on the same network, using a PIN displayed on guest mode-enabled devices.
To prepare your app for iOS 13 you will need to decide if you:
Need to keep guest mode support
- Must add the
Privacy - Bluetooth Always Usage Descriptionkey.
- Add a string to explain the Bluetooth® usage for your users to your
Need to remove guest mode support
- Prevents your app from requiring Cast Bluetooth® requirements.
- Integrate the latest version of the Google Cast SDK with no Bluetooth® support.
- This is available both on the
developer site and on the new
Near future considerations
Some device discovery system-level APIs changed with iOS 13. The Google Cast SDK v4.4.3 was updated to work better with these new behaviors.
Here is a breakdown depending on the version of the iOS SDK you are currently using:
Apps built with the iOS 12 SDK or earlier
- Action Recommended. Device discovery performance may decrease when running on iOS 13, but will still be functional. We highly recommend developers upgrade to Cast SDK v4.4.4 when available.
- iOS 13 will prompt users to grant Bluetooth® permissions to the app.
Apps built with the iOS 13 SDK
- Action Required: Update to Cast SDK 4.4.4 or the cast button may not appear if the user does not grant location permission. Upgrading to Cast SDK 4.4.4 is necessary to ensure a reliable casting experience on iOS 13.
- Please refer to developer documentation for more information on how to integrate guest mode, or opt-out of guest mode with Google Cast SDK and no Bluetooth® support.