The integration of Prebid Rendering API with Google Ad Manager (GAM) assumes that the publisher has an account on GAM and has already integrated the Google Mobile Ads SDK (GMA SDK) into the app project.
If you do not have GMA SDK in the app yet, refer to the Google Integration Documentation.
Steps 1-2 Prebid SDK makes a bid request. Prebid server runs an auction and returns the winning bid.
Step 3 Prebid SDK using Prebid GAM Event Handler sets up the targeting keywords into the GAM’s ad unit.
Step 4 GMA SDK makes an ad request. GAM returns the winner of the waterfall.
Step 5 Based on the ad response Prebid GAM Event Handler decides who has won on GAM - the Prebid bid or another ad source on GAM.
Step 6 The winner is displayed in the App with the respective rendering engine. The winning bid will be renderd by Prebid SDK. Other winners will be rendered by GMA SDK. The GAM Event Handler manages this process.
Prebid SDK provides rendering integration into GAM setup thru app events mechanism. To integrate Prebid Event Handlers into your app, add the following line to your Podfile:
pod 'PrebidMobileGAMEventHandlers'
Warning: GMA SDK is a closed library that sometimes works in unexpected ways. The GADMobileAds.sharedInstance().start()
should be called in all bundles where it is used. Otherwise, GMA SDK won’t load the ads with an error of: adView:didFailToReceiveAdWithError: SDK tried to perform a networking task before being initialized.
To avoid this error add the following line to your app right after initialization of GMA SDK:
GAMUtils.shared.initializeGAM()
Integration example:
// 1. Create an Event Handler
let eventHandler = GAMBannerEventHandler(adUnitID: GAM_AD_UNIT_ID,
validGADAdSizes: [NSValueFromGADAdSize(adSize)])
// 2. Create a Banner View
let banner = BannerView(configID: CONFIG_ID,
eventHandler: eventHandler)
banner.delegate = self
addBannerToUI(banner: banner)
// 3. Load an Ad
banner.loadAd()
To create the GAMBannerEventHandler
you should provide:
BannerView
- is a view that will display the particular ad. It should be added to the UI. To create a BannerView you should provide:
configID
- an ID of Stored Impression on the Prebid servereventHandler
- the instance of the banner event handlerYou should also add the instance of BannerView
to the UI.
Call the method loadAd()
which will:
For Banner Video you also need to specify the ad format:
banner.adFormat = .video
The rest of the code will be the same as for integration of Display Banner.
GAM setup:
Integration:
GAMBannerView
with BannerView
in the UI.BannerViewDelegate
in the ViewController.GAMBannerView
, GAMRequest
, and implementation of the GADBannerViewDelegate
.BannerAdUnit
.Integration example:
// 1. Create Event Handler
let eventHandler = GAMInterstitialEventHandler(adUnitID: GAM_AD_UNIT_ID)
// 2. Create Interstitial Ad Unit
interstitial = InterstitialRenderingAdUnit (configID: CONFIG_ID,
minSizePercentage: CGSize(width: 30, height: 30),
eventHandler: eventHandler)
interstitial.delegate = self
// 3. Load an Ad
interstitial.loadAd()
/// .......
// 4. Show Ad
if interstitial.isReady {
interstitial.show(from: self)
}
The default ad format for interstitial is .banner. In order to make a multiformat bid request
, set the respective values in the adFormats
property.
// Make bid request for video ad
adUnit?.adFormats = [.video]
// Make bid request for both video amd disply ads
adUnit?.adFormats = [.video, .banner]
// Make bid request for banner ad (default behaviour)
adUnit?.adFormats = [.banner]
To create an event handler you should provide a GAM Ad Unit.
Initialize the InterstitialRenderingAdUnit
with properties:
configID
- an ID of Stored Impression on the Prebid serverminSizePercentage
- specifies the minimum width and height percent an ad may occupy of a device’s real estate.eventHandler
- the instance of the interstitial event handlerNOTE: the
minSizePercentage
- plays an important role in the bidding process for display ads. If provided space is not enough demand partners won’t respond with bids.
Call the method loadAd()
which will make a bid request to Prebid Server.
Wait for the Prebid Server to return an ad and show it to the user in any suitable time.
// MARK: InterstitialRenderingAdUnitDelegate
func interstitialDidReceiveAd(_ interstitial: InterstitialAdUnit) {
// Now the ad is ready for display
}
GAM setup:
Integration:
GAMInterstitialAd
with InterstitialRenderingAdUnit
in the View Controller.InterstitialAdUnitDelegate
in the View Controller.GAMInterstitialAd
, GAMRequest
.InterstitialAdUnit
.Integration example:
// 1. Create an Event Handler
let eventHandler = GAMRewardedEventHandler(adUnitID: GAM_AD_UNIT_ID)
// 2. Create an Ad Unit
rewardedAd = RewardedAdUnit(configID: CONFIG_ID,
eventHandler: eventHandler)
rewardedAd.delegate = self
// 3. Load an Ad
rewardedAd.loadAd()
/// .......
// 4. Display Ad
if rewardedAd.isReady {
rewardedAd.show(from: self)
}
The proccess for displaying the Rewarded Ad is the same as for the Interstitial Ad.
To be notified when a user earns a reward - implement the method of RewardedAdUnitDelegate
:
- (void)rewardedAdUserDidEarnReward:(RewardedAdUnit *)rewardedAd;
The reward object is stored in the RewardedAdUnit
:
if let reward = rewardedAd.reward as? GADAdReward {
// ...
}
To create an event handler you should provide a GAM Ad Unit ID.
Create the RewardedAdUnit
object with parameters:
configID
- an ID of Stored Impression on the Prebid servereventHandler
- the instance of rewarded event handlerCall the loadAd()
method which will make a bid request to Prebid server.
Wait for the ad to load and display it to the user in any suitable time.
// MARK: RewardedAdUnitDelegate
func rewardedAdDidReceiveAd(_ rewardedAd: RewardedAdUnit) {
// Now the ad is ready for display
}
GAM setup:
Integration:
GADRewardedAd
with RewardedAdUnit
in the View Controller.RewardedAdUnitDelegate
in the View Controller.GAMRequest
.RewardedVideoAdUnit
.