AI-generated Key Takeaways
- 
          The IMAAdDisplayContainer manages the ad container view and companion ad slots for ad playback. 
- 
          The adContainerproperty is a view that must be in the view hierarchy to make ad or stream requests.
- 
          The adContainerViewControllerproperty is a view controller containing the ad container and must be non-nil and in the view hierarchy before ad playback.
- 
          You can initialize an IMAAdDisplayContainerwith an ad container view and optionally a view controller and companion ad slots.
- 
          The registerFriendlyObstructionandunregisterAllFriendlyObstructionsmethods are used to manage views that overlay the container for viewability measurement.
IMAAdDisplayContainer
@interface IMAAdDisplayContainer : NSObjectThe IMAAdDisplayContainer is responsible for managing the ad container view and companion ad slots used for ad playback.
- 
                  
                  View containing the video display and ad related UI. This view must be present in the view hierarchy in order to make ad or stream requests. DeclarationSwift var adContainer: UIView { get }Objective-C @property (nonatomic, readonly) UIView *_Nonnull adContainer;
- 
                  
                  View controller containing the ad container. Used to present ad UI in child view controllers. It must be non-nil in order to make ad or stream requests, and it must be in the view hierarchy before ad playback. DeclarationSwift weak var adContainerViewController: UIViewController? { get set }Objective-C @property (nonatomic, weak, nullable) UIViewController *adContainerViewController;
- 
                  
                  The environment to focus on during an ad break. Nil if there is not currently an ad break. DeclarationSwift var focusEnvironment: (any UIFocusEnvironment)? { get }Objective-C @property (nonatomic, readonly, nullable) id<UIFocusEnvironment> focusEnvironment;
- 
                  
                  List of companion ad slots. Can be nil or empty. DeclarationSwift var companionSlots: [IMACompanionAdSlot]? { get }Objective-C @property (nonatomic, readonly, nullable) NSArray<IMACompanionAdSlot *> *companionSlots;
- 
                  
                  Initializes IMAAdDisplayContainer for rendering the ad and displaying the ad UI without any companion slots. DeclarationSwift init(adContainer: UIView, viewController adContainerViewController: UIViewController?)Objective-C - (nonnull instancetype)initWithAdContainer:(nonnull UIView *)adContainer viewController:(nullable UIViewController *) adContainerViewController;ParametersadContainerThe view where the ad will be rendered. Fills the view’s bounds. adContainerViewControllerThe view controller containing the ad container. If not provided here, must be set on the property before making an ads or stream request. Return ValueA new IMAAdDisplayContainer instance 
- 
                  
                  Initializes IMAAdDisplayContainer for rendering the ad and displaying the ad UI. DeclarationSwift init(adContainer: UIView, viewController adContainerViewController: UIViewController?, companionSlots: [IMACompanionAdSlot]?)Objective-C - (nonnull instancetype) initWithAdContainer:(nonnull UIView *)adContainer viewController:(nullable UIViewController *)adContainerViewController companionSlots: (nullable NSArray<IMACompanionAdSlot *> *)companionSlots;ParametersadContainerThe view where the ad will be rendered. Fills the view’s bounds. adContainerViewControllerThe view controller containing the ad container. If not provided here, must be set on the property before making an ads or stream request. companionSlotsThe array of IMACompanionAdSlots. Can be nil or empty. Return ValueA new IMAAdDisplayContainer instance 
- 
                  
                  Registers a view that overlays or obstructs this container as “friendly” for viewability measurement purposes. See Open Measurement in the IMA SDK for guidance on what is and what is not allowed to be registered. DeclarationSwift func register(_ friendlyObstruction: IMAFriendlyObstruction)Objective-C - (void)registerFriendlyObstruction: (nonnull IMAFriendlyObstruction *)friendlyObstruction;ParametersfriendlyObstructionAn obstruction to be marked as “friendly” until unregistered. 
- 
                  
                  Unregisters all previously registered friendly obstructions. DeclarationSwift func unregisterAllFriendlyObstructions()Objective-C - (void)unregisterAllFriendlyObstructions;