- Fixes a crash in BCOVTVPlayerView related to invalid CGRect values.
- Fixes an issue in BCOVTVPlayerView wherethe thumbnail preview would briefly show when resuming playback during scrubbing.
- On tvOS the BCOVTVPlayerView UI will no longer display a thumbnail preview by default when playback is paused using the Play/Pause button on the remote. You can enable the new
displayThumbnailOnPause
property onBCOVTVPlayerViewOptions
to restore this behavior. - Fixes an issue in BCOVUIPlayerView that would cause the thumbnail preview to fade out while seeking.
- The
BCOVFairPlayManager
methodpreloadContentKeys(for:)
has been change topreloadContentKeys(forVideos:)
- The format for
BCOVAd
constants has changed. For examplekBCOVAdPropertyKeySkippable
is nowBCOVAd.PropertyKeySkippable
. - The
BCOVPlaybackControllerAdsDelegate
method for entering an ad sequence is nowplaybackController(controller:playbackSession:didEnterAdSequence:)
- The
BCOVPlaybackControllerAdsDelegate
method for entering an ad is nowplaybackController(controller:playbackSession:didEnterAd:)
- The
BCOVPlaybackControllerAdsDelegate
method for pausing an ad is nowplaybackController(controller:playbackSession:didPauseAd:)
- The kBCOVCAFReceiverApplicationID constant has been changed to
C179578D
in order to target the v3 Brighcove CAF Receiver.
- Support for the static Framework and static XCFramework has deprecated.
- The format for BCOVVideoErrorCodes constants has change. For example
kBCOVVideoErrorCodeBadRequest
is nowBCOVVideoErrorCode.BadRequest
. - The format for Sidecar Subtitle constants has changed. For example
kBCOVSSVideoPropertiesKeyTextTracks
is nowBCOVSSConstants.VideoPropertiesKeyTextTracks
. - The
shared
singleton forBCOVPlayerSDKManager
has been changed tosharedManager
and is no longer nullable. You no longer need to treat it as an optional in Swift. - The
BCOVPlayerSDKManager
methodcreatePlaybackController(with:viewStrategy:)
has been changed tocreatePlaybackController(withSessionProvider:viewStrategy:)
and no longer returns and optional value. - The
BCOVPlayerSDKManager
methodcreateFairPlaySessionProvider(with:upstreamSessionProvider:)
has been changed tocreateFairPlaySessionProvider(withAuthorizationProxy:upstreamSessionProvider:)
- The format for
BCOVPlaybackService
constants has changed. For examplekBCOVPlaybackServiceConfigurationKeyAssetID
is nowBCOVPlaybackService.ConfigurationKeyAssetID
. - The closures for the
BCOVPlaybackService
methodsfindVideo(withConfiguration:queryParameters:completion)
andfindPlaylist(withConfiguration:queryParameters:completion)
have changed. ThejsonResponse: [AnyHashable:Any]?
type is nowjsonResponse: Any?
. - The
BCOVPlaybackService
methodBCOVPlaybackService(accountId:policyKey:)
has been changed toBCOVPlaybackService(withAccountId:policyKey:)
. - The
BCOVPlaybackService
methodBCOVPlaybackService(requestFactory:)
has been changed toBCOVPlaybackService(withRequestFactory:)
. - The
BCOVPlaybackRequestFactory
methodBCOVPlaybackServiceRequestFactory(accountId:, policyKey:)
has been changed toBCOVPlaybackServiceRequestFactory(withAccountId:, policyKey:)
. - The
sharedConfig()
singleton forBCOVGlobalConfiguration
has been changed tosharedConfig
. - The
BCOVMutableSource
protocol has been replaced with theBCOVMutableSource
class. This primarily affects theupdate:
method onBCOVSource
in which aBCOVMutableSource
object is now returned. - The
properties
dictionary onBCOVSource
is no longer nullable. You no longer need to treat it as an optional in Swift. - The format for
BCOVSource
constants has changed. For examplekBCOVSourceURLSchemeHTTPS
is nowBCOVSource.URLSchemeHTTPS
. - The
BCOVFPSBrightcoveAuthProxy
methodBCOVFPSBrightcoveAuthProxy(publisherId:applicationId:)
has been changed toBCOVFPSBrightcoveAuthProxy(withPublisherId:applicationId:)
and is no longer nullable. You no longer need to treat it as an optional in Swift. - The format for
BCOVVideo
constants has changed. For examplekBCOVVideoPropertyKeyName
is nowBCOVVideo.PropertyKeyName
. - The C-Style functions
NSString * localizedNameForLocale(BCOVVideo, NSLocale)
,NSString * localizedShortDescriptionForLocale(BCOVVideo, NSLocale)
andNSString * localizedLongDescriptionForLocale(BCOVVideo, NSLocale)
are nowBCOVVideo
instance methods. For examplevideo.localizedName(forLocale: locale)
. - The
BCOVMutableVideo
protocol has been replaced with theBCOVMutableVideo
class. This primarily affects theupdate:
method onBCOVVideo
in which aBCOVMutableVideo
object is now returned. - The
variantForPreferredLanguage:
method onBCOVVideo
has been changed tovariantForPreferredLanguages:
. - The
properties
dictionary onBCOVVideo
is no longer nullable. You no longer need to treat it as an optional in Swift. - The
setVideos:
method onBCOVPlaybackController
now requires an array ofBCOVVideo
objects. This removes the need in Swift to cast an arrayas NSFastEnumeration
. - The
BCOVPlaybackSessionBasicConsumer
didCompletePlaylist:
delegate method now returns an array ofBCOVVideo
objects. - The
BCOVPlaybackControllerBasicDelegate
playbackController:didCompletePlaylist:
andplaybackController:noPlayableVideosFound:
delegate methods now return an array ofBCOVVideo
objects. - The
videos
array onBCOVPlaylist
is no longer nullable. You no longer need to treat it as an optional in Swift. - The format for
BCOVPlaylist
constants has changed. For examplekBCOVPlaylistPropertiesKeyAccountId
is nowBCOVPlaylist.PropertiesKeyAccountId
.
- Adds Thumbnail Seeking support for ReactNative and Flutter sample projects.
- Fixes an issue where the thumbnail image is not always displayed as expected after moving the playhead position in the progress bar.
- Fixes an issue where the "From Beginning" button in the tvOS Info Tab View was visible for Live content.
- Added the
titleForInfoViewForVideo:
delegate method toBCOVTVPlayerViewDelegate
that allows customization of the title displayed in the tvOS Info Tab View. - Fixes an issue where the player controls would not be hidden when pressing on the Menu button on the Siri remote.
- Fixes an issue where the Menu button on the Siri remote would not perform the default behavior if the playback controls were hidden.
- The Google Cast Plugin Framework and XCFramework are now dynamic instead of static.
- The "No-Bluetooth" podspec variation has been removed. We are targeting Google Cast SDK 4.8.1 and at this time there is not a 4.8.1 version of the "No-Bluetooth" Google Cast SDK. If you require the "No-Bluetooth" option you can manually install our Google Cast Plugin and add the
google-cast-sdk-no-bluetooth
pod to your podfile which will install Google Cast SDK 4.8.0.
- The Omnigure Plugin Framework and XCFramework are now dynamic instead of static.
- Adds IMA Plugin support for SwiftUI, ReactNative and Flutter sample projects.
- Released SDK Interactivity v1.0 - Please review the Interactivity README for further information.
- Fix for calling
insertVideo:afterVideoAtIndex:
after the current video has completed. - Fix for presenting
BCOVTVPlayerView
in a modal view causing the modal to automatically dismiss. - Fix for poster image for audio-only content being displayed during ad breaks.
- Supports Google Cast SDK 4.8.1.
- The minimum Deployment Target for Google Cast Plugin for Brightcove Player SDK for iOS is iOS 14.0.
- Supports Google Ads IMA SDK 3.23.0 for iOS and 4.13.0 for tvOS.
- Supports Google Ads IMA SDK 3.23.0 for iOS and 4.13.0 for tvOS.
- The BrightcovePlayerSDK XCFrameworks are now code signed.
-
The BrightcoveSSAI and OMSDK_Brightcove XCFrameworks are now code signed.
-
Supports Open Measurement SDK 1.4.13 for iOS.
- The BrightcovePulse XCFramework is now code signed.
- The BrightcoveIMA XCFramework is now code signed.
- The BrightcoveFW XCFramework is now code signed.
- The BrightcoveGoogleCast XCFramework is now code signed.
- The BrightcoveAMC XCFramework is now code signed.
-
Adds a new UI experience for tvOS. See the Migrating from BCOVTVTabBarItemView to UIViewController section of the TVPlayer README for migration information.
-
The deprecated
BCOVPlaybackService
findVideo:
methods have been removed. UsefindVideoWithConfiguration:queryParameters:completion:
method going forward. See the Core README for more information. -
The deprecated
BCOVPlaybackService
findPlaylist:
methods have been removed. UsefindPlaylistWithConfiguration:queryParameters:completion:
method going forward. See the Core README for more information.
- Adds a Privacy Manifest to the Core SDK.
- Fixes an issue where you could not fast-rewind past a mid-roll cue-point.
- Fixes an issue where the app crashes trying to load an invalid asset from the VAST response.
- Supports Google Ads IMA SDK 3.22.0 for iOS and 4.12.0 for tvOS.
- Fixes a memory leak for SSAI session which could cause a video to continue playing after its view controller had been dismissed while ad was playing.
- Adds support for custom labels for Audible and Legible tracks in the "Audio & Subtitles" UI. See
titleForLegibleMediaSelectionOption:
andtitleForAudibleMediaSelectionOption:
inBCOVPlaybackController.h
for more information.
- Fixes an issue where using the same ad tag URL on multiple videos on the same
BCOVPlaybackController
could result in the ads not loading for subsequent videos.
- Fixes an issue where after a playback session with captions, the next session remains showing the button for captions even if the video does not contain any caption.
- Fixes an issue when using
resumeVideoAtTime:withAutoPlay:
during an ad break where the ad controls would remain active.
- The minimum Deployment Target for all Brightcove Native Player for iOS frameworks is now iOS 12.0 and tvOS 12.0.
-
Fixes an issue where
playbackController:playbackSession:determinedMediaType:
would not be called. -
Fixes an issue where a
kBCOVPlaybackSessionLifecycleEventError
lifecycle event could be triggered when using a Fairplay Session Provider on a non-DRM video. -
Adds support for retaining a user's caption selection preference. This is enabled by default, see documentation for
enableCaptionPersistence
inBCOVPlaybackController.h
for more information. -
Adds support for downloading HDCP content.
-
Fixed an issue that prevented pausing/resuming of offline downloads when using
requestVideoDownload:downloadConfiguration:parameters:completion:
. -
Added the
downloadWasPausedForOfflineVideoToken:
delegate method toBCOVOfflineVideoManagerDelegate
. -
Adds support for
application_id
,player
andplayer_name
fields for Analytics.
-
Supports Google Ads IMA SDK 3.19.1 for iOS and 4.9.1 for tvOS.
-
The tvOS slices are part now of the BrightcoveIMA XCFramework.
-
Adds support for tvOS with SPM.
- The minimum Deployment Target for IMA Plugin for Brightcove Player SDK for iOS is iOS 14.0.
- Supports Google Cast SDK 4.8.0.
- The minimum Deployment Target for Google Cast Plugin for Brightcove Player SDK for iOS is iOS 13.0.
- Fixes an issue where calling
resumeVideoAtTime:withAutoPlay:
would result in an incorrect video duration.
-
Fixes an issue with FairPlay license renewal when using AirPlay on iOS 16.
-
Fixes an issue where calling
setVideos:
a second time could result in playback failure.
- Added documentation for SSAI URL Variables.
-
All existing
BCOVPlaybackService
findVideo:
methods are now deprecated. Use the newfindVideoWithConfiguration:queryParameters:completion:
method going forward. See the Core README for more information. -
All existing
BCOVPlaybackService
findPlaylist:
methods are now deprecated. Use the newfindPlaylistWithConfiguration:queryParameters:completion:
method going forward. See the Core README for more information.
- Fixes an issue where the progress of a completed video would continue to increment when AirPlay is active and no network connection is available.
-
Added support for SpringServe Macros.
-
Fixes an issue that would prevent playback when using an invalid adTagURL.
-
Fixes an issue where the player controls greyed out and disabled when Airplay is active after switch video.
-
Fixes an issue where the progress bar would jump back ~15 seconds after a post-roll ad completed when
enableBackgroundPlayback
is enabled onIMASettings
.
- Fixes an issue where linear playback was not being enabled when Picture-in-Picture was active during an SSAI pre-roll.
-
The SDK now utilizes AVQueuePlayer over AVPlayer. Refer to the Video Insertion section of the Core README for information on how to insert videos. AVQueuePlayer does not support calling
replaceCurrentItemWithPlayerItem:
, useremoveAllItems
instead if this behavior is needed. -
Adds support for downloading content with
AVAssetDownloadConfiguration
for iOS 15+ devices. See the OfflinePlayback README for more information. -
Adds support for displaying the poster image for audio-only offline downloads.
-
Fixes an issue where the completion block for BCOVPlaybackService would be called on a background thread when requesting a bumper video.
-
Fixes a crash that could occur when using Generic Stream Concurrency.
- Support for
iFramePlaylistURL
has been removed. UsethumbnailVTTURL
instead.
-
Supports Google Ads IMA SDK 3.18.1 for iOS and 4.6.1 for tvOS.
-
Adds XCFramework support for IMA Plugin.
-
Adds support for Swift Package Manager. Refer to the Swift Package Manager section.
-
The minimum Deployment Target for IMA Plugin for Brightcove Player SDK for iOS is iOS 12.0 and tvOS 12.0.
-
The static IMA podspec has been removed. Use
Brightcove-Player-IMA
orBrightcove-Player-IMA/XCFramework
instead.
- Supports version 6.52.0 of the FreeWheel AdManager framework for iOS and tvOS.
- The static FreeWheel podspec has been removed. Use
Brightcove-Player-FreeWheel
orBrightcove-Player-FreeWheel/XCFramework
instead.
- The static Pulse podspec has been removed. Use
Brightcove-Player-Pulse
orBrightcove-Player-Pulse/XCFramework
instead.
- The static SSAI podspec has been removed. Use
Brightcove-Player-SSAI
orBrightcove-Player-SSAI/XCFramework
instead.
- Fixes an issue where disabling captions on a Cast receiver wouldn't sync with the device when Casting ended.
-
Fixes an issue that could cause the playback button to be in the wrong state.
-
Fixes a crash that would occur when a text track did not have a label value.
-
Fixes an issue that would prevent playback of some DRM content.
-
Fixes an issue where using a custom playback rate could result in ads not playing.
-
Fixes a timing accuracy issue with thumbnail seeking.
- The minimum Deployment Target for all Brightcove Native Player for iOS frameworks is now iOS 11.4 and tvOS 11.4.
- SDK release 6.8.6 fixed an issue where the
video_duration
value was not being passed with VODvideo_view
events.
bcovpuiiconfont.ttf
resource has been moved toBCOVPUIResources.bundle
to comply with new code signing requirements. For manual installation with static XCFramework or Fat Framework (Universal Framework) refer to the Manual Installation section of the Core README. The manual installation with dynamic XCFramework or Fat Framework (Universal Framework) or, installation with CocoaPods or Swift Package Manager has not changed.
-
Fixes code signing issues by repackaging resource files into Xcode Resource Bundles.
-
Fixes an issue where an expired TTL prevented DRM-protected offline videos from playing.
-
Corrects the behavior of the
BCOVPlaybackController
method,–resumeVideoAtTime:withAutoPlay:
. -
Fixes an issue with setting the thumb image of a
BCOVPlayerUI
progress slider.
-
Fixes a crash which occurred when attempting to play a second video after playing a first video with ads.
-
Fixes an issue where while playing a playlist, an incorrect video began playback after a preroll ad.
-
Fixes an issue with calling
setVideos:
after receivingkBCOVPlaybackSessionLifecycleEventEnd
whenenableBackgroundPlayback
is enabled onIMASettings
.
omsdk-v1.js
resource has been moved toBCOVSSAIOMResources.bundle
to comply with new code signing requirements. The installation has not changed.
-
SDK release 6.10.5 added support for Live HLSe License Keys Protection.
-
Adds support for Video Bumpers. Refer to the Bumper Support section of the Core README for details.
-
Fixes a crash when
keepControlsVisible
is set toYES
inBCOVPUIPlayerViewOptions
. -
Fixes an issue where calling
-setVideos:
was briefly blocking the main thread on iOS 15+ devices. -
Fixes play/pause behavior during ad playback on Apple TV.
-
Fixes an issue which prevented customization of the progress slider tint color.
-
Fixes a crash which could occur when closing a player on devices running iOS 12.
-
Adds the
video_duration
field toplay_request
events for VOD content. -
Fixes an issue where progress and duration values were not updated correctly between videos in a playlist.
-
Improves documentation and error reporting for preloading a FairPlay license in the context of video downloads.
- Improves the behavior of seeking around ads and Seek Without Ads.
- Improves the behavior of seeking around ads and Seek Without Ads.
-
Fixes an issue where Seek Without Ads did not skip the midrolls before the seek time.
-
Fixes an issue where Pause Ads were not displayed when using
automaticControlTypeSelection
.
- Improves the behavior of seeking around ads and Seek Without Ads.
- In preparation for Xcode 14, bitcode has been removed from all frameworks of the Brightcove Native Player SDK for iOS.
- Adds the TableViewPlayer sample projects in Objective-C and Swift to demonstrate a scrolling list of playing videos.
-
Support for Short Manifest TTL was added in SDK release 6.10.3.
-
Adds
rendition_width
,rendition_height
anddropped_frames
metrics when reporting engagement events. -
Fixes an issue where the completion block of
-preloadFairPlayLicense:parameters:completion:
was not called when a loading error occurred. -
Fixes an issue where the player view could be black when multiple BCOVPlaybackControllers are in use (e.g. a table view of video players).
-
Fixes an issue where calling
-play
on aBCOVPlaybackController
after the video had completed might not restart the video. -
Fixes a crash that could occur on iOS 11 and iOS 12 when using a renewing DRM license.
- Adds limited support for picture-in-picture playback. Refer to the Picture in Picture section of the FreeWheel README for information on supported configurations and expectations.
- Adds support for Generic Stream Concurrency.
- Deprecates
kBCOVIMAOptionBlockAdTargetingAPIsKey
. The option will be removed in a future release of the SDK.
-
Adds support for Swift Package Manager. Refer to the Swift Package Manager sections of the Core SDK and Plugin READMEs.
-
Adds support for Live HLSe License Keys Protection.
-
Adds sample code for customizing UI controls in the PlayerUI/PlayerUICustomization projects in the ios-sample-projects.
-
Removes references to legacy Video Cloud services from the ios-sample-projects.
-
Improves Generic Stream Concurrency retry logic.
-
Uses thumbnail VTT tracks to improve the performance of Thumbnail Seeking. The
iFramePlaylistURL
property ofBCOVVideo
has been deprecated and it, and all other support for I-frame playlists, will be removed in a future release of the SDK. -
Fixes seek behavior when the progress slider is dragged to its end after the video has already completed.
-
Clarifies the steps for adding custom localizations. Refer to the Custom Localization section of the Core SDK README.
-
Adds guidance for presenting a LEARN MORE button during IMA ad playback while using an AVPlayerViewController. Refer to the Using an AVPlayerViewController with a BCOVPlaybackController section of the Core SDK README.
- Fixes an issue with duplicate tracks while casting to a GoogleCast device.
- Adds limited support for picture-in-picture playback. Refer to the Picture in Picture section of the IMA README for information on supported configurations and expectations.
- Adds a ReactNative sample project to the ios-sample-projects git repository.
-
Support for I-frame playlists (also known as HLS Trick Play) has been deprecated in favor of WebVTT files. This change only affects apps that utilize a custom I-frame playlist URL.
-
Fixes an issue with playlist auto-advance when playing in a Picture in Picture controller.
-
Fixes an issue where the
contentIdentifierFromLoadingRequest
delegate was not being called while using a custom FairPlay proxy implementation.
- Adds support for Adobe Marketing Cloud v4.21.2 and Adobe Video Heartbeat v2.3.0.
-
Adds Mac Catalyst support for the SDK Core and SSAI plugin.
-
Each XCFramework now contains all supported platform binaries, for example, simulator and device binaries for iOS, tvOS and Mac Catalyst.
-
Adds a SharePlay sample project to the ios-sample-projects git repository.
-
Adds a Flutter sample project to the ios-sample-projects git repository.
Brightcove-Player-OpenMeasurement
is no longer installed by default with the SSAI Plugin. Addpod 'Brightcove-Player-OpenMeasurement'
to your Podfile to include it in your project.
- The deprecated
BCOVPlaybackController
propertythumbnailScrubbingEnabled
has been removed. UsethumbnailSeekingEnabled
instead.
-
Supports Low Latency HLS and Dolby Atmos playback.
-
Adds new audio-only playback control layouts for on demand, live and live-DVR audio. Refer to the Audio-Only Support section of the Core README for details.
-
Adds support for Mac Catalyst.
-
Adds support for the addition of custom localizations. Refer to the Custom Localization section of the Core README for details.
-
Fixes an issue where thumbnail images failed to download for offline viewing when a network disconnect occurred during the download.
-
Fixes an issue where using renewable FairPlay licenses with AirPlay caused unnecessary license renewals, leading to false errors.
Brightcove-Player-OpenMeasurement
is no longer installed by default with the SSAI Plugin. Addpod 'Brightcove-Player-OpenMeasurement'
to your Podfile to include IAB Open Measurement in your project.
-
Adds support for Mac Catalyst.
-
Fixes an issue where the player would sometimes fail to respond to the Apple TV Remote Menu button.
-
Brightcove-Player-OpenMeasurement
is not supported by Mac Catalyst apps. See the Open Measurement section of the SSAI README for details.
- Adds support for Generic Stream Concurrency.
- Legible and Audible media selections are now synchronized between the CAF receiver and AVPlayer (in addition to fixes made in 6.10.1).
- Fixes a crash when using the Pulse SDK with AVPlayerViewController.
-
Adds support for Fallback HDCP.
-
Adds support for enabling and disabling playback over cellular networks. See
allowsCellularPlayback
onBCOVGlobalConfiguration
. -
Since release 6.8.7, the SDK exposes the
AVPictureInPictureController
through thepictureInPictureController
property ofBCOVPlaybackController.h
. This addition was mistakenly absent from the original 6.8.7 release announcement. -
Fixes an issue where custom playback rates were not applied in some use cases.
-
Updates the TVPlayer README to clarify remote control gestures for Live and Live DVR playback.
- Legible and Audible media selections are now synchronized between the CAF receiver and AVPlayer.
-
Adds XCFramework plugins for Core, FreeWheel, GoogleCast, Omniture, Pulse and SSAI. IMA does not support XCFramework. The static SSAI framework is no longer available.
-
Adds XCFramework subspecs to the relevant plugin Podspecs. Refer to the Noteworthy section of the SDK Core README.
-
Adds the SwiftUI sample project which runs natively on iPad and Apple silicon Macs.
-
Fixes an issue where building with Universal Frameworks for iOS Simulator on Apple silicon Macs.
-
Adds support for
interstitialTimeRanges
when usingAVPlayerViewController
on tvOS. See the Advertising sub-section of Using an AVPlayerViewController with a BCOVPlaybackController for more information. -
Adds two new keys,
kBCOVAdPropertyKeyClickthroughURLs
andkBCOVAdPropertyKeyTrackingURLs
, for use with the BCOVAd'sproperties
dictionary. The keyskBCOVAdPrivatePropertyKeyClickthroughURLs
andkBCOVAdPrivatePropertyKeyTrackingURLs
will be removed from theprivateProperties
dictionary in a future SDK release. -
Fixes thumbnail seeking for some DRM-protected thumbnail assets.
-
Adds support for the 2nd generation Siri Remote for Apple TV.
-
Supports version 4.6.1 of the Google Cast SDK for iOS.
-
Supports the
no-bluetooth
version of the Google Cast SDK viaBrightcove-Player-GoogleCast/No-Bluetooth
orBrightcove-Player-GoogleCast-static/No-Bluetooth
subspecs.
- Supports Google Ads IMA SDK 3.14.4 for iOS and 4.4.2 for tvOS.
- Supports Pulse SDK 2.6.21.6.0 for iOS and tvOS.
- Removes the static SSAI framework. The
Brightcove-Player-SSAI-static
Podspec now installs the static Core framework with the dynamic SSAI framework.
- Supports Open Measurement SDK 1.3.22 for iOS.
-
Adds
playbackRate
toBCOVPlaybackController
to customize the playback speed of AVPlayer. See the Playback Rate section of the README for more information. -
Fixes an issue where the AirPlay button would not be visible when using
automaticControlTypeSelection
-
Fixes an issue where there would appear to be no video playback after the notification tray was brought down and then dismissed.
-
Fixes an issue where a FairPlay license request may not occur.
- Fixes a Main Thread Exception issue.
- Adds support for jump-backward and jump-forward buttons on the
GCKUIExpandedMediaControlsViewController
when using a Brightcove CAF receiver.
-
Fixes an issue with controls not being visible after advancing to the next video in a playlist after a post-roll ad completed.
-
Adds support for auto-hiding/showing the controls view when entering and exiting ad sequences on tvOS.
-
Fixes an issue where the
kBCOVPlaybackSessionLifecycleEventEnd
lifecyle event may not be triggered.
-
Fixes an issue where ad controls would lock up when starting an AirPlay session during ad playback.
-
Fixes an issue with thumbnail seeking.
-
If you install the Brightcove Native Player frameworks manually, be aware that the following header file names have changed to replace '+' characters with '-', for example,
NSDictionary+BCOVURLSupport.h
is nowNSDictionary-BCOVURLSupport.h
. The following header files have been renamed:NSDictionary-BCOVURLSupport.h
,BCOVPlayerSDKManager-BCOVFWAdditions.html
,BCOVSessionProviderExtension-BCOVFWAdditions.html
,BCOVPlayerSDKManager-BCOVIMAAdditions.html
,BCOVSessionProviderExtension-BCOVIMAAdditions.html
,BCOVSessionProviderExtension-BCOVPulseAdditions.html
,BCOVPlayerSDKManager-BCOVPulseAdditions.html
,BCOVSource-BCOVSSAIAdditions.html
,BCOVPlayerSDKManager-BCOVSSAIAdditions.html
andBCOVSessionProviderExtension-BCOVSSAIAdditions.html
. -
Future versions of the iOS SDK will be built using Xcode 12.5.1 or higher. Apps built with Xcode 12.4 and static versions of future Brightcove SDKs may report the following error during export and archive (the same error has not been seen for apps built with Xcode 12.4 and dynamic versions of Brightcove SDKs built with Xcode 12.5.1):
ld: could not reparse object file in bitcode bundle: 'Invalid bitcode version (Producer: '1205.0.22.11.0_0' Reader: '1200.0.32.29_0')', using libLTO version 'LLVM version 12.0.0, (clang-1200.0.32.29)' for architecture arm64
-
Adds support for Forensic Watermarking. Refer to Forensic Watermarking with Native SDKs.
-
Fixes UI issues observed when using
automaticControlTypeSelection
. -
Adds an example of modifying the AVAudioSession configuration at runtime based on the mute state of the AVPlayer. Refer to the VideoCloudBasicPlayer sample project.
-
Fixes FairPlay license preloading for online playback.
-
Fixes FairPlay license loading when downloading videos for offline playback.
-
Fixes FairPlay license renewal for offline video playback.
-
Fixes a crash that occurred when loading a DRM-protected video without a network connection (affects iOS and tvOS).
-
Fixes a crash that occurred when the network connection is lost during playback of a Live DRM-protected stream.
-
Fixes an issue where the progress slider was disabled after switching from a Live stream to a Live-DVR stream.
-
Migrates Video360 playback from OpenGL ES to Apple Metal to fix deprecation warnings.
-
Fixes a Main Thread Checker Exception which could occur when releasing an IMA Playback Session.
-
Fixes an issue where autoPlay could fail when using VMAP documents.
-
Fixes a delay when starting playback of a pre-roll ad with a live stream.
- Fixes an issue where video playback would not resume after a mid-roll ad sequence completed and Picture-in-Picture was active.
- Adds the new SubtitleRendering sample project which demonstrates how to find text tracks in a video manifest and render them in a separate view.
-
Exposes the
AVPictureInPictureController
through the newpictureInPictureController
property ofBCOVPlaybackController.h
. -
Fixes an issue where Picture in Picture could fail to start.
-
Fixes issues with the behavior of the
automaticControlTypeSelection
property ofBCOVPUIPlayerViewOptions
; the duration label could be missing from the UI, or the wrong controls layout could be auto-selected when an ad plugin plays a pre-roll ad. -
When
automaticControlTypeSelection
is enabled, the video and control views will be briefly hidden by an opaque, black overlay view between videos. Once the video-type of the next video has been detemined and the new control view is automatically selected, the black view will fade out. You can disable this new behavior by settingautomaticControlTypeSelectionUsesShutter
toNO
. You can also control the duration of the fade-out by settingautomaticControlTypeSelectionShutterFadeTime
.
-
Adds support for creating a
BCOVSource
from VMAP XML data. Refer to the Using VMAP XML data section of the SSAI README for details. -
Fixes an issue with
seekWithoutAds
when using the FairPlay plugin with SSAI in whichseekWithoutAds
could fail to call the completion handler.
-
Adds sample code to the CustomControls sample project which demonstrates a custom implementation of the built-in Audio and Subtitles control, often referred to as the "CC button".
-
Adds sample code to the VideoCloudBasicPlayer sample project which demonstrates one possible method for enabling and disabling AirPlay route detection which can reduce energy consumption.
-
Adds sample code to the BrightcoveCastReceiver sample project which demonstrates the use of the
playerURL
property of theBCOVReceiverAppConfig
class.
-
Fixes an issue where the
video_duration
value was not being passed with VODvideo_view
events. -
Fixes an issue where calling
-setVideos:
twice with the same DRM-protected video failed to play the second time. -
Fixes an issue where the AirPlay button might not appear after calling
BCOVPlaybackController
-setVideos:
, due to a missed update in AirPlay route detection. -
Fixes an issue where the ad countdown label could be missing for multi-ad sequences played on a small device. This problem primarily affected German localizations.
-
Adds the
BCOVPUIPlayerViewDelegate
method
-pictureInPictureController:restoreUserInterfaceForPictureInPictureStopWithCompletionHandler:
. -
Clarifies the documentation for FairPlay parameters used for downloading videos for offline viewing. See OfflinePlayback.md.
- Adds documentation for the
splashScreen
andplayerURL
properties of theBCOVReceiverAppConfig
class. Refer to the Brightcove CAF Receiver section of the GoogleCast plugin README.
-
Fixes an issue where a Main Thread Checker exception was raised by the IMA framework when releasing a BCOVPlaybackSession.
-
Fixes an issue where
kBCOVPlaybackSessionLifecycleEventAdSequenceExit
was not always sent.
- Adds examples of app localization to the VideoCloudBasicPlayer, BasicIMAPlayer, BasicSSAIPlayer and AppleTV sample projects.
-
Adds the
automaticControlTypeSelection
property toBCOVPUIPlayerViewOptions
andBCOVTVPlayerViewOptions
. Refer to the BCOVPUIPlayerViewOptions section of the Core SDK README for details. -
Fixes an issue where FairPlay license renewal was failing for downloaded videos.
-
Fixes an issue where the Audio & Subtitles button could fail to show when loading a video was delayed.
-
Fixes an issue where audio played but video could be black when an app was launched from a Universal Link.
-
Fixes an issue where dragging the progress slider to the start of a video set the playhead position to a time value greater than zero.
-
Fixes an issue where
kBCOVPlaybackSessionLifecycleEventEnd
failed to fire when an ad or ads failed to play. -
Fixes an issue where releasing an IMA Playback Session object could cause a UI background thread exception.
-
Adds support for the VMAP Tracking events
breakStart
andbreakEnd
. -
Fixes an issue where the VAST Tracking event
complete
was incorrectly fired when an ad was skipped.
- Nullability annotations have been added to BCOVVideo.h to resolve compile time warnings. You may need to use
guard let
orif let
in your Swift code to handle optionals.
- Deprecates
thumbnailScrubbingEnabled
. UsethumbnailSeekingEnabled
instead.
- Adds the
kBCOVFWLifecycleEventAdError
eventType to pass through errors encountered by the FreeWheel SDK. Refer to the Tracking FreeWheel Errors section of the Freewheel README for details.
- Fixes an issue where the
playerUrl
property of theBCOVReceiverAppConfig
was ignored.
-
Updates the IMA README to reflect deprecations, e.g.
registerVideoControlsOverlay
, in Google IMA SDK v3.12.1 for iOS. -
Adds Open Measurement example code to the BasicIMAPlayer sample project.
- Fixes an issue where
kBCOVPlaybackSessionLifecycleEventEnd
was posted before a postroll ad.
-
Adds an abbreviated ad time remaining label (e.g. "30s") to the built-in PlayerUI ad controls. This label is used only when the available width is at a minimum as is the case for some small iOS devices and syllable-verbose languages.
-
Adds the
vmapResponseData
property to the SSAI session object. Refer to the Access to VMAP Response Data section of the SSAI plugin README for details.
-
An
NSError
returned with akBCOVPlaybackSessionLifecycleEventError
event may now contain thekBCOVFPSAuthProxyResponseData
key in itsuserInfo
. -
Adds the
iFramePlaylistURL
property toBCOVVideo
to allow an iFrame (TrickPlay) playlist URL to be defined at runtime. Refer to the Thumbnail Scrubbing section of the Core SDK README for details. -
Fixes Automatic Picture in Picture compatibility with iOS 14.
-
Fixes an issue where an app in Picture in Picture mode closed the PiP view when advancing to the next video in a video playlist.
-
Fixes an issue where auto-advancing to an MP4 video in a playlist would not auto-play.
-
Fixes the
BCOVPlaybackController
methodresumeVideoAtTime:withAutoPlay:
. -
Improves resuming Live video streams after very long pauses.
-
Fixes an issue where the Video360 screen-mode button was not disabled when entering VR Goggles mode.
- Release 6.8.2 added support for setting a splash screen image URL. For example:
BCOVReceiverAppConfig *appConfig = [BCOVReceiverAppConfig new];
appConfig.splashScreen = @"https://host.company.com/images/cast-splash.jpg";
self.googleCastManager = [[BCOVGoogleCastManager alloc] initForBrightcoveReceiverApp:appConfig];
-
Adds the
kBCOVIMAOptionBlockAdTargetingAPIsKey
option to prevent the Brightcove IMA plugin from making calls to Apple's AdSupport and AppTrackingTransparency APIs. This can be helpful when submitting certain apps to the App Store. Refer to the Device Ad Targeting section of the IMA README for details. Refer also to the header comments of thecreateIMAPlaybackControllerWithSettings:
methods inBCOVIMAComponent.h
. -
Fixes an issue where
kBCOVPlaybackSessionLifecycleEventEnd
was not sent when a video played with no ads.
-
When a VMAP document cannot be found it will be reported by a
kBCOVPlaybackSessionLifecycleEventError
event with anNSError
having acode
property set tokBCOVSSAIErrorCodeVMAPMissingError
. -
Fixes an issue where VMAP documents could be requested twice.
- Fixes an issue where
kBCOVPlaybackSessionLifecycleEventEnd
would not be triggered when using anIMASessionProvider
with no ads configured.
- Exposes ad skip properties for all SDK ad plugins. Refer to
kBCOVAdPropertyKeySkippable
andkBCOVAdPropertyKeySkipTime
inBCOVAdvertising.h
.
-
Adds convenience methods for accessing Multilingual Metadata in a Playback API response. Refer to
localizedNameForLocale
,localizedShortDescriptionForLocale
andlocalizedLongDescriptionForLocale
inBCOVVideo
and note that these are C-style functions in keeping with the pattern ofNSLocalizedString
. Also adds theBCOVPlaybackControllerBasicDelegate
callback methodplaybackController:determinedMetadata:forVideo:
. -
Adds the
BCOVPlaybackControllerBasicDelegate
method-playbackController:determinedCodecs:forVideo:
to report the codecs in use during playback. -
Fixes an issue with custom progress bar thumb images on iOS 14.
-
Fixes issues with background audio on some devices running iOS 14.
-
Fixes an issue where a video manifest would be requested even if
thumbnailScrubbingEnabled
was set to false. -
Fixes an issue where subtitles were no longer visible after an app returned to the foreground.
-
Fixes an issue where a paused video resumed playing after swiping down to expose the tab bar menu on tvOS.
-
Fixes playback for some complex custom view strategies.
-
Reduces SDK startup time after videos have been downloaded to the device.
-
Supports version 6.38.0 of the FreeWheel AdManager framework for iOS and tvOS.
-
Fixes an issue where an incorrect ad duration value could be passed to a
BCOVFWSessionProviderAdContextPolicy
block.
- Adds support for setting a splash screen image URL. For example:
BCOVReceiverAppConfig *appConfig = [BCOVReceiverAppConfig new];
appConfig.splashScreen = @"https://host.company.com/images/cast-splash.jpg";
self.googleCastManager = [[BCOVGoogleCastManager alloc] initForBrightcoveReceiverApp:appConfig];
-
Adds support for VAST 4.1 AdVerification through integration of the IAB Open Measurement SDK (OM SDK) v1.3. Refer to
createSSAISessionProviderWithUpstreamSessionProvider:omidPartner:
in theBCOVSSAIAdditions
category ofBCOVPlayerSDKManager
inBCOVSSAIComponent.h
. Addition of the OM SDK has increased the file size of the SSAI dynamic framework by ~13 MB, and the static framework by ~18MB. -
Fixes an issue where the browser view displayed in response to tapping a companion ad was transparent on iPad devices.
- Some Brightcove Player SDK Podspecs have been updated which might affect your project Podfile. Refer to the Noteworthy section of the SDK Core README.
-
Fixes an issue where Rebuild from Bitcode failed during Distribution, Validation and App Store submission for apps built with dynamic Brightcove frameworks.
-
Fixes some Podspecs to allow the IMA and Omniture plugins to be used together.
- The property
externalRouteView
onBCOVPUIBasicControlView
has been renamed toexternalRouteViewButton
and is now aBCOVPUIButton
.
- Fixes the AirPlay button accessibility label.
- Fixes a memory leak which could cause a video to continue playing after its view controller had been dismissed.
-
Adds the
BCOVTVPlayerViewDelegate
methodsplayerDidBeginFastForward
,playerDidEndFastForward
,playerDidBeginFastRewind
andplayerDidEndFastRewind
to indicate the start and end of fast-forwarding and fast-rewinding. -
Improves reporting of FairPlay errors which are now passed as
kBCOVPlaybackSessionLifecycleEventError
lifecycle events. -
Fixes an issue where the use of Sidecar Subtitles caused the video to fail to play for some Dynamic Delivery accounts.
-
Fixes an issue where the status of a terminated download was incorrectly reported as complete. Downloads are terminated when the app is terminated, for example by swiping up.
-
Fixes an issue where
BCOVVideo -playableoffline
always returnedNO
on iOS 14. -
Fixes the appearance of the player progress bar on iOS 14.
-
Fixes an issue where
kBCOVPlaybackSessionLifecycleEventFail
was not posted for bad video source URL's on iOS 11. -
Fixes an issue where rental licenses (dual expiry licenses) prevented playback on iOS 11.4.
-
Adds support for the Brightcove CAF Receiver. See the Brightcove CAF Receiver section of the Google Cast Plugin README for more information.
-
Supports version 4.5.0 of the Google Cast SDK for iOS. See the iOS Permissions Changes page for information about permission changes for iOS 14 and how they play into the Google Cast SDK.
-
Fixes an issue where AirPlay failed to play EPA enabled content on 3rd and 4th generation Apple TV devices.
- As a result of new support for Google Ads IMA SDK 3.12.1 for iOS and 4.3.2 for tvOS, all
BCOVPlayerSDKManager(BCOVIMAAdditions)
category methods now require theUIViewController
of the IMA ad container view to be passed as an additional parameter. Refer to the BCOVPlayerSDKManager(BCOVIMAAdditions) Category Reference page. Refer also to Section 3.12.0 of the Google IMA iOS SDK release history.
-
Adds support for App Tracking Transparency for Google Interactive Media Ads SDK 3.12.1 for iOS and 4.3.2 for tvOS. See Request App Tracking Transparency authorization for more information.
-
Corrects the value of
is_lat
for the purpose of Ad Tracking.
-
Adds the
kBCOVPlaybackSessionLifecycleEventAdSkipped
lifecycle event type to allow for detecting when a user has skipped an ad. -
Fixes an issue where VMAP documents were requested twice.
- Fixes the behavior of the Audio and Subtitles control in the presence of Live passthrough captions (608).
-
Adds the
BCOVTVPlayerViewDelegate
methodliveIndicatorViewForIsPlaying:atLiveEdge:
to allow for customization of the DVR Live indicator. -
Adds the
BCOVPlaybackControllerDelegate
methodplaybackController:playbackSession:didChangeSelectedAudibleMediaOption
to be notified when the audible media option for the current video is changed. -
Adds the
BCOVPlaybackControllerDelegate
methodplaybackController:playbackSession:didChangeSelectedLegibleMediaOption
to be notified when the legible media option for the current video is changed. -
Fixes an issue where BCOVPlaybackSessionLifecycleEvent
kBCOVPlaybackSessionLifecycleEventReady
orkBCOVPlaybackSessionLifecycleEventFail
sometimes failed to reach theBCOVPlaybackController
delegate. -
Fixes an issue where subtitles set with the Sidecar plugin could cause subsequent videos in a playlist to not play.
-
Improves the appearance of the built-in TV Player Controls and the handling of Siri Remote gestures.
-
Adds Objective-C and Swift sample projects for playing IMA preroll ads with Live SSAI streams. See SSAI/SLS_IMA-Player and SSAI/SLS_IMA-tvOSPlayer in brightcoveos/ios-player-samples.git on GitHub.
- Fixes an issue where playback controls remained hidden after an ad failed to play when using a VAST ad profile.
-
Adds the optional
BCOVGoogleCastManagerDelegate
methodwillBuildMediaInformationBuilder:
to allow for additional configuration of theGCKMediaInformationBuilder
object. -
Adds the optional
BCOVGoogleCastManagerDelegate
methoduseSourceFromSources:
to allow for custom source selection. -
Adds the optional
BCOVGoogleCastManagerDelegate
methodwillSendMediaLoadOptions:
to allow for additional configuration of theGCKMediaLoadOptions
object. -
Adds the optional
BCOVGoogleCastManagerDelegate
methodshouldCastVideo:
to allow for customization of cast behavior.
-
Fixes an issue where, while using an AVPlayerViewController, video could appear to freeze after a few seconds while audio continued to play.
-
Fixes a crash in Sidecar Subtitles Playback Session Provider caused by an unexpected WebVTT text track.
-
Fixes a crash that could occur when calling
setVideos:
multiple times onBCOVPlaybackController
. -
Fixes a crash that could occur when an application certificate is not available during Fairplay license processing.
-
Fixes an issue where a Fairplay video might not play back when using certain session providers.
- Removes the
offlineVideoToken:didFinishAggregateDownloadWithError:
method of theBCOVOfflineVideoManagerDelegate
protocol.
-
Resolves App Store submission issues related to use of the IDFA (Identifier for Advertisers) by moving those references out of the Core SDK framework.
-
Fixes an issue where playback of DRM-protected content could stop in mid-play when using certain authorization schemes.
-
Adds support for customizing the layout of thumbnail previews. See
playerViewShouldDisplayThumbnailPreviewWithSize:
on theBCOVTVPlayerViewDelegate
protocol andplayerViewShouldDisplayThumbnailPreviewWithRect:
on theBCOVPUIPlayerViewDelegate
protocol for more information. -
Fixes an issue where the player layer of a custom view strategy was not updated as needed, resulting in a black video display. Updates the View Strategy section of the Core SDK README. Provides a new ViewStrategy sample project in PlayerUI/ViewStrategy of the ios-sample-projects.git git repository.
- Adds bitcode to the tvOS framework to fix app submission.
- Several Brightcove Player SDK Podspecs have been renamed which might affect your project Podfile. Refer to the Noteworthy section of the SDK Core README.
-
Updates the
Brightcove-Player-Core
podspec to install the dynamic SDK Core framework. To install the static framework, reference theBrightcove-Player-SDK-static
podspec instead. -
Fixes an issue where use of a custom layout prevented scrubbing.
-
Fixes an issue where occasionally, a downloaded video could not be played while off-line.
-
Adds support for IMA pre-roll ads with SSAI live streams on iOS and tvOS.
-
Adds support for version 3.11.4 of the Google IMA SDK for iOS.
-
Adds support for version 4.2.3 of the Google IMA SDK for tvOS.
-
Updates the
Brightcove-Player-SSAI
podspec to install the dynamic SSAI framework. To install the static framework, reference theBrightcove-Player-SSAI-static
podspec instead. -
Improves the behavior of seeking around ads and Seek Without Ads.
- Updates the
Brightcove-Player-GoogleCast
podspec to install the dynamic Core framework. To install the static Core framework, reference theBrightcove-Player-GoogleCast-static
podspec instead.
-
Adds the optional
BCOVPUIPlayerViewDelegate
methodsprogressSliderDidTouchDown:
,progressSliderDidChangeValue:
andprogressSliderDidTouchUp:
for iOS. -
Adds the optional
BCOVTVPlayerViewDelegate
methodsprogressViewPanGestureStateBegan:
,progressViewPanGestureStateChanged:
andprogressViewPanGestureStateEnded:
for tvOS. -
Adds support for dual expiry for offline FairPlay protected videos. Refer to the Download a Video section of OfflinePlayback.md for more information.
-
Fixes an issue on tvOS where audio would continue to play after a player view had been removed from the view heirarchy.
- Adds support for pre-roll and post-roll ad playback over AirPlay. Set
enableBackgroundPlayback
toYES
onIMASettings
along with enabling AirPlay on yourBCOVPlaybackController
. Refer to the AirPlay section of the README for more information.
-
Fixes a fatal exception on tvOS caused by multiple app launches.
-
Adds support for preloading content keys for online FairPlay protected videos. See
preloadContentKeysForVideos:
onBCOVFairPlayManager
for more information. -
Improves support for right-to-left languages.
-
Adds support for localized number values.
-
Fixes an issue where the Captions button was hidden after changing the controls layout.
-
Fixes an issue where
offlineVideoToken:aggregateDownloadTask:didProgressTo:forMediaSelection:
was not being called after an app was moved from the background to the foreground.
-
Adds the ability to pause and resume ads with support for Pulse PauseAd.
-
Supports seeking without ads (resume).
-
Fixes post-roll ad playback on tvOS.
-
Improves handling for various error conditions such as bad ad paths.
-
Improves support for right-to-left languages.
-
Adds support for the Brightcove Playback Rights Management Service.
-
Adds support for HEVC and HLSv7 video playback.
-
Adds new localizations for Arabic (ar), French (fr), German (de), Japanese (ja), Korean (ko) and Spanish (es).
- Adds new support for integrating Pulse Video Advertising with your iOS and tvOS apps.
-
Supports version 3.11.3 of the Google IMA SDK for iOS.
-
Supports version 4.2.1 of the Google IMA SDK for tvOS.
-
Fixes an issue where
kBCOVIMALifecycleEventAdsLoaderLoaded
was not triggered for VAST ad profiles.
- Adds improvements to some video analytics.
- The minimum Deployment Target for all Brightcove Native Player for iOS frameworks is now iOS 11.0 and tvOS 11.0.
- Fixes an issue with apps crashing during launch on iOS Simulators running iOS 11 and 12 (
dyld: Symbol not found: _OBJC_CLASS_$_AVAssetDownloadURLSession
). The exception to the fix is apps built with the Google Cast SDK for iOS CocoaPod due to an issue with the google-cast-sdk Podspec. To work around the issue, for example in the Brightcove BasicCastPlayer sample project for Objective-C, follow these steps:
- Run
pod install
- Open the BasicCastPlayer.xcworkspace document
- In the Xcode Project Navigator, navigate to Pods -> Target Support Files -> Pods-BasicCastPlayer
- In the files Pods-BasicCastPlayer.debug.xcconfig and Pods-BasicCastPlayer.release.xcconfig change this line:
OTHER_LDFLAGS = $(inherited) -ObjC -l"c++" -framework "AVFoundation" -framework "Accelerate" -framework "AudioToolbox" -framework "BrightcoveGoogleCast" -framework "BrightcovePlayerSDK" -framework "CFNetwork" -framework "CoreBluetooth" -framework "CoreData" -framework "CoreGraphics" -framework "CoreMedia" -framework "CoreText" -framework "Foundation" -framework "GoogleCast" -framework "MediaAccessibility" -framework "MediaPlayer" -framework "QuartzCore" -framework "Security" -framework "SystemConfiguration" -framework "UIKit" -framework "protobuf"
to this:
OTHER_LDFLAGS = $(inherited) -ObjC -l"c++" -framework "BrightcovePlayerSDK" -framework "BrightcoveGoogleCast" -framework "GoogleCast" -framework "protobuf"
- Adds support for short-duration license renewal for FairPlay protected videos. See
updateLicenseRenewalInterval:
onBCOVPlaybackController
for more information.
-
Fixes an issue that could prevent downloads from starting immediately when using
BCOVOfflineVideoManager
. -
Adds the
playbackController:determinedVideoType:forVideo:
delegate method toBCOVPlaybackController
. See theBCOVPlaybackController
header for more information, including all available types ofBCOVVideoType
. -
Updates header documentation for the
BCOVVideo.playableOffline
property which can have an unexpected value when the video is loaded for playback.
- Adds support for setting Audience Segment Targeting information on ad requests. See
updateAudienceSegmentTargetingValues:
inBCOVPlaybackController
for more information. This is currently only supported when using IMA + VAST.
- Fixes scrubbing behavior when using BCOVPlayerUI player controls and the SSAI plugin to play back VOD.
- Fixes bitcode embedding.
-
Adds support for the Brightcove Playback Rights Management Service which is in Limited Availability.
-
Deprecates support for iOS 10 and tvOS 10 in the Core SDK and all plugin frameworks. Support for iOS 10 and tvOS 10 will end in the near future.
- Removes strings generated by Xcode Project Versioning as those settings are not used for SDK versioning. Version strings were declared in the SDK framework umbrella headers, for example, in BrightcovePlayerSDK.h:
FOUNDATION_EXPORT const unsigned char BrightcovePlayerSDKVersionString[];
- Deprecates support for downloading secondary tracks as a separate download request (
requestVideoDownload:parameters:completion:
andrequestMediaSelectionsDownload:offlineVideoToken:
). Update your apps to the newest download method described in the "Downloading Secondary Tracks" section of OfflinePlayback.md.
- Removes deprecated method
renewFairPlayLicense:parameters:completion
fromBCOVOfflineVideoManager
.
- After requesting a video download, the download can delay for several minutes. To work around this issue, implement the BCOVOfflineVideoManagerDelegate method,
didCreateSharedBackgroundSesssionConfiguration:
, and set thediscretionary
property of thebackgroundSessionConfiguration
object toNO
. A permanent fix will be released in the near future.
- (void)didCreateSharedBackgroundSesssionConfiguration:(NSURLSessionConfiguration *)backgroundSessionConfiguration
{
backgroundSessionConfiguration.discretionary = NO;
}
- Adds support for tvOS.
- Adds the
prepareForReuse
method to clean up state of aBCOVGoogleCastManager
instance if shared across view controllers.
- Deprecates support for
sharedManager
. In a future release,BCOVGoogleCastManager
will need to be instantiated explicitly.
-
Fixes an issue where the
didChangeSeekableRanges
delegate method was not being called. This issue first appeared in SDK release 6.6.0. -
Fixes an issue where the
kBCOVPlaybackSessionLifecycleEventReady
lifecycle event might be sent in response to seek starts and ends.
- Fixes an issue where successive calls to
BCOVPlaybackController -setVideos:
on a singleBCOVPlaybackController
caused resource leaks which could result in an app crash.
-
Reduces the file size of the dynamic framework by ~10MB, and ~20MB for the static framework.
-
Reduces CPU load up to 40% when playing video, decreases memory usage by up to 10%, and decreases energy usage by up to 30%.
-
Fixes an issue causing default captions to not be automatically selected. Note that the default caption may not be selected when the user has enabled "Closed Captions + SDH".
-
Fixes an issue where tapping the LIVE button on a paused live video did not begin playback after seeking to the live edge.
-
Fixes an issue when retrying a download of secondary tracks after a previous attempt resulted in a failure.
-
Enables playback of an IMA pre-roll ad with Live HLS streams.
-
Adds functionality to specify an initial selection when setting bitrate options along with the ability to programmatically set a preferred bitrate. Refer to the "Setting a Preferred Bitrate" section of the README for more information.
-
Removes a reference to the deprecated UIWebKit.
-
The Offline Downloads API has changed for iOS 13+. Refer to the "Downloading Secondary Tracks" section of OfflinePlayback.md for details.
-
The minimum tvOS Deployment Target for all Brightcove Native Player for tvOS frameworks is now tvOS 10.0.
-
Support for
BCOVBasicSessionLoadingPolicy
has been removed. Refer to the "Preloading Videos" section of the README for guidance on using multiple playback controllers to achieve a preloading effect. -
Requires Xcode 11+.
-
Fixes an issue where the delegate method
playbackController:playbackSession:didExitAd:
was not being triggered when an applicable IMA ad was skipped. -
Fixes an issue where ads were not replayed when
ignoringPreviouslyProcessedCuePoints
onBCOVCuePointProgressPolicy
was disabled.
- Support for Xcode 10 has been deprecated and Brightcove SDK releases after 6.5.0 will require you to build your apps with Xcode 11+.
-
Adds support for Live streams with FairPlay DRM. Refer to the Live DRM support pages.
-
Adds localizations for traditional Chinese (zh-hant) and simplified Chinese (zh-hans) language scripts.
-
Fixes an issue causing the duration and progress labels to display in Times New Roman on devices running iOS 13.
-
Fixes the public declarations of Playback Session lifecycle event types
kBCOVPlaybackSessionLifecycleEventPlayRequest
,kBCOVPlaybackSessionLifecycleEventPauseRequest
,kBCOVPlaybackSessionLifecycleEventAdSequenceEnter
,kBCOVPlaybackSessionLifecycleEventAdSequenceExit
,kBCOVPlaybackSessionLifecycleEventAdEnter
,kBCOVPlaybackSessionLifecycleEventAdExit
,kBCOVPlaybackSessionLifecycleEventAdProgress
,kBCOVPlaybackSessionLifecycleEventAdPause
andkBCOVPlaybackSessionLifecycleEventAdResume
which can be found in the framework header BCOVPlaybackSession.h.
- Supports version 4.4.5 of the Google Cast SDK for iOS.
- Adds support for Live Streams with Server-Side Ad Insertion. Refer to the Overview: Advanced Player Toolkit for Live SSAI pages for details.
- Fixes an exception which occurred when calling
setVideos:
more than once for a singleBCOVPlaybackController
object. The exception error message includes the textException 'Cannot remove an observer...
.
-
Extends support for Picture-in-Picture by adding
showPictureInPictureButton
toBCOVPUIPlayerViewOptions
. When set to true, a Picture-in-Picture button will be added to the player controls on supported devices. Refer to the VidoCloudBasicPlayer sample project for example code. -
Adds support for AirPlay 2. Refer to the AirPlay section of the SDK Core README for details on adding AirPlay 2 support to your apps.
-
Adds the optional BCOVTVPlayerViewDelegate method
- (BOOL)playerViewShouldRequireLinearPlayback:(BCOVTVPlayerView *)playerView;
. Refer to the BCOVTVPlayerViewDelegate reference. -
Fixes an issue where setting the BCOVPlaybackController
shutter
property from a non-main thread generated an exception.
- Removes the
defaultControlsViewStrategy
option onBCOVPlayerSDKManager
. Use the built-in PlayerUI controls instead; see the Built-In PlayerUI Controls section in the README for details.
- Fixes a crash which occurred when getting or setting the
shutter
property of the BCOVPlaybackController from a non-main thread.
- Release 6.4.3 of the Brightcove Player SDK for iOS deprecates BrightcoveOUX, replacing it with the SSAI Plugin for Brightcove Player SDK for iOS. Refer to the OnceUX or SSAI README for instructions on migrating your app to the new BrightcoveSSAI framework.
-
Adds support for VoiceOver to the built-in BCOVTVPlayerUI controls.
-
Adds the
BCOVTVAccessibilityDelegate
protocol to allow customization of some accessibility labels.
-
Supports version 3.9.0 of the Google IMA SDK for iOS.
-
Adds default values for the
playerType
andplayerVersion
properties of the IMASettings object.
-
Introduces the SSAI Plugin. Refer to the OnceUX or SSAI README for instructions on migrating your apps to the new BrightcoveSSAI framework.
-
Provides access to the VMAP data retrieved in response to a
-setVideos:
call to the Playback Controller. Refer to the SSAI README for details. -
Fixes an issue which could cause rewind or jump-back to fail, and which could prevent a preroll ad from playing.
-
Deprecates the OnceUX Plugin. Support for OnceUX is now provided by the SSAI Plugin for Brightcove Player SDK for iOS. Refer to the README for information on migrating your apps to BrightcoveSSAI.
-
Provides access to the VMAP data retrieved in response to a
-setVideos:
call to the Playback Controller. Refer to the OnceUX README for details. -
Fixes an issue which could cause rewind or jump-back to fail, and which could prevent a preroll ad from playing.
-
Adds support for the Brightcove Playback Authorization Service.
-
Fixes an issue where
player_width
andplayer_height
were being reported as 0 in analytics for 360° videos. -
Fixes an issue where the fullscreen toggle button remained visible after entering VR Goggles mode for 360° videos.
-
Adds constants for common values in property/paramater dictionaries. You can find these near the top of:
- BCOVAnalytics.h
- BCOVAnalyticsSession.h
- BCOVCuePoint.h
- BCOVPlaybackService.h
- BCOVPlaylist.h
- BCOVSource.h
- BCOVVideo.h
-
BCOVBasicSessionLoadingPolicy has been deprecated. Refer to the
Preloading Videos
section of the README for guidance on using multiple playback controllers to achieve a preloading effect.
-
Fixes an issue where the
creativeView
ad tracking event could be reported twice for each ad. -
Adds ability to obtain VMAP data after it has been recieved by observing the
kBCOVOUXVMAPResponseReceivedNotification
(nowkBCOVSSAIVMAPResponseReceivedNotification
) notification.
-
Adds support for VoiceOver to the built-in BCOVPlayerUI controls.
-
Removes the
kBCOVOfflineVideoManagerHTTPMaximumConnectionsPerHostKey
option to BCOVOfflineVideoManager initialization. Use the BCOVOfflineVideoManagerDelegate-didCreateSharedBackgroundSesssionConfiguration:
method instead.
- Adds support for honoring the video Advertising setting (Free or Ad Supported).
- Adds support for honoring the video Advertising setting (Free or Ad Supported).
- The minimum iOS Deployment Target for all Brightcove Native Player for iOS frameworks is now iOS 10.0.
-
Adds functionality to select a preferred peak bitrate for AVPlayer. Refer to the
Setting a Preferred Bitrate
section of the README as well as thepreferredBitrateConfig
property on theBCOVPUIPlayerViewOptions
class. -
Fixes an issue where the status information of offline video downloads was being deleted. This issue is present only in Release 6.3.11.
- Adds new support for integrating Google Cast with your application.
-
Adds support for tvOS.
-
Supports version 6.26.0 of the FreeWheel AdManager framework for iOS and tvOS.
-
Removes references to UIWebView.
-
Fixes an issue where the status information of offline video downloads was being deleted. This issue is present only in Release 6.3.11.
- Supports IMA 3.11.3 for iOS which, among other improvements, removes references to UIWebView. When running on an iOS 9.x device, configure IMAAdsRenderingSettings to use Safari when opening landing pages in response to taps on "Learn More" or companions ads.
IMAAdsRenderingSettings *renderSettings = [[IMAAdsRenderingSettings alloc] init];
renderSettings.webOpenerPresentingController = nil;
renderSettings.webOpenerDelegate = self; // optional
-
Fixes an issue where the BCOV Offline Video Manager failed to detect the deletion of videos via the device Settings app (General --> iPhone (or iPad) Storage).
-
Clarifies documentation for the
BCOVVideo.playableOffline
property.
- Fixes a documentation error in the BCOVOfflineVideoStatus Class Reference.
-
Supports version 6.25.0 of the FreeWheel AdManager framework for iOS.
-
Fixes an issue where, while looping a video with postroll ads, the lifecycle event kBCOVPlaybackSessionLifecycleEventEnd was sent only the first time the video reached its end.
- Fixes an issue with video downloads in which the load on the main thread increased as the number of stored videos increased.
- Fixes an issue where requesting a download of a rented video would fail FairPlay authentication in some regions when 24-Hour Time was turned off in the device Date & Time settings (Settings -> General -> Date & Time).
- Corrects the release version number.
-
Improves performance of the BCOVOfflineVideoManager method
-videoObjectFromOfflineVideoToken:
. -
Fixes a crash which could occur while downloading videos for offline viewing.
-
Fixes a crash which could occur when a video failed to load.
- The Brightcove Native Player for iOS now requires Xcode 9.0 or higher.
-
Adds SDK Reference documentation for built-in tvOS player controls (
BCOVTVPlayer
). -
Fixes an issue where downloading secondary tracks could cause an additional, unrequested video rendition to be downloaded.
-
Fixes the declaration of the Closed Caption button in BCOVPlayerUI.
-
Adds BCOVAttributions.h, acknowledging open source software which may be contained in some portions of the Brightcove Native Player SDK.
-
Fixes an issue with Sidecar Subtitles where text tracks added to a manifest with pre-existing text tracks were not available to the user. Affects Dynamic Delivery only.
- Fixes an issue where a
BCOVVideo
with a singleBCOVSource
failed to play when theBCOVSource
'sdeliveryMethod
was not set tokBCOVSourceDeliveryHLS
orkBCOVSourceDeliveryOnce
.
-
The TV Player UI now supports playback of live and live DVR streams with controls specific to each type of stream.
-
The
BCOVTVPlayerView
class has a newplayerType
property, of typeBCOVTVPlayerType
. This property lets you specify whether the TV Player View will be used for VOD, live, or live DVR presentation. -
The
BCOVTVPlayerType
enumeration was added to let you specify VOD, live, or live DVR playback in the TV Player UI. The enumerated values areBCOVTVPlayerTypeVOD
for video-on-demand,BCOVTVPlayerTypeLive
for live, andBCOVTVPlayerTypeLiveDVR
for live DVR playback. -
Fixes an issue in the Offline Video Manager where a download stopped by the user by terminating the app would result in a
downloadState
set toBCOVOfflineVideoDownloadStateCompleted
instead ofBCOVOfflineVideoDownloadStateTracksError
in its associatedBCOVOfflineVideoStatus
object.
- Fixes an issue where HTTP video sources could be selected over HTTPS sources. HTTPS is the preferred source.
-
Supports version 6.22.0 of the FreeWheel AdManager framework for iOS.
-
Fixes an issue where a
videoView
event was sent before theslotImpression
event when preroll ads were present.
Additions and improvements in the BCOVOfflineVideoManager
class.
FairPlay License Renewal
- (void)renewFairPlayLicense:(BCOVOfflineVideoToken)offlineVideoToken
video:(BCOVVideo *)video
parameters:(NSDictionary *)parameters
completion:(void (^)(BCOVOfflineVideoToken offlineVideoToken, NSError *error))completionHandler;
This method, used for renewing the FairPlay license for an offline video, replaces the older method wtihout a video
parameter. The video parameter is a recently retrieved BCOVVideo
object from the Playback API or Playback Service class, and is used to provide updated key server exchange URLs. Key server URLs are set to expire after a certain amount of time, so this method will allow you to renew your licenses even after the original URLs have expired.
FairPlay License Invalidation
- (void)invalidateFairPlayLicense:(BCOVOfflineVideoToken)offlineVideoToken;
This method allows you to invalidate a FairPlay license before the license has expired, by deleting the license from storage. This is a secure way to make sure that the video is not playable on the device. If desired, a new license can be acquired using the renewFairPlayLicense:video:parameters:completion:
method above.
A new error code, kBCOVOfflineVideoManagerErrorCodeInvalidLicense
will be returned in a playback session lifecycle event of type kBCOVPlaybackSessionLifecycleEventFail
if you attempt to play a video with an invalid license.
FairPlay License Expiration Retrieval
- (NSDate *)fairPlayLicenseExpiration:(BCOVOfflineVideoToken)offlineVideoToken;
This method provides a convenient way to determine the date and time at which the video will no longer be playable. Normal FairPlay rental licenses return an NSDate
object representing the expiration of the license. A purchase license, or videos without FairPlay, will return NSDate.distantFuture
.
If the license was invalidated, or was never acquired, this method will return nil.
Other Improvements
- Improves task resume behavior for aggregate track downloads (secondary audio and caption tracks). Previously, a paused aggregate track download may not have been able to resume downloading if it was paused.
In the BCOVOfflineVideoManager class, this method has been deprecated.
- (void)renewFairPlayLicense:(BCOVOfflineVideoToken)offlineVideoToken
parameters:(NSDictionary *)parameters
completion:(void (^)(BCOVOfflineVideoToken offlineVideoToken, NSError *error))completionHandler;
A similar method with a new video
parameter is now available for renewing a FairPlay license:
- (void)renewFairPlayLicense:(BCOVOfflineVideoToken)offlineVideoToken
video:(BCOVVideo *)video
parameters:(NSDictionary *)parameters
completion:(void (^)(BCOVOfflineVideoToken offlineVideoToken, NSError *error))completionHandler;
You can pass nil
as the video
parameter, but if you do, this method will no longer work after the URLs from the original downloaded video have expired.
We recommend you always pass a BCOVVideo
object that was recently retrieved from the Playback API or Brightcove Service class as the video
parameter.
-
Supports version 3.7.0 of the Google IMA SDK for iOS. The Podspec for the IMA Plugin for Brightcove Player SDK for iOS references version 3.7.0.1 of the Google IMA iOS SDK as instructed by the IMA Release History.
-
Adds the ability to modify an IMAAdsRequest object immediately before the IMA Plugin calls the
IMAAdsLoader -requestAdsWithRequest:
method. For details, refer to the "Modifying the IMAAdsRequest" section of the Brightcove IMA Plugin README.
- VAST 3.0 CreativeExtensions embedded in an ad are now accessible through the
BCOVAd
's properties dictionary. The header file BCOVOUXConstants.h has sample code showing how to access these values.
Adds a new method to the BCOVOfflineVideoManagerDelegate
protocol:
- (void)didCreateSharedBackgroundSesssionConfiguration:(NSURLSessionConfiguration *)backgroundSessionConfiguration;
This method is called after the background NSURLSessionConfiguration
object is created, and before it's used to create the shared AVAssetDownloadURLSession
object that's used to download videos. You can use this configuration object to set various options specified for the NSURLSessionConfiguration in NSURLSession.h, such as the discretionary
flag, or the HTTPMaximumConnectionsPerHost
setting.
You should not set the allowsCellularAccess
property; that is set through the kBCOVOfflineVideoManagerAllowsCellularDownloadKey
setting passed to -initializeOfflineVideoManagerWithDelegate:options:
.
- Fixes an issue where the HTTP version of some WebVTT URLs was being used instead of HTTPS. This only occurred when using Sidecar Subtitles with a legacy Video Cloud account.
Version 6.3 of the Brightcove Native Player SDK includes built-in controls for playback in tvOS on Apple TV. For full details about using the built-in TV Player UI with the Brightcove Native Player SDK, see our TV Player guide.
- The
BCOVPlaybackSessionProvider
protocol method-(id)playbackSessionsForVideos:
has been deprecated. This method had no practical use so no code changes are required in your app.
- Fixes an issue where pre-roll ads would re-play after seeking to the start of the video when using an IMA ads request policy (
BCOVIMAAdsRequestPolicy
) with aBCOVCuePointProgressPolicy
for which theignoringPreviouslyProcessedCuePoints
parameter is set to YES. - Fixes an issue where some VMAP URLs would cause the Google IMA library to crash when a post-roll was played.
Adds the ability to renew FairPlay licenses for downloaded videos without re-downloading the video. To support these feature, there are a few new items in BCOVOfflineVideo.h:
The following method lets you renew the FairPlay license by specifying new license terms along with the offline video token.
- (void)renewFairPlayLicense:(BCOVOfflineVideoToken)offlineVideoToken
parameters:(NSDictionary *)parameters
completion:(void (^)(BCOVOfflineVideoToken offlineVideoToken, NSError *error))completionHandler;
The kBCOVOfflineVideoLicenseAbsoluteExpirationTimePropertyKey
is used to obtain the absolute expiration time of an offline BCOVVideo
object that uses a FairPlay rental license.
extern NSString * const kBCOVOfflineVideoLicenseAbsoluteExpirationTimePropertyKey;
Previously downloaded videos wll not have this property, but it will be added once the license is renewed.
- Fixes an issue where FairPlay licenses could not be generated on devices using non-Gregorian calendars.
- Fixes an issue where FairPlay rental licenses did not respect the set duration. To ensure that licenses have been issued properly for your users' content, we recommend renewing any FairPlay license issued using version 6.2.1 or earlier of the Brightcove SDK. License renewal will not require the video to be downloaded again. (Tip: if a downloaded video does not have the
kBCOVOfflineVideoLicenseAbsoluteExpirationTimePropertyKey
property, its license should be renewed.) - Fixes an issue that caused apps using the Brightcove SDK to crash when running on iOS 9.
- Fixes an issue where VTT files containing extra empty lines could crash when downloaded and played back on iOS 10 (Sideband Subtitles).
- The minimum iOS Deployment Target for all Brightcove Native Player for iOS frameworks is now iOS 9.0.
Adds the ability to store playback analytics for videos that have been downloaded and played while offline. Analytics are transmitted to Brightcove servers once the device comes back online.
A few new items are added to support this feature:
-
kBCOVOfflineVideoManagerAnalyticsStorageFullWarningNotification
is a new NSNotification name that you can register to observe. This notification is sent when the storage for offline analytics has reached a prescribed limit (500 MiB by default). When this occurs, you have the option of encouraging your user to go back online, at which point stored analytics data will be sent to Brightcove servers. -
kBCOVOfflineVideoManagerAllowsCellularAnalyticsKey
is the dictionary key for a setting passed to the Offline Video Manager when it is initialized. You can pass @(YES) to allow analytics collected while offline to be transferred over a cellular connection. Pass @(NO) to only transfer over a WiFi connection. This setting is optional, and the default value is @(YES). -
kBCOVOfflineVideoManagerAnalyticsStorageLimitKey
is the dictionary key for a setting passed to the Offline Video Manager when it is initialized. This setting is an NSNumber that determines the maximum amount of storage space (in Bytes) that will be allowed for storing analytics collected for videos played offline. The default value is 500 MiB, and may be set as low as 1 MiB. When the limit is reached, only video_view events will be stored, and other events will start being dropped.
- Adds support for Adobe Marketing Cloud v4.14.1 and Adobe Video Heartbeat v2.0.1.
-
The
BCOVCatalogService
, also referred to as the Brightcove Media API, has reached end-of-life status and been removed from the Brightcove Native Player SDK. If your app uses the BCOVCatalogService, you must update it to use the BCOVPlaybackService. -
You can no longer download caption files using Sideband Subtitles in iOS 11. Sideband Subtitles is a workaround for incomplete track download support in iOS 10. As a result, you can no longer pass
kBCOVOfflineVideoManagerSubtitleLanguagesKey
as an option when requesting a video download. iOS 11 supports downloading of both subtitle and audio tracks; see "Addtions and Improvements" below for more details. Caption tracks that were downloaded using Sideband Subtitles will continue to play correctly on iOS 11.
-
The
BCOVPlayerSDKManager
has a newversion
class method which returns an NSString containing the SDK version. -
When developing for iOS 11 and later, in addition to HLS videos, you can download all secondary caption and audio tracks using iOS 11's new AVAggregateAssetDownloadTask class. This support includes the folowing changes:
The BCOVOfflineVideoDownloadState
enumeration adds the following values:
/* iOS 11+ only: Download of extra tracks requested but not yet reporting progress */
BCOVOfflineVideoDownloadStateTracksRequested = 7,
/* iOS 11+ only: Download of extra tracks is progressing normally */
BCOVOfflineVideoDownloadStateTracksDownloading = 8,
/* iOS 11+ only: Download of extra tracks was paused */
BCOVOfflineVideoDownloadStateTracksSuspended = 9,
/* iOS 11+ only: Download of extra tracks completed normally */
BCOVOfflineVideoDownloadStateTracksCancelled = 10,
/* iOS 11+ only: Download of extra tracks completed normally */
BCOVOfflineVideoDownloadStateTracksCompleted = 11,
/* iOS 11+ only: Download of extra tracks terminated with an error */
BCOVOfflineVideoDownloadStateTracksError = 12
The BCOVOfflineVideoManagerDelegate
protocol adds the following optional methods signatures:
This method is used on iOS 11.0+ to provide feedback about track downloads:
- (void)offlineVideoToken:(BCOVOfflineVideoToken)offlineVideoToken
aggregateDownloadTask:(AVAggregateAssetDownloadTask *)aggregateDownloadTask
didProgressTo:(NSTimeInterval)progressPercent
forMediaSelection:(AVMediaSelection *)mediaSelection
This method is called when an individual track download is complete:
- (void)offlineVideoToken:(BCOVOfflineVideoToken)offlineVideoToken
didFinishMediaSelectionDownload:(AVMediaSelection *)mediaSelection
This method is called when all requested track downloads are complete:
- (void)offlineVideoToken:(BCOVOfflineVideoToken)offlineVideoToken
didFinishAggregateDownloadWithError:(NSError *)error
The BCOVOfflineVideoStatus
class includes a new property for managing secondary track downloads:
@property (nonatomic, readonly) AVAggregateAssetDownloadTask *aggregateDownloadTask
Secondary track include captions, subtitles, and audio tracks. You create a list of tracks to download as an array of AVMediaSelections, and iOS will download them all together using an AVAggregateAssetDownloadTask. You can only start a track download after the primary video has been downloaded.
BCOVOfflineVideoManager has several new methods to help you start and manage secondary track downloads. These new methods apply only to iOS 11.
This method is used to begin downloading additional caption and audio tracks. Track selections are specified as AVMediaSelections. This request can only be made after the related video download has completed. Be sure the offlineVideoToken:didFinishDownloadWithError:
delegate callback method has already been called for this video.
- (void)requestMediaSelectionsDownload:(NSArray<AVMediaSelection *> *)mediaSelections
offlineVideoToken:(BCOVOfflineVideoToken)offlineVideoToken
This method returns the AVMediaSelectionGroup for a downloaded video. You can get the media selection group for audio or caption tracks by specifying AVMediaCharacteristicAudible or AVMediaCharacteristicLegible respectively.
- (AVMediaSelectionGroup *)mediaSelectionGroupForMediaCharacteristic:(NSString *)mediaCharacteristic
offlineVideoToken:(BCOVOfflineVideoToken)offlineVideoToken
This is a convenience method that returns the array of AVMediaSelectionOptions that have already been downloaded for an associated offline video as reported by the AVAssetCache for the underlying AVURLAsset.
You can specify AVMediaCharacteristicAudible or AVMediaCharacteristicLegible to find out what audio or caption tracks have been downloaded.
- (NSArray<AVMediaSelectionOption *> *)downloadedMediaSelectionOptionsForMediaCharacteristic:(NSString *)mediaCharacteristic
offlineVideoToken:(BCOVOfflineVideoToken)offlineVideoToken
The forceStopAllDownloadTasks
method is implemented as a workaround for a bug on iOS 11.0.x and iOS 11.1.x. On these iOS versions, a track download will resume to completion if it was paused and then cancelled. The only way to stop the download is to force all the downloads in progress to stop wtih an error.
This method should not be used on other versions of iOS; you can cancel an aggregate download task normally on iOS 11.2 by calling cancelVideoDownload
.
- (void)forceStopAllDownloadTasks
For full details about downloading video for offline playback, see the iOS App Developer's Guide to Video Downloading and Offline Playback with HLS in the Brightcove Player SDK for iOS, in OfflinePlayback.md in the main SDK directory.
- The PlayerUI controls, and full-screen view of the PlayerUI now respect the new iOS 11 Safe Areas. This ensures that PlayerUI views display properly on iPhone X.
- Fixes an issue that caused link errors when building with the core Native Player SDK framework using Xcode 8.
- The method
-[BCOVOfflineVideoManager variantBitratesForVideo:completion:]
now passes an array containing NSNumber objects to the completion handler, instead of incorrectly passing an array of NSString objects.
- Fixes an issue that prevented subtitles from updating properly when playing back offline videos.
- Fixes an issue that prevented FairPlay videos from playing on Apple TV. This only affected Video Cloud accounts using Dynamic Delivery.
- Adds BCOVPUIAdControlView.h to the BrightcovePlayerSDK.h umbrella header to fix a compiler warning.
- Fixes an issue where code coverage symbols were present in the framework executables. This caused link errors in some build configurations.
- Adds support for downloading and playing back clear (non-DRM) video content from Video Cloud accounts using Dynamic Delivery. Previously only FairPlay-protected content could be downloaded.
- Fixes an issue on iOS 11 where downloaded FairPlay videos would not play back until the app was restarted.
- The
BCOVVideo
class has a new BOOLusesFairPlay
property that returns YES if the video contains a FairPlay-encrypted source. This only applies to videos retrieved from a Dynamic Delivery account. - The
BCOVPlayerSDKManager
singleton class has a newsessionID
property. ThisNSString *
property is a unique read-only value that remains constant until the app is relaunched. This value is sent with all analytics reports and can be used to help diagnose playback issues. Refer to the "Tracking Errors" section of the README for full details. - The
BCOVPlaybackService
class has four new methods for converting JSON response data from the Playback Service API. These methods are useful if you need to retrieve data from the Playback Service API (through a proxy server, for example) and then convert them to objects you can work with in the SDK. These methods work identically to the methods found in theBCOVCatalogService
class with the same names:+ (BCOVSource *)sourceFromJSONDictionary:(NSDictionary *)json
+ (BCOVCuePoint *)cuePointFromJSONDictionary:(NSDictionary *)json
+ (BCOVPlaylist *)playlistFromJSONDictionary:(NSDictionary *)json
+ (BCOVVideo *)videoFromJSONDictionary:(NSDictionary *)json
- The
BCOVPUIAdControlView
class is now fully declared in BCOVPUIAdControlView.h so that you can use theBCOVPUIPlayerView
propertyadControlsView
. Previously,BCOVPUIAdControlView
was only a forward class declaration.
- Release 6.1.0 of the FreeWheel Plugin adds support for version 6.17.5 of the FreeWheel SDK, which introduces several deprecations and new classes. As a result, the return type of
BCOVFWSessionProviderAdContextPolicy
has changed fromid<FWContext>
toBCOVFWContext*
. Refer to the "Quick Start" section of the FreeWheel Plugin README, and the iOS Player Samples, for full details.
- The
BCOVPlaybackController
protocol has a newusesExternalPlaybackWhileExternalScreenIsActive
property. Setting thisBOOL
property sets the similarly namedusesExternalPlaybackWhileExternalScreenIsActive
property of the current playback session's AVPlayer, as well as that of any subsequent sessions. This property has no effect ifallowsExternalPlayback
is false. - The
BCOVPlaybackController
protocol's-setAllowsExternalPlayback:
method has been turned into theBOOL allowsExternalPlayback
property.
- Supports version 3.6.0 of the Google IMA iOS SDK Framework.
- Fixes an issue where dynamic frameworks were missing bitcode.
- Fixes an issue where a zero-length file in the framework would cause a build warning.
- Fixes an issue where adding the Brightcove Player SDK using CocoaPods required the manual addition of the MediaAccessibility framework.
- Fixes an issue where certain video names caused those videos to fail to download for offline playback. Refer to the "Specifying the Download Display Name" section of the OfflinePlayback.md document.
- This release exposes the
HTTPMaximumConnectionsPerHost
property of theNSURLSessionConfiguration
object used to construct theAVAssetDownloadTask
which downloads a video for offline playback. Set this value when calling the+initializeOfflineVideoManagerWithDelegate:options:
method of theBCOVOfflineVideoManager
by providing an NSNumber value for thekBCOVOfflineVideoManagerHTTPMaximumConnectionsPerHostKey
key in theoptions
dictionary.
- Server-Side Ad Insertion (SSAI) is now supported for both non-DRM and DRM videos ingested for Dynamic Delivery.
- When playing offline video, subtitles now render according to the user captioning preferences of the device.
- Fixes an issue in which the Live button would frequently change state during live streaming.
- Server-Side Ad Insertion (SSAI) is now supported for non-DRM videos ingested for Dynamic Delivery. This update requires the use of the OnceUX Plugin for Brightcove Player SDK for iOS.
- Server-Side Ad Insertion (SSAI) is now supported for non-DRM videos ingested for Dynamic Delivery.
- Improves error reporting for downloading videos. Previoiusly, some errors were recorded but not reported right away to the Offline Video Manager delegate.
- Fixes pause and resume functionality for downloading videos.
- Fixes an issue where the UI could hang when using the
AVPlayerViewController
class.
-
This and future releases of Brightcove Native Player for iOS will include all software components, all having the same version number. When building your app with Brightcove Native Player for iOS components, the component version numbers must always match. As an example, when using version 6.0.1 of the FreeWheel Plugin for Brightcove Player SDK for iOS, you must also use version 6.0.1 of the core Brightcove Player SDK for iOS. Each component will continue to be available from individual GitHub repositories.
-
The Brightcove Podspecs repository has moved and the Pods have been renamed. The Podspecs are now available at https://github.com/brightcove/BrightcoveSpecs.
-
All CocoaPods podfiles that use Brightcove frameworks should include a reference to the Brightcove Podspecs at the top of the podfile:
source 'https://github.com/brightcove/BrightcoveSpecs.git'
- CHANGELOG.md (this file) has been consolidated to include all Brightcove Native Player for iOS software components.
- The BrightcoveFairPlay module is now integrated into the core BrightcovePlayerSDK module and framework. No functional code changes are required, but you should make these changes for your build:
- Remove BrightcoveFairPlay.framework from your project.
- If using CocoaPods, remove all references to BrightcoveFairPlay from your Podfiles, and then update.
- In your source code, change any #includes from
<BrightcoveFairPlay/header_name.h>
to<BrightcovePlayerSDK/header_name.h>
. - Remove any imports that refer to the BrightcoveFairPlay module.
- The BrightcoveSidecarSubtitles module is now integrated into the core BrightcovePlayerSDK module and framework. No functional code changes are required, but you should make these changes for your build:
- Remove BrightcoveSidecarSubtitles.framework from your project.
- If using CocoaPods, remove all references to BrightcoveSidecarSubtitles from your Podfiles, and then update.
- In your source code, change any #includes from
<BrightcoveSidecarSubtitles/header_name.h>
to<BrightcovePlayerSDK/header_name.h>
. - Remove any imports that refer to the BrightcoveSidecarSubtitles module.
- Supports downloading FairPlay-encrypted HLS videos, and playing them back from storage while online or offline.
- New classes and types to support offline playback:
BCOVOfflineVideoManager
,BCOVOfflineVideoStatus
,BCOVOfflineVideoToken
,BCOVOfflineVideoDownloadState
. - Refer to our app developer's guide for full details: "iOS App Developer's Guide to Video Downloading and Offline Playback with FairPlay" in OfflinePlayback.md.
- The
BCOVVideo
class has three new properties:BOOL canBeDownloaded
: Returns YES if this video object can be downloaded for offline playbackBOOL offline
: Returns YES if this instance refers to an offline video.BOOL playableOffline
: Returns YES if this instance refers to an offline video playable from the device's local storage. Returns NO if the video has not completed downloading, or if the video has been purged and needs to be re-downloaded.
- The publisher ID can be nil when calling
-[BCOVFPSBrightcoveAuthProxy initWithPublisherId:applicationId:]
. Neither value is needed for Dynamic Delivery accounts. - Fixes an issue where multiple check marks could appear unintentionally when making language or audio selections in the Audio & Subtitles control's view in the PlayerUI.
- Adds the
BCOVPlayerSDKManager
class methodsharedManagerWithOptions:
that returns the same singletonBCOVPlayerSDKManager
class instance, but accepts an options dictionary as a parameter. This is reserved for future use related to debug logging.
- The FreeWheel Plugin for Brightcove Player SDK now supports version 6.15.0 of the FreeWheel Ad Manager framework.
- Fixes an issue where the video view start time was sometimes reported incorrectly for Quality of Service metrics.
- Fixes an issue where the video view start time was sometimes reported incorrectly for Quality of Service metrics.
- Fixes an issue where the video view start time was sometimes reported incorrectly for Quality of Service metrics.