This how-to guide covers the ‘Prebid-Rendered’ approach for integrating the Prebid SDK into your app with the GMA SDK. It utilizes:
If you do not have GMA SDK in the app yet, refer to the Google Integration Documentation.
Another way to integrate GAM into your app is with the GAM Bidding-Only integration.
Tradeoffs between these integration approaches:
Aspect | Bidding-Only Integration | Prebid-Rendered Integration |
---|---|---|
App code has direct access to bids | ||
Support for MRAID 3.0 | ||
Support for SKAdnetwork | ||
Loads data from Prebid Cache | ||
Supports instream video | ||
Triggers billing and Notice URLs | ||
Supports Third Party Rendering libraries |
Notes:
The GAM Prebid-Rendered Integration method assumes that you have the following components:
Here’s how the ad bidding-auction-rendering process works in this integration scenario.
Assuming your app already has AdUnits integrated with the GMA SDK, the technical implementation of Prebid mobile into your app will involve these major steps:
The AdOps team will need to create line items in GAM. The creatives used depend on which media formats your adunits utilize:
AdUnit Format | Line Item Targeting | Creative Type | Prebid Cache? | Ad Ops Details |
---|---|---|---|---|
HTML banner, interstitial banner or video, non-instream video | hb_pb hb_format=banner |
3rd party HTML that loads google_mobile_app_ads.js | no | link |
Instream Video | hb_pb hb_format=video inventoryType in (instream, mobile app) |
VastUrl pointing to Prebid Cache | yes | link |
Rewarded Video | hb_pb hb_format=video inventoryType in (instream, mobile app) rewarded adunits |
VastUrl pointing to prebid-mobile-rewarded-vast.xml | no | link |
In-app native | hb_pb hb_format=native |
GAM native | no | link |
Notes:
This information may be useful when comparing data across various reporting systems:
Scenario | 3pHTML Creative | VastUrl Creative | GAM Native Creative |
---|---|---|---|
Rendering Method | js in iframe fires an event | GMA SDK player | App code with data from PBSDK |
Fires Prebid win event | always | never | always |
Fires Prebid imp event | never | VAST impression tag | never |
Fires OpenRTB burl | never | n/a | never |
Fires OpenRTB nurl | never | n/a | never |
Fires OpenMeasurement events | PBSDK | n/a | PBSDK |
Notes:
First, a little bit of setup is needed.
The Prebid SDK supples a set of classes called the ‘GAM Event Handlers’ that wrap the GAM Ad Units and manage them in the In-App Bidding flow. These classes are provided in the form of library that could be added to the app via Gradle:
Root build.gradle
allprojects {
repositories {
...
mavenCentral()
...
}
}
App module build.gradle:
implementation('org.prebid:prebid-mobile-sdk-gam-event-handlers:x.x.x')
This section covers integration details for different ad formats. In each scenario, you’ll be asked for a configId
- this is a key worked out with your Prebid Server provider. It’s used at runtime to pull in the bidders and parameters specific to this adunit. Depending on your Prebid Server partner, it may be a UUID or constructed out of parts like an account number and adunit name.
To integrate the banner ad you need to implement three easy steps:
// 1. Create a banner custom event handler for GAM ad server.
val eventHandler = GamBannerEventHandler(requireContext(), GAM_AD_UNIT, GAM_AD_SIZE)
// 2. Create a bannerView instance and provide the GAM event handler
bannerView = BannerView(requireContext(), configId, eventHandler)
// (Optional) set an event listener
bannerView?.setBannerListener(this)
// Add bannerView to your viewContainer
viewContainer?.addView(bannerView)
// 3. Execute the loadAd function.
bannerView?.loadAd()
loadAd()
should be called on the main thread.
Prebid SDK’s GAM event handlers are special containers that wrap GAM Ad Views and help to manage collaboration between GAM and Prebid views.
Important: you should create and use a unique event handler for each ad view.
To create the event handler you should provide a GAM Ad Unit Id and the list of available sizes for this ad unit.
BannerView - is the view that will display a particular ad. It should be added to the UI. To create it you should provide:
Also, you should add the instance of BannerView
to the UI.
And assign the listeners for processing ad events.
Call the loadAd()
method to make a bid request.
For Non-Instream Video you also need to specify video placement type of the expected ad:
bannerView.videoPlacementType = PlacementType.IN_BANNER // or any other available type
GAM setup:
Integration:
AdManagerAdView
with BannerView
in the UI.BannerViewListener
.AdManagerAdView
and AdManagerAdRequest
and implement anAdListener
.BannerAdUnit
.To integrate an interstitial ad follow these steps:
// 1. Create an interstitial custom event handler for GAM ad server.
val eventHandler = GamInterstitialEventHandler(requireContext(), gamAdUnit)
// 2. Create an interstitialAdUnit instance and provide GAM event handler
interstitialAdUnit = InterstitialAdUnit(requireContext(), configId, minSizePercentage, eventHandler)
// (Optional) set an event listener
interstitialAdUnit?.setInterstitialAdUnitListener(this)
// 3. Execute the loadAd function.
interstitialAdUnit?.loadAd()
//....
// 4. After ad is loaded you can execute the `show` function to trigger ad display
interstitialAdUnit?.show()
loadAd()
should be called on the main thread.
The default ad format for an interstitial ad is DISPLAY. In order to make a multiformat bid request
, set the respective values into the adUnitFormats
parameter.
interstitialAdUnit = InterstitialAdUnit(
requireContext(),
configId,
EnumSet.of(AdUnitFormat.BANNER, AdUnitFormat.VIDEO),
eventHandler)
GAM’s event handlers are special containers that wrap the GAM Ad Views and help to manage collaboration between GAM and Prebid views.
Important: you should create and use a unique event handler for each ad view.
To create an event handler you should provide a GAM Ad Unit.
InterstitialAdUnit - is an object that will load and display a particular ad. To create it you should provide:
Also, you can assign the listeners for processing ad events.
NOTE: minSizePercentage - plays an important role in a bidding process for display ads. If the provided space is too small demand partners won’t respond with bids.
Call the loadAd()
method make a bid request. The ad unit will load an ad and will wait for explicit instructions to display the Interstitial Ad.
The most convenient way to determine if the interstitial ad is ready for displaying is to listen to the listener method:
override fun onAdLoaded(interstitialAdUnit: InterstitialAdUnit) {
//Ad is ready for display
}
GAM setup:
Integration:
AdManagerInterstitialAd
with InterstitialRenderingAdUnit
.InterstitialEventListener
.AdManagerInterstitialAd
and AdManagerAdRequest
.InterstitialAdUnit
.To display a Rewarded Ad follow these steps:
// 1. Create a rewarded custom event handler for GAM ad server.
val eventHandler = GamRewardedEventHandler(requireActivity(), gamAdUnitId)
// 2. Create a rewardedAdUnit instance and provide the GAM event handler
rewardedAdUnit = RewardedAdUnit(requireContext(), configId, eventHandler)
// You can also set an event listener, this step is optional.
rewardedAdUnit?.setRewardedAdUnitListener(this)
// 3. Execute the loadAd function.
rewardedAdUnit?.loadAd()
//...
// 4. After the ad is loaded you can execute the `show` function to display the ad.
rewardedAdUnit?.show()
loadAd()
should be called on the main thread.
Displaying the Rewarded Ad is the same as displaying an Interstitial Ad. The type of ad can be customized to:
Be notified when user earns a reward - implement RewardedAdUnitListener
interface:
fun onUserEarnedReward(rewardedAdUnit: RewardedAdUnit)
When the actual reward object is stored in the RewardedAdUnit
:
val reward = rewardedAdUnit.getUserReward()
GAM’s event handlers are special containers that wrap the GAM Ad Views and help to manage collaboration between GAM and Prebid views.
Important: you should create and use a unique event handler for each ad view.
To create an event handler you should provide a GAM Ad Unit.
RewardedAdUnit - is an object that will load and display the particular ad. To create it you should provide
You can also assign the listener for processing ad events.
Call the loadAd()
method to make a bid request. The ad unit will load an ad and will wait for explicit instructions to display the Rewarded Ad.
The most convenient way to determine if the ad is ready for displaying is to listen for the listener method:
override fun onAdLoaded(rewardedAdUnit: RewardedAdUnit) {
//Ad is ready for display
}
GAM setup:
Integration:
RewardedAd
with RewardedAdUnit
.RewardedAdUnitListener
.RewardedVideoAdUnit
.The adPosition
property allows developers to specify the position of the ad within the publisher’s content. This property maps to the pos
field in the OpenRTB specification under the imp[].banner
or imp[].video
objects, depending on the ad format. The possible values for this field could be found in the respective specification.
You can set adPosition
by using the following method:
adUnit.setAdPosition(AdPosition.FOOTER);