Classes
The following classes are available globally.
-
Used to provide a value that represents a price that can be used by real-time bidding (RTB) systems. Specified in
See moreInline.Pricing
in the VAST response.Declaration
Objective-C
@interface BMPAdPricing : NSObject <_BMPJsonEncodable>
Swift
class AdPricing : NSObject, _JsonEncodable
-
A string representation of a URI to any resource relating to an integrated survey. Specified in
See moreInLine.Survey
in the VAST response.Declaration
Objective-C
@interface BMPAdSurvey : NSObject <_BMPJsonEncodable>
Swift
class AdSurvey : NSObject, _JsonEncodable
-
Describes the ad system that returned the ad. Specified in
See moreInLine.AdSystem
in the VAST response.Declaration
Objective-C
@interface BMPAdSystem : NSObject <_BMPJsonEncodable>
Swift
class AdSystem : NSObject, _JsonEncodable
-
Defines the url and type of an ad manifest.
See moreDeclaration
Objective-C
@interface BMPAdTag : NSObject <_BMPJsonEncodable>
Swift
class AdTag : NSObject, _JsonEncodable
-
Describes he advertiser as defined by the ad serving party. Specified in
See moreInLine.Advertiser
in the VAST response.Declaration
Objective-C
@interface BMPAdvertiser : NSObject <_BMPJsonEncodable>
Swift
class Advertiser : NSObject, _JsonEncodable
-
IMPORTANT: Methods from BMPBitmovinCastManager need to be called from the main thread.
Singleton providing access to GoogleCast related features. The BMPBitmovinCastManager needs to be initialized by calling BMPBitmovinCastManager#initializeCasting in the AppDelegate of the application which should support casting.
See moreDeclaration
Objective-C
@interface BMPBitmovinCastManager : NSObject
Swift
class BitmovinCastManager : NSObject
-
Contains various data about the
See moreCreative
. Specified inInLine.Creative
orWrapper.Creative
in the VAST Response.Declaration
Objective-C
@interface BMPCreative : NSObject <_BMPJsonEncodable>
Swift
class Creative : NSObject, _JsonEncodable
-
A config object representing an HTTP request.
See moreDeclaration
Objective-C
@interface BMPHttpRequest : NSObject <NSCopying>
Swift
class HttpRequest : NSObject, NSCopying, @unchecked Sendable
-
Represents ID3 metadata found in the stream.
See more -
Undocumented
See moreDeclaration
Objective-C
@interface BMPMetadata : NSObject @property (nonatomic, readonly, copy) NSArray<id<BMPMetadataEntry>> *entries; - (instancetype)init NS_UNAVAILABLE; + (instancetype)new NS_UNAVAILABLE; - (instancetype)initWithEntries:(NSArray<id<BMPMetadataEntry>> *)entries NS_DESIGNATED_INITIALIZER; @end
Swift
class Metadata : NSObject
-
Factory to create a
See morePlayer
instance.Declaration
Objective-C
@interface BMPPlayerFactory : NSObject
-
Represents the SCTE-35 metadata from the media playlist.
See moreDeclaration
Objective-C
@interface BMPScteMetadata : BMPMetadata
Swift
class ScteMetadata : Metadata
-
Undocumented
See moreDeclaration
Objective-C
@interface BMPSourceOptions : NSObject <NSCopying, _BMPJsonEncodable> /** The position where the stream should be started. Number can be positive or negative depending on the used TimelineReferencePoint. Invalid numbers will be corrected according to the stream boundaries. For VOD this is applied at the time the stream is loaded, for LIVE when the playback starts. Default: NAN */ @property (nonatomic) NSTimeInterval startOffset; /** Timeline reference point to calculate BMPSourceOptions.startOffset from. Default for live: BMPTimelineReferencePointEnd Default for VOD: BMPTimelineReferencePointStart */ @property (nonatomic) BMPTimelineReferencePoint startOffsetTimelineReference; /** The identifier for the `SourceConfig` in a SharePlay session. This identifier is used: - to validate that received SharePlay commands are intended for the currently active `Source`'s `SourceConfig` when receiving them. - for caching the playback state within the SharePlay session If there is a stored playback state for the given identifier, it will be applied when a `SourceConfig` with the same identifier becomes active. @note The identifier must match for all participants in the SharePlay session. If no identifier is provided, the URL of the `SourceConfig` will be used. */ @property (nonatomic, nullable, copy) NSString *sharePlayIdentifier; - (instancetype)initWithStartOffset:(NSTimeInterval)startOffset startOffsetTimelineReferencePoint:(BMPTimelineReferencePoint)startOffsetTimelineReference; - (instancetype)initWithStartOffset:(NSTimeInterval)startOffset startOffsetTimelineReferencePoint:(BMPTimelineReferencePoint)startOffsetTimelineReference sharePlayIdentifier:(nullable NSString *)sharePlayIdentifier NS_DESIGNATED_INITIALIZER; @end
Swift
class SourceOptions : NSObject, NSCopying, _JsonEncodable, @unchecked Sendable
-
Represents a VTT thumbnail.
See moreDeclaration
Objective-C
@interface BMPThumbnail : NSObject <_BMPJsonEncodable>
Swift
class Thumbnail : NSObject, _JsonEncodable
-
Describes a unique creative identifier that is maintained across systems. Specified in
See moreCreative.UniversalAdId
in the VAST response.Declaration
Objective-C
@interface BMPUniversalAdId : NSObject <_BMPJsonEncodable>
Swift
class UniversalAdId : NSObject, _JsonEncodable
-
Factory to create a
See morePlayer
instance.Declaration
Swift
@available(iOS 14.0, tvOS 14.0, *) public class PlayerFactory : @unchecked Sendable
-
Provides the means to manage latency for live-streams. Accessible through
Player.latency
.Note
DisablePlayerConfig.tweaksConfig.isCustomHlsLoadingEnabled
when intending to play HLS-LL streams below iOS and tvOS 17. Due to platform limitations, HLS-LL streams are not supported there while this property is enabled.This API is not supported during casting.
See moreDeclaration
Swift
@objcMembers @objc(BMPLatencyApi) public class LatencyApi : NSObject
-
The Obj-C version of the SharePlay API. It is empty on purpose as SharePlay can only be used from Swift.
See moreDeclaration
Swift
@objc(BMPSharePlayApi) public class SharePlayApi : NSObject
-
Provides the means to interact and manage thumbnails. Accessible through
Player.thumbnails
.This API is not supported during casting.
See moreDeclaration
Swift
@objcMembers @objc(BMPThumbnailsApi) public class ThumbnailsApi : NSObject
-
The Obj-C version of the player events API. It is empty on purpose as Combine-based event subscriptions can only be used from Swift.
See moreDeclaration
Swift
@objc(BMPPlayerEventsApi) public class PlayerEventsApi : NSObject
-
The Obj-C version of the player view events API. It is empty on purpose as Combine-based event subscriptions can only be used from Swift.
See moreDeclaration
Swift
@MainActor @objc(BMPPlayerViewEventsApi) public class PlayerViewEventsApi : NSObject
-
The Obj-C version of the source events API. It is empty on purpose as Combine-based event subscriptions can only be used from Swift.
See moreDeclaration
Swift
@objc(BMPSourceEventsApi) public class SourceEventsApi : NSObject
-
Base class for ad break related event classes.
See moreDeclaration
Swift
@objcMembers @objc(BMPAdBreakEvent) open class AdBreakEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPAdBreakFinishedEvent) open class AdBreakFinishedEvent : AdBreakEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPAdBreakStartedEvent) open class AdBreakStartedEvent : AdBreakEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPAdClickedEvent) open class AdClickedEvent : PlayerEvent, @unchecked Sendable
-
See
PlayerListener
for more information on this event.Possible error codes for
AdErrorEvent
when using ads withAdSourceType.bitmovin
:During ad loading and parsing:
Code Description 100 The ad response was not recognized as a valid VAST ad. 302 The maximum number of VAST wrapper redirects has been reached. 400 There was an error playing the video ad. During ad playback:
See
PlayerErrorEvent
andSourceErrorEvent
for more information on possible error codes.All other error codes are provided by OS frameworks such as
CoreMedia
,AVFoundation
,CFNetworking
etc. These error codes can be negative values and many of them are not documented by Apple.
Possible error codes for
See moreAdErrorEvent
when using ads withAdSourceType.ima
:Declaration
Swift
@objcMembers @objc(BMPAdErrorEvent) open class AdErrorEvent : PlayerEvent, @unchecked Sendable
-
Base class for ad related event classes.
See moreDeclaration
Swift
@objcMembers @objc(BMPAdEvent) open class AdEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPAdFinishedEvent) open class AdFinishedEvent : AdEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPAdManifestLoadEvent) open class AdManifestLoadEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPAdManifestLoadedEvent) open class AdManifestLoadedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPAdQuartileEvent) @objcMembers open class AdQuartileEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPAdScheduledEvent) @objcMembers open class AdScheduledEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPAdSkippedEvent) open class AdSkippedEvent : AdEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPAdStartedEvent) open class AdStartedEvent : AdEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPAirPlayAvailabilityChangedEvent) public class AirPlayAvailabilityChangedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@available(*, deprecated, renamed: "AirPlayAvailabilityChangedEvent(allowsAirPlay:﹚") @objcMembers @objc(BMPAirPlayAvailableEvent) public class AirPlayAvailableEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPAirPlayChangedEvent) public class AirPlayChangedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPAudioAddedEvent) @objcMembers public class AudioAddedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPAudioChangedEvent) public class AudioChangedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPAudioRemovedEvent) public class AudioRemovedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPCastAvailableEvent) @objcMembers open class CastAvailableEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPCastPausedEvent) @objcMembers open class CastPausedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPCastPlaybackFinishedEvent) @objcMembers open class CastPlaybackFinishedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPCastPlayingEvent) @objcMembers open class CastPlayingEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPCastStartEvent) @objcMembers open class CastStartEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPCastStartedEvent) @objcMembers open class CastStartedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPCastStoppedEvent) @objcMembers open class CastStoppedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPCastTimeUpdatedEvent) @objcMembers open class CastTimeUpdatedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@available(tvOS, unavailable) @objc(BMPCastWaitingForDeviceEvent) @objcMembers open class CastWaitingForDeviceEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPCueEnterEvent) open class CueEnterEvent : PlayerEvent, CueEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPCueExitEvent) open class CueExitEvent : PlayerEvent, CueEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPCueParsedEvent) open class CueParsedEvent : NSObject, CueEvent, SourceEvent, @unchecked Sendable
-
Provides additional data about a deficiency (error or warning).
See moreDeclaration
Swift
@objcMembers @objc(BMPDeficiencyData) public class DeficiencyData : NSObject
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPDestroyEvent) public class DestroyEvent : PlayerEvent, @unchecked Sendable
-
See
See moreSourceListener
for more information on this event.Declaration
Swift
@objc(BMPDownloadFinishedEvent) @objcMembers public class DownloadFinishedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPDrmDataParsedEvent) @objcMembers public class DrmDataParsedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See moreSourceListener
for more information on this event.Declaration
Swift
@objc(BMPDurationChangedEvent) @objcMembers public class DurationChangedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPDvrWindowExceededEvent) @objcMembers open class DvrWindowExceededEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPLicenseValidatedEvent) @objcMembers open class LicenseValidatedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPMetadataEvent) public class MetadataEvent : PlayerEvent, @unchecked Sendable
-
See
See moreSourceListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPMetadataParsedEvent) public class MetadataParsedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPMutedEvent) public class MutedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPOutputObscuredEvent) public class OutputObscuredEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPOutputUnobscuredEvent) public class OutputUnobscuredEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPPausedEvent) public class PausedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPPlayEvent) @objcMembers public class PlayEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPPlaybackFinishedEvent) @objcMembers public class PlaybackFinishedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPPlaybackSpeedChangedEvent) public class PlaybackSpeedChangedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPPlayerActiveEvent) public class PlayerActiveEvent : PlayerEvent, @unchecked Sendable
-
See
PlayerListener
for more information on this event.Possible error codes for
PlayerErrorEvent
:Code Description 1002 Verification of the player license key failed. A valid license must be provided in the Info.plist
file or viaPlayerConfig.key
.1003 The license request failed or was denied by the server. One possible reason is that the Bundle ID of the app is not authorized for the specified player license key. Make sure that the Bundle ID of the application is registered for the license key provided in the Info.plist file or in the PlayerConfiguration. This can be done in the Bitmovin dashboard. 1004 A general error code for Advertising errors. 1200 A general error code for network errors. All other error codes are provided by OS frameworks such as
See moreCoreMedia
,AVFoundation
,CFNetworking
etc. These error codes can be negative values and many of them are not documented by Apple.Declaration
Swift
@objcMembers @objc(BMPPlayerErrorEvent) public class PlayerErrorEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPPlayerInactiveEvent) public class PlayerInactiveEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@available(*, deprecated, message: "Warnings are now communicated through logs with level `.warning`. These logs are printed to the console by default. You can also access them by providing your own logger to `DebugConfig.logging.logger`\"") @objcMembers @objc(BMPPlayerWarningEvent) public class PlayerWarningEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPPlayingEvent) public class PlayingEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPPlaylistTransitionEvent) public class PlaylistTransitionEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPReadyEvent) public class ReadyEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPSeekEvent) public class SeekEvent : PlayerEvent, @unchecked Sendable
-
Class represent seeking position
See moreDeclaration
Swift
@objcMembers @objc(BMPSeekPosition) public class SeekPosition : NSObject
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPSeekedEvent) public class SeekedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@available(iOS 15.0, tvOS 15.0, *) @objc(BMPSharePlayEndedEvent) @objcMembers public class SharePlayEndedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@available(iOS 15.0, tvOS 15.0, *) @objc(BMPSharePlayStartedEvent) @objcMembers public class SharePlayStartedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@available(iOS 15.0, tvOS 15.0, *) @objc(BMPSharePlaySuspensionEndedEvent) @objcMembers public class SharePlaySuspensionEndedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@available(iOS 15.0, tvOS 15.0, *) @objc(BMPSharePlaySuspensionStartedEvent) @objcMembers public class SharePlaySuspensionStartedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPSourceAddedEvent) @objcMembers public class SourceAddedEvent : PlayerEvent, @unchecked Sendable
-
See
SourceListener
for more information on this event.Possible error codes for
SourceErrorEvent
:Code Description 2001 A general source error code when a more specific error code could not be determined. 2101 Failed to start playing the source. 2202 Failed to download playlist. 2301 A general error indicating that the current DRM session failed for some reason. The message of the according SourceErrorEvent provides more information. 2302 The required DRM configuration is missing. 2303 No DRM license URL provided. 2306 The response to the DRM license request failed with an invalid HTTP response code. The message of the according SourceErrorEvent provides more information. 2307 The response to the DRM certificate request failed with an invalid HTTP response code. The message of the according SourceErrorEvent provides more information. 2309 No DRM certificate URL provided. All other error codes are provided by OS frameworks such as
See moreCoreMedia
,AVFoundation
,CFNetworking
etc. These error codes can be negative values and many of them are not documented by Apple.Declaration
Swift
@objcMembers @objc(BMPSourceErrorEvent) public class SourceErrorEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See moreSourceListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPSourceLoadedEvent) public class SourceLoadedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPSourceRemovedEvent) @objcMembers public class SourceRemovedEvent : PlayerEvent, @unchecked Sendable
-
See
See moreSourceListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPSourceUnloadEvent) public class SourceUnloadEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See moreSourceListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPSourceUnloadedEvent) public class SourceUnloadedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See moreSourceListener
for more information on this event.Declaration
Swift
@available(*, deprecated, message: "Warnings are now communicated through logs with level `.warning`. These logs are printed to the console by default. You can also access them by providing your own logger to `DebugConfig.logging.logger`\"") @objcMembers @objc(BMPSourceWarningEvent) public class SourceWarningEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPStallEndedEvent) public class StallEndedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPStallStartedEvent) public class StallStartedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPSubtitleAddedEvent) @objcMembers open class SubtitleAddedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPSubtitleChangedEvent) @objcMembers open class SubtitleChangedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPSubtitleRemovedEvent) @objcMembers open class SubtitleRemovedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPTimeChangedEvent) open class TimeChangedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPTimeShiftEvent) public class TimeShiftEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPTimeShiftedEvent) public class TimeShiftedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPUnmutedEvent) @objcMembers open class UnmutedEvent : PlayerEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPVideoDownloadQualityChangedEvent) @objcMembers public class VideoDownloadQualityChangedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See moreSourceListener
for more information on this event.Declaration
Swift
@objc(BMPVideoPlaybackQualityChangedEvent) @objcMembers public class VideoPlaybackQualityChangedEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPVideoSizeChangedEvent) open class VideoSizeChangedEvent : PlayerEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
@objc(BMPControlsHideEvent) @objcMembers open class ControlsHideEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
@objc(BMPControlsShowEvent) @objcMembers open class ControlsShowEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPFullscreenDisabledEvent) public class FullscreenDisabledEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPFullscreenEnabledEvent) public class FullscreenEnabledEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPFullscreenEnterEvent) public class FullscreenEnterEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPFullscreenExitEvent) public class FullscreenExitEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
public class PictureInPictureEnterEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
public class PictureInPictureEnteredEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
public class PictureInPictureExitEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
public class PictureInPictureExitedEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPScalingModeChangedEvent) public class ScalingModeChangedEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPTimelineMarkerEnterEvent) public class TimelineMarkerEnterEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreUserInterfaceListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPTimelineMarkerExitEvent) public class TimelineMarkerExitEvent : NSObject, PlayerViewEvent, @unchecked Sendable
-
See
See moreSourceListener
for more information on this event.Declaration
Swift
@objc(BMPFairplayLicenseAcquiredEvent) @objcMembers public class FairplayLicenseAcquiredEvent : NSObject, SourceEvent, @unchecked Sendable
-
See
See moreSourceListener
for more information on this event.Declaration
Swift
@objcMembers @objc(BMPSourceLoadEvent) public class SourceLoadEvent : NSObject, SourceEvent, @unchecked Sendable
-
Represents one single log entry
See moreDeclaration
Swift
@objc(BMPLogEntry) @objcMembers public final class LogEntry : NSObject
-
A class holding information for the
See moreCastWaitingForDeviceEvent
.Declaration
Swift
@available(tvOS, unavailable) @objc(BMPCastPayload) @objcMembers public final class CastPayload : NSObject
-
The options to be used for initializing
See moreBitmovinCastManager
Declaration
Swift
@objcMembers @objc(BMPBitmovinCastManagerOptions) public final class BitmovinCastManagerOptions : NSObject
-
Contains config values to help debugging the SDK.
See moreDeclaration
Swift
@objcMembers @objc(BMPDebugConfig) public final class DebugConfig : NSObject, @unchecked Sendable
-
This component enables configuration of logging globally in the SDK through assigning a
logger
.Logging can be configured through the assigned
logger
in multiple ways. By setting thelogger
tonil
logging can be disabled. A minimum log level is also set in the assignedlogger
. The minimum log level is used to filter log output.The default value for the
logger
is an instance ofConsoleLogger
. Instead of theConsoleLogger
, a custom logger can be assigned for receiving log entries. A custom logger would need to apply its own filtering based on level. This level-based filtering is applied by default in theConsoleLogger
.To configure logging, access this config via
See moreDebugConfig.logging
. Refer toLogger
,LogLevel
,LogEntry
,ConsoleLogger
andDebugConfig
for more details.Declaration
Swift
@objcMembers @objc(BMPLoggingConfig) public final class LoggingConfig : NSObject, @unchecked Sendable
-
Configures the current Now Playing information for the application. This information will be displayed wherever Now Playing information typically appears, such as the lock screen and inside the control center.
See moreDeclaration
Swift
@objcMembers @objc(BMPNowPlayingConfig) public class NowPlayingConfig : NSObject, @unchecked Sendable
-
Configures a new
See morePlayer
instance. Must not be modified after it was used to create aPlayer
instance.Declaration
Swift
@objc(BMPPlayerConfig) @objcMembers public final class PlayerConfig : NSObject, @unchecked Sendable
-
Contains config values regarding the behaviour of the bitrate adaptation.
See moreDeclaration
Swift
@objcMembers @objc(BMPAdaptationConfig) public class AdaptationConfig : NSObject, @unchecked Sendable
-
Represents an ad break which can be scheduled for playback.
See moreDeclaration
Swift
@objc(BMPAdItem) @objcMembers public class AdItem : NSObject, @unchecked Sendable
-
Contains config values regarding the ads which should be played back by the player.
See moreDeclaration
Swift
@objc(BMPAdvertisingConfig) @objcMembers public class AdvertisingConfig : NSObject, @unchecked Sendable
-
Configuration object for the LinearAd UI.
In case Bitmovin Player UI is used, message placeholders such as:
{remainingTime}
,{adDuration}
or{playedTime}
are available to customize the ad messages. When using the System UI, only{remainingTime}
is supported.Example:
See morelet linearAdUiConfig = LinearAdUiConfig() linearAdUiConfig.message = "This ad will end in {remainingTime}" linearAdUiConfig.untilSkippableMessage = "This ad is skippable in {remainingTime}" linearAdUiConfig.skippableMessage = "You can skip this ad now." // Create an `AdItem` with one `AdSource` of type `.bitmovin` let adItem = AdItem( adSources: [AdSource(tag: adTagUrl, ofType: .bitmovin)], // Configure the ad as a pre-roll ad atPosition: "pre", // Provide a LinearAdUiConfig instance to customize the ad UI messages linearAdUiConfig: linearAdUiConfig )
Declaration
Swift
@objc(BMPLinearAdUiConfig) @objcMembers public class LinearAdUiConfig : NSObject, @unchecked Sendable
-
Contains configuration options to customize behavior for Bitmovin Advertising Module integration.
See moreDeclaration
Swift
@objc(BMPBitmovinAdvertisingConfig) @objcMembers public class BitmovinAdvertisingConfig : NSObject, @unchecked Sendable
-
Represents a VAST macro for
See moreVastMacroValueProvider
.Declaration
Swift
@objc(BMPVastMacro) public class VastMacro : NSObject, @unchecked Sendable
-
Contains configuration options for VAST macros.
See moreDeclaration
Swift
@objc(BMPVastMacroConfig) @objcMembers public class VastMacroConfig : NSObject, @unchecked Sendable
-
Defines the IMA Ad attribution UI mode
See moreDeclaration
Swift
@available(tvOS, unavailable) @objcMembers @objc(BMPImaAdAttributionUiMode) public class ImaAdAttributionUiMode : NSObject, @unchecked Sendable
-
Contains configuration options to customize behavior for Google IMA SDK.
See moreDeclaration
Swift
@objcMembers @objc(BMPImaAdvertisingConfig) public class ImaAdvertisingConfig : NSObject, @unchecked Sendable
-
The ImaSettings class stores SDK wide settings.
See moreDeclaration
Swift
@objc(BMPImaSettings) @objcMembers public class ImaSettings : NSObject, NSCopying, @unchecked Sendable
-
Player buffer config object to configure buffering behavior.
See moreDeclaration
Swift
@objcMembers @objc(BMPBufferConfig) public class BufferConfig : NSObject, @unchecked Sendable
-
Configures buffer target levels for different
See moreMediaType
s.Declaration
Swift
@objcMembers @objc(BMPBufferMediaTypeConfig) public class BufferMediaTypeConfig : NSObject, @unchecked Sendable
-
Contains config values regarding the behaviour when playing live streams.
See moreDeclaration
Swift
@available(*, deprecated, message: "Configuration for live streams has moved to the source-based `SourceLiveConfig`. Use `SourceConfig.liveConfig` instead.") @objcMembers @objc(BMPLiveConfig) public final class LiveConfig : NSObject, @unchecked Sendable
-
Represents an HTTP request for DRM information.
See moreDeclaration
Swift
@objc(BMPDrmRequest) @objcMembers public final class DrmRequest : HttpRequest, @unchecked Sendable
-
Represents an HTTP response.
See moreDeclaration
Swift
@objc(BMPHttpResponse) @objcMembers public final class HttpResponse : NSObject, @unchecked Sendable
-
The network config gives the ability to influence network requests.
See moreDeclaration
Swift
@objcMembers @objc(BMPNetworkConfig) public class NetworkConfig : NSObject, @unchecked Sendable
-
Contains config values that can be used to alter the playback behaviour of the player.
See moreDeclaration
Swift
@objcMembers @objc(BMPPlaybackConfig) public class PlaybackConfig : NSObject, @unchecked Sendable
-
Contains config values which can be used to alter the behaviour of the player when it comes to remote playback.
See moreDeclaration
Swift
@available(visionOS, unavailable) @objcMembers @objc(BMPRemoteControlConfig) public class RemoteControlConfig : NSObject, @unchecked Sendable
-
Contains config values that can be used to alter the visual presentation and behaviour when the Bitmovin Player Web UI is used.
See moreDeclaration
Swift
@objcMembers @objc(BMPBitmovinUserInterfaceConfig) public class BitmovinUserInterfaceConfig : UserInterfaceConfig, @unchecked Sendable
-
Contains metadata values to act as a fallback when respective values are not defined for the currently active source. See individual properties for details.
See moreDeclaration
Swift
@objcMembers @objc(BMPBitmovinUserInterfaceMetadata) public class BitmovinUserInterfaceMetadata : NSObject, @unchecked Sendable
-
Contains config values which can be used to alter the visual presentation and behaviour of the player UI.
See moreDeclaration
Swift
@objcMembers @objc(BMPStyleConfig) public final class StyleConfig : NSObject, @unchecked Sendable
-
Contains config values that can be used to alter the visual presentation and behaviour when the subtitle only UI is used.
See moreDeclaration
Swift
@objcMembers @objc(BMPSubtitleUserInterfaceConfig) public class SubtitleUserInterfaceConfig : UserInterfaceConfig, @unchecked Sendable
-
Contains config values that can be used to alter the visual presentation and behaviour when the System UI is used.
See moreDeclaration
Swift
@objcMembers @objc(BMPSystemUserInterfaceConfig) public class SystemUserInterfaceConfig : UserInterfaceConfig, @unchecked Sendable
-
Declaration
Swift
@objcMembers @objc(BMPUserInterfaceConfig) public class UserInterfaceConfig : NSObject, @unchecked Sendable
-
This configuration is used as an incubator for experimental features. Tweaks are not officially supported and are not guaranteed to be stable, i.e. their naming, functionality and API can change at any time within the tweaks or when being promoted to an official feature and moved into its final configuration namespace.
See moreDeclaration
Swift
@objcMembers @objc(BMPTweaksConfig) public final class TweaksConfig : NSObject, @unchecked Sendable
-
Configures a new
See morePlayerView
instance.Declaration
Swift
@objcMembers @objc(BMPPlayerViewConfig) public class PlayerViewConfig : NSObject, @unchecked Sendable
-
Provides options to configure Picture in Picture playback.
See moreDeclaration
Swift
@objcMembers @objc(BMPPictureInPictureConfig) public class PictureInPictureConfig : NSObject, @unchecked Sendable
-
Configures a playlist that can be loaded into a
See morePlayer
.Declaration
Swift
@objcMembers @objc(BMPPlaylistConfig) public final class PlaylistConfig : NSObject, @unchecked Sendable
-
Contains additional configuration options for setting up a playlist.
See moreDeclaration
Swift
@objcMembers @objc(BMPPlaylistOptions) public final class PlaylistOptions : NSObject, @unchecked Sendable
-
Marks the time range of an interstitial for the asset when presented in the tvOS system UI. Only supported when
See moreStyleConfig.userInterfaceType = .system
is used! An interstitial could be an advertisement, legal notice, or content warning. The time range defined by anInterstitialMarker
is visually collapsed from the presentation, affecting rendered duration and playback time. The values returned byplayer.duration
andplayer.currentTime
remain unaffected. -
Provides the possibility to overwrite the labels which are automatically assigned for different types of tracks.
See moreDeclaration
Swift
@objcMembers @objc(BMPLabelingConfig) public class LabelingConfig : NSObject, @unchecked Sendable
-
Represents a source config which can be played back in a player instance.
See moreDeclaration
Swift
@objcMembers @objc(BMPSourceConfig) open class SourceConfig : NSObject, @unchecked Sendable
-
Contains config values regarding the behaviour when playing live streams.
Note
DisablePlayerConfig.tweaksConfig.isCustomHlsLoadingEnabled
when intending to play HLS-LL streams below iOS and tvOS 17. Due to platform limitations, HLS-LL streams are not supported there while this property is enabled.Declaration
Swift
@objcMembers @objc(BMPSourceLiveConfig) public class SourceLiveConfig : NSObject, @unchecked Sendable
-
Represents a decryption key for a ClearKey DRM config
See moreDeclaration
Swift
@objcMembers @objc(BMPDecryptionKey) public final class DecryptionKey : NSObject, NSCopying, @unchecked Sendable
-
Declaration
Swift
@objcMembers @objc(BMPDrmConfig) public class DrmConfig : NSObject, @unchecked Sendable
-
Provides access to DRM scheme UUIDs.
See moreDeclaration
Swift
@objcMembers @objc(BMPDrmSystems) public final class DrmSystems : NSObject, @unchecked Sendable
-
Describes a subtitle cue.
See moreDeclaration
Swift
@objcMembers @objc(BMPCue) public class Cue : NSObject, NSCopying, @unchecked Sendable
-
Positioning information for CEA captions
See moreDeclaration
Swift
@objcMembers @objc(BMPCuePosition) public class CuePosition : NSObject, @unchecked Sendable
-
Declaration
Swift
@objcMembers @objc(BMPTrack) public class Track : NSObject, @unchecked Sendable
-
Prints a log entry to the console when logging is enabled in the SDK, and the log entry level equals or is above the minimum log level that is assigned to
See morelevel
below. SeeLogEntry
andLoggingConfig
for more details.Declaration
Swift
@objcMembers @objc(BMPConsoleLogger) public class ConsoleLogger : NSObject, Logger
-
Contains analytics specific data returned from the license server.
See moreDeclaration
Swift
@objc(BMPAnalyticsLicenseData) @objcMembers public class AnalyticsLicenseData : NSObject
-
Represents in-playlist timed metadata.
See moreDeclaration
Swift
@objcMembers @objc(BMPDaterangeMetadata) public class DaterangeMetadata : Metadata
-
Declaration
Swift
@objc(BMPDrmData) @objcMembers public final class DrmData : NSObject
-
Represents a FairPlay content key request. This object can be used for renewing expiring licenses via
See moreSource.drm.fairplay.renewExpiringLicense
APIDeclaration
Swift
@objc(BMPFairplayContentKeyRequest) @objcMembers public class FairplayContentKeyRequest : NSObject
-
Contains additional license data returned from the license server.
See moreDeclaration
Swift
@objc(BMPLicenseData) @objcMembers public class LicenseData : NSObject
-
Describes default properties of the custom SCTE35 tag from the playlist.
See moreDeclaration
Swift
@objcMembers @objc(BMPScteMetadataEntry) public final class ScteMetadataEntry : NSObject, MetadataEntry
-
Holds different information about the buffer levels.
See moreDeclaration
Swift
@objcMembers @objc(BMPBufferLevel) open class BufferLevel : NSObject
-
Provides the means to manage DRM on a
See moreSource
. Accessible throughSource.drm
.Declaration
Swift
@objc(BMPSourceDrmApi) @objcMembers public class SourceDrmApi : NSObject
-
Declaration
Swift
@objcMembers @objc(BMPQuality) public class Quality : NSObject
-
Declaration
Swift
@objc(BMPVttLine) @objcMembers public final class VttLine : NSObject
-
Declaration
Swift
@objc(BMPVttPosition) @objcMembers public final class VttPosition : NSObject
-
Declaration
Swift
@objc(BMPVttProperties) @objcMembers public final class VttProperties : NSObject
-
Contains config options which can be used to alter the default behaviour of content downloads.
See moreDeclaration
Swift
@objc(BMPDownloadConfig) @objcMembers public final class DownloadConfig : NSObject, @unchecked Sendable
-
This config is used as an incubator for experimental features. Tweaks are not officially supported and are not guaranteed to be stable, i.e. their naming, functionality and API can change at any time within the tweaks or when being promoted to an official feature and moved into its final config namespace.
See moreDeclaration
Swift
@objc(BMPDownloadTweaksConfig) @objcMembers public final class DownloadTweaksConfig : NSObject, @unchecked Sendable
-
Declaration
Swift
@objcMembers @objc(BMPOfflineManager) public class OfflineManager : NSObject, @unchecked Sendable
-
Holds DRM licence information
See moreDeclaration
Swift
@objcMembers @objc(BMPDrmLicenseInformation) public class DrmLicenseInformation : NSObject
-
Configures the offline functionality
See moreDeclaration
Swift
@objc(BMPOfflineConfig) @objcMembers public final class OfflineConfig : NSObject, @unchecked Sendable
-
Represents a
See moreSourceConfig
which references already downloaded or currently downloading offline content. It can passed to aPlayer
instance for playback. Do not create instances of this class on your own, instead useOfflineContentManager.createOfflineSourceConfig(restrictedToAssetCache:)
.Declaration
Swift
@objcMembers @objc(BMPOfflineSourceConfig) public class OfflineSourceConfig : SourceConfig, @unchecked Sendable
-
Declaration
Swift
@objc(BMPOfflineAudioTrack) @objcMembers public final class OfflineAudioTrack : OfflineTrack
-
Represents a text track which can be selected to download for offline playback
See moreDeclaration
Swift
@objc(BMPOfflineTextTrack) @objcMembers public final class OfflineTextTrack : OfflineTrack
-
Superclass of tracks which can be selected to download for offline playback
See moreDeclaration
Swift
@objc(BMPOfflineTrack) @objcMembers public class OfflineTrack : NSObject
-
Represents the information which tracks to download for offline playback
See moreDeclaration
Swift
@objc(BMPOfflineTrackSelection) @objcMembers public final class OfflineTrackSelection : NSObject
-
Provides the means to manage latency for a live-stream on a
Source
. Accessible throughSource.latency
.Note
DisablePlayerConfig.tweaksConfig.isCustomHlsLoadingEnabled
when intending to play HLS-LL streams below iOS and tvOS 17. Due to platform limitations, HLS-LL streams are not supported there while this property is enabled.Declaration
Swift
@objc(BMPSourceLatencyApi) @objcMembers public class SourceLatencyApi : NSObject
-
See
See morePlayerListener
for more information on this event.Declaration
Swift
@objc(BMPSourceMetadataChangedEvent) @objcMembers public class SourceMetadataChangedEvent : NSObject, SourceEvent, @unchecked Sendable
-
A view that provides the Bitmovin Player UI and default UI handling to an attached
Player
instance. This view needs aPlayer
instance to work properly. This Player can be passed to the initializer.If a custom UI is preferred, an
AVPlayerLayer
or anAVPlayerViewController
can be registered viaregisterPlayerLayer
/registerPlayerViewController
. SeePlayerView
for more details.
See more// Create a subclass of UIView class CustomView: UIView { init(player: Player, frame: CGRect) { super.init(frame: frame) // register the AVPlayerLayer of this view to the Player player.register(playerLayer) } var playerLayer: AVPlayerLayer { layer as! AVPlayerLayer } override class var layerClass: AnyClass { AVPlayerLayer.self } }
Declaration
Swift
@available(iOS 14.0, tvOS 14.0, *) @MainActor @objcMembers @objc(BMPPlayerView) open class PlayerView : UIView
extension PlayerView: UIScrollViewDelegate
extension PlayerView: UserInterfaceApi
extension PlayerView: UserInterfaceEventHandler
extension PlayerView: _PlayerListenerInternal
-
This class handles all communication between the native environment and the Bitmovin Web UI environment in one place.
See moreDeclaration
Swift
@objcMembers @objc(BMPCustomMessageHandler) public class CustomMessageHandler : NSObject, @unchecked Sendable
-
Context for VAST macro replacement.
See moreDeclaration
Swift
@objc(BMPVastMacroContext) @objcMembers public class VastMacroContext : NSObject
-
The options to be used for initializing
See moreBitmovinCastManager
-
Contains config values that can be used to alter the visual presentation and behaviour when the Bitmovin Player Web UI is used.
See more -
Marks the time range of an interstitial for the asset when presented in the tvOS system UI. Only supported when
See moreStyleConfig.userInterfaceType = .system
is used! An interstitial could be an advertisement, legal notice, or content warning. The time range defined by anInterstitialMarker
is visually collapsed from the presentation, affecting rendered duration and playback time. The values returned byplayer.duration
andplayer.currentTime
remain unaffected.Declaration
Swift
public class InterstitialMarker : TimelineMarker, @unchecked Sendable
-
Contains config options which can be used to alter the default behaviour of content downloads.
See more -
This config is used as an incubator for experimental features. Tweaks are not officially supported and are not guaranteed to be stable, i.e. their naming, functionality and API can change at any time within the tweaks or when being promoted to an official feature and moved into its final config namespace.
See more -
Configures the offline functionality
See more -
Represents a
See moreSourceConfig
which references already downloaded or currently downloading offline content. It can passed to aPlayer
instance for playback. Do not create instances of this class on your own, instead useOfflineContentManager.createOfflineSourceConfig(restrictedToAssetCache:)
. -
Represents a text track which can be selected to download for offline playback
See more -
Superclass of tracks which can be selected to download for offline playback
See more -
Represents the information which tracks to download for offline playback
See more -
This class handles all communication between the native environment and the Bitmovin Web UI environment in one place.
See more -
Provides an ObjC way of accessing the
See moreAnalytics
namespace for a givenPlayer
instance.Declaration
Swift
@objcMembers @objc(BPAPlayerAnalyticsApiAccessor) public class PlayerAnalyticsApiAccessor : NSObject, @unchecked Sendable