-
Couldn't load subscription status.
- Fork 2
Rewarded Ads
Rewarded ad units enable users to play games, take surveys, or watch videos to earn in-app rewards, such as coins, extra lives, or points.
This guide explains how to integrate rewarded video ads into an iOS app.
flowchart TD
A[isAutoloadEnabled] -->|auto| L((loadAd))
L -->|success| R([didLoadContent])
L -->|fail| F([didFailToLoadWithError])
F -->|delay| A
R --> RL[isAdLoaded]
S((present)) --> RL
RL -->|success| SR([willPresentContent])
RL -->|fail| SF([didFailToPresentWithError])
SR --> I([didRecordImpression])
SR --> C([didClickContent])
I --> UR([userDidEarnRewardHandler])
UR --> D([didDismissContent])
D --> A
SF --> A
Ad instance can be initialized along with the UIViewController before viewDidLoad.
import CleverAdsSolutions
class MyViewController: UIViewController, CASScreenContentDelegate {
let rewardedAd = CASRewarded(casID: MyAppDelegate.casID)
The SDK provides the capability to create and precache multiple ad instances, enabling uninterrupted sequential ad display. CAS SDK will load mediation ads in order for each created instance.
The CASScreenContentDelegate handles events related to displaying your CASInterstitial. Callbacks are called on the main thread. Before showing ad, make sure to set delegate.
func screenAdDidLoadContent(_ ad: any CASScreenContent) {
// Called when the ad content has been successfully loaded.
}
func screenAd(_ ad: any CASScreenContent, didFailToLoadWithError error: AdError) {
// Called when the ad content fails to load.
}
func screenAd(_ ad: any CASScreenContent, didFailToPresentWithError error: AdError) {
// Called when the ad content fails to present.
}
func screenAdWillPresentContent(_ ad: any CASScreenContent) {
// Called when the ad content is successfully shown.
}
func screenAdDidClickContent(_ ad: any CASScreenContent) {
// Called when the ad content is clicked by the user.
}
func screenAdDidDismissContent(_ ad: any CASScreenContent) {
// Called when the ad content is dismissed.
}Note
- Read more about
AdContentInfostructure in Impression Level Data. - Attempting to load a new ad from the
didFailToLoadWithErrormethod is strongly discouraged. Limit ad load retries to avoid continuous failed ad requests in situations such as limited network connectivity. - When an error occurs during ad impression, executed the
didFailToPresentWithErroronly. In this case thedidDismissContentwill not be executed, since the impression is not considered successful.
The next step is to fill out the loadAd() method and handle the ad load callbacks.
override func viewDidLoad() {
super.viewDidLoad()
let screenContentDelegate: CASScreenContentDelegate = self
rewardedAd.delegate = screenContentDelegate
rewardedAd.loadAd();
}You can use ad load calls to build up a cache of preloaded ads before you intend to show them, so that ads can be shown with zero latency when needed. Since ads expire after an hour, you should clear this cache and reload with new ads every hour.
If enabled, the ad will automatically load new content when the current ad is dismissed or completed. Additionally, it will automatically retry loading the ad if an error occurs during the loading process.
override func viewDidLoad() {
super.viewDidLoad()
let screenContentDelegate: CASScreenContentDelegate = self
rewardedAd.delegate = screenContentDelegate
rewardedAd.isAutoloadEnabled = true
}By default autoload disabled.
When you present a rewarded ad, you will use an userDidEarnRewardHandler to handle reward for the user.
rewardedAd.present(from: self, userDidEarnRewardHandler: { (info: AdContentInfo) in
// Called when a user earns a reward from the ad.
// TODO: Reward the user
})The UIViewController parameter is an optional. The SDK uses the app’s main window to look up view controllers automatically when one is not provided.
Starting with CAS SDK version 4.3.0, all ads functions can be safely called from any thread.
Use isAdLoaded to check whether an ad is currently loaded.
if rewardedAd.isAdLoaded {
}Even if isAdLoaded returns true, it does not guarantee that the ad will be shown successfully — various issues may still prevent it from being displayed. We strongly recommend handling potential display failures via screenAd(_:didFailToPresentWithError:) delegate to ensure a smoother user experience.
By relying on these delegate, you ensure that your application can react appropriately to real-time conditions, rather than making assumptions based on ad load state at a single point in time.
Controls whether interstitial ads are shown as a fallback when a rewarded video ad has no available fill. Interstitial ads do not require the user to watch the entire ad to completion. However, the userDidEarnRewardHandler will still be triggered as if the user completed the rewarded video.
This option is enabled by default. You can disable extra fill by following line:
rewardedAd.isExtraFillInterstitialAdEnabled = falseIndicates if the application’s audio is muted. Affects initial mute state for all ads.
Use this method only if your application has its own volume controls.
CAS.settings.mutedAdSounds = trueIt is important to destroy() loaded but not displayed ads.
deinit {
rewardedAd.destroy();
}- SwiftUI Rewarded Ad ViewModel
- Swift Rewarded Ad UIViewController
- Objective-C Rewarded Ad UIViewController
🔗 Next
Native Ad
Tip
We've moved!
Visit the updated CAS.AI docs.
- Integration
- Initialization
- Additional mediation steps
- AppStore data disclosure
- App-ads.txt🔗
- App Open Ad
- Banner Ad
- Interstitial Ad
- Rewarded Ad
- Native Ad