AI-generated Key Takeaways
- 
          The IMAAdsRenderingSettingsclass defines properties that control how ads are displayed.
- 
          You can specify supported MIME types for ad media playback using the mimeTypesproperty.
- 
          The bitrateproperty allows setting a maximum recommended bitrate for ad media, with an option for SDK-selected bitrate based on network speed.
- 
          loadVideoTimeoutsets a timeout for loading ad media files, canceling playback if the timeout is exceeded.
- 
          For VMAP and ad rules playlists, playAdsAfterTimeensures only ad breaks scheduled after the specified time are played.
- 
          The uiElementsproperty controls which UI elements are visible for ads, though it may be ignored for AdSense/AdX ads or on tvOS.
- 
          enablePreloadingdetermines whether the SDK preloads ad media.
- 
          linkOpenerPresentingControllerandlinkOpenerDelegatemanage how in-app browsers or app stores are presented and provide notifications when links are opened/closed.
IMAAdsRenderingSettings
@interface IMAAdsRenderingSettings : NSObjectSet of properties that influence how ads are rendered.
- 
                  
                  If specified, the SDK will play the media with MIME type on the list. List of strings specifying the MIME types. When empty, the SDK will use its default list of MIME types supported on iOS. Example: @[ @“video/mp4”, @“application/x-mpegURL” ] The property is an empty array by default. DeclarationSwift var mimeTypes: [String]? { get set }Objective-C @property (nonatomic, copy, nullable) NSArray<NSString *> *mimeTypes;
- 
                  
                  Maximum recommended bitrate. The value is in kbit/s. SDK will pick media with bitrate below the specified max, or the closest bitrate if there is no media with smaller bitrate found. Default value, |kIMAAutodetectBitrate|, means the bitrate will be selected by the SDK, using the currently detected network speed (cellular or Wi-Fi). DeclarationSwift var bitrate: Int { get set }Objective-C @property (nonatomic) NSInteger bitrate;
- 
                  
                  Timeout (in seconds) when loading a video ad media file. If loading takes longer than this timeout, the ad playback is canceled and the next ad in the pod plays, if available. Use -1 for the default of 8 seconds. DeclarationSwift var loadVideoTimeout: TimeInterval { get set }Objective-C @property (nonatomic) NSTimeInterval loadVideoTimeout;
- 
                  
                  For VMAP and ad rules playlists, only play ad breaks scheduled after this time (in seconds). This setting is strictly after the specified time. For example, setting playAdsAfterTime to 15 will ignore an ad break scheduled to play at 15s. DeclarationSwift var playAdsAfterTime: TimeInterval { get set }Objective-C @property (nonatomic) NSTimeInterval playAdsAfterTime;
- 
                  
                  Specifies the list of UI elements that should be visible. This property may be ignored for AdSense/AdX ads. For valid values, see IMAUiElementType. This field is ignored on tvOS, where UI elements are unavailable. DeclarationSwift var uiElements: [NSNumber]? { get set }Objective-C @property (nonatomic, copy, nullable) NSArray<NSNumber *> *uiElements;
- 
                  
                  Whether or not the SDK will preload ad media. Default is YES. DeclarationSwift var enablePreloading: Bool { get set }Objective-C @property (nonatomic) BOOL enablePreloading;
- 
                  
                  Specifies the optional UIViewController that the SDK uses to present an in-app browser or app store. When nil, tapping the video ad “Learn More” button or companion ads results in opening a Safari browser. Setting this allows the SDK to open links in-app. This field is ignored on tvOS, where Safari is not available. If provided, the SDK presents the app store in this view controller for SKAdNetwork ads. If left nil, it is presented in the view controller provided to the ad display container. DeclarationSwift weak var linkOpenerPresentingController: UIViewController? { get set }Objective-C @property (nonatomic, weak, nullable) UIViewController *linkOpenerPresentingController;
- 
                  
                  The IMALinkOpenerDelegate to be notified when a link is opened/closed. SKAdNetwork and web links are unavailable on tvOS, but this delegate is used to notify for deep links. DeclarationSwift weak var linkOpenerDelegate: (any IMALinkOpenerDelegate)? { get set }Objective-C @property (nonatomic, weak, nullable) id<IMALinkOpenerDelegate> linkOpenerDelegate;