Skip to main content

Setting up a Banner Ad

The SDK supports Banner Ads via the CIBannerView SwiftUI View. This takes up to three parameters:

Required

  • placementID: String: Unique ID for this Ad Placement provided by Content Ignite.
  • pageUrl: String?: This is used for targeting for example if the ad is displayed inline within an article or section of the app which has an equivalent URL on the web.

Optional

  • delegate: CIBannerViewDelegate: This protocol allows you to respond to events related to the banner ad.
  • targeting: [String: [String]]: Pass custom key-value pairs to ad requests.
  • publisher: ViewBuilder closure to allow you to provide a fallback to your existing Ad implementation for this particular placement. This gives publishers full control over the use of the SDK and the rate at which this fallback is used can be controlled directly through the Fusion platform.
import CIMobileSDKSwiftUI

let coordinator = BannerCoordinator()
let targeting = ["segment" : ["health","fitness"]]

CIBannerView(
    placementID: "<PLACEMENT-ID>",
    pageUrl: "https://publisher.com/sport",
    delegate: coordinator,
    targeting: targeting,
    publisher: {
        // Publisher fallback implementation
    }
)
.frame(width: 300.0, height: 250.0)

Handling ad events

To listen and respond to events from an Interstitial ad, use the CIBannerViewDelegate protocol:
extension BannerCoordinator: CIBannerViewDelegate {

    func bannerLoaded() {
        print("Banner ad loaded.")
    }
    
    func bannerLoadFailed(error: String) {
        print("Banner ad failed to load: \(error)")
    }
    
    func bannerClicked() {
        print("Banner ad clicked.")
    }
    
    func bannerImpression() {
        print("Banner ad impression")
    }
}
See the full examples: SPM | CocoaPods.