插屏广告是聚合了其他第三方广告平台的图片插屏广告和视频插屏广告,两种广告类型都是可以使用ATAdManager的API来实现广告的加载和播放。目前支持两种集成方式,具体说明如下:
模式(二选一) | 说明 |
---|---|
手动请求模式 | 由自行通过API选择合适的时机调用广告加载,具体参照文档下方集成建议 |
全自动加载模式 | Taku推出的一站式请求维护方案,能够根据用户的使用状态和广告消耗进度,自动判断下一条广告的预加载和缓存时机,以达到更优的加载效果,具体见:插屏广告全自动加载模式 |
false:重新执行ATInterstitialAd#loadInterstitialAd来加载广告
true:执行ATInterstitialAd#showInterstitialAd展示广告,在onInterstitialAdClose的回调中再执行ATInterstitialAd#loadInterstitialAd来预加载下一次的广告(在onInterstitialAdClose的回调里可直接调用loadInterstitialAd不需要经过hasInterstitialAdReady的判断,有助于提升优先级比较高的广告源的展示量.)
3.广告预加载:
插屏广告展示后,onInterstitialAdShow(v5.8.10及之后)或onInterstitialAdClose(低于v.5.8.10)的回调中无需ATInterstitialAd#hasInterstitialAdReady判断,直接调用ATInterstitialAd#loadInterstitialAd进行预加载(有助于提升优先级比较高的广告源的展示量)
可参考自动请求广告,开启自动请求广告(若已实现上方展示后预加载则不用开启)
4.如需使用广告场景区分不同业务场景的数据,具体参考示例代码
ATInterstitialAd:
API | 参数 | 说明 |
---|---|---|
loadInterstitialAd | string placementid,Dictionary | 加载广告 |
setListener | ATInterstitialAdListener listener | 设置监听回调接口 (5.9.51版本之后废弃)设置监听器的方式具体参考: 插屏广告事件设置说明 |
hasInterstitialAdReady | string placementid | 判断是否有广告缓存 |
checkAdStatus | string placementid | (v5.7.03新增)获取当前广告位的状态(Json字符串): 1、isLoading:是否正在加载 2、isReady:是否有广告缓存(与hasInterstitialAdReady作用相同) 3、AdInfo:当前优先级最高的广告缓存信息(参考ATCallbackInfo说明) |
getValidAdCaches | string placementid | (v5.7.54新增)获取加载成功的全部广告缓存信息(JSON字符串) (参考ATCallbackInfo说明) |
showInterstitialAd | string placementid,Dictionary | 显示广告 |
entryScenarioWithPlacementID | string placementId, string scenarioID | 设置进入可展示广告场景 |
使用以下代码加载插屏广告
public void loadInterstitialAd()
{
ATInterstitialAd.Instance.client.onAdLoadEvent += onAdLoad;
ATInterstitialAd.Instance.client.onAdLoadFailureEvent += onAdLoadFail;
ATInterstitialAd.Instance.client.onAdShowEvent += onShow;
ATInterstitialAd.Instance.client.onAdClickEvent += onAdClick;
ATInterstitialAd.Instance.client.onAdCloseEvent += onAdClose;
ATInterstitialAd.Instance.client.onAdShowFailureEvent += onAdShowFail;
ATInterstitialAd.Instance.client.onAdVideoStartEvent += startVideoPlayback;
ATInterstitialAd.Instance.client.onAdVideoEndEvent += endVideoPlayback;
ATInterstitialAd.Instance.client.onAdVideoFailureEvent += failVideoPlayback;
Dictionary jsonmap = new Dictionary();
ATInterstitialAd.Instance.loadInterstitialAd(mPlacementId_interstitial_all, jsonmap);
}
注: 请参阅下文,了解如何获得有关插屏广告事件的通知(加载成功/失败,展示,点击,视频开始/结束)。
ATInterstitialAd.Instance.hasInterstitialAdReady(mPlacementId_interstitial_all);
与激励视频相同,插屏广告只要调用展示api并传递展示广告位ID作为参数:
public void showInterstitialAd()
{
ATInterstitialAd.Instance.showInterstitialAd(mPlacementId_interstitial_all);
}
当用到 场景 功能时:
public void showInterstitialAd()
{
Dictionary jsonmap = new Dictionary();
jsonmap.Add(AnyThinkAds.Api.ATConst.SCENARIO, showingScenarioID);
ATInterstitialAd.Instance.showInterstitialAd(mPlacementId_interstitial_all, jsonmap);
}
回调信息详情请查看:回调信息说明
使用以下代码实现多个监听器
//广告加载成功
ATInterstitialAd.Instance.client.onAdLoadEvent += onAdLoad;
//广告加载失败
ATInterstitialAd.Instance.client.onAdLoadFailureEvent += onAdLoadFail;
//广告展示(可以依赖该回调进行展示统计)
ATInterstitialAd.Instance.client.onAdShowEvent += onShow;
//广告点击
ATInterstitialAd.Instance.client.onAdClickEvent += onAdClick;
//广告关闭
ATInterstitialAd.Instance.client.onAdCloseEvent += onAdClose;
//广告展示失败
ATInterstitialAd.Instance.client.onAdShowFailureEvent += onAdShowFail;
//视频广告播放开始
ATInterstitialAd.Instance.client.onAdVideoStartEvent += startVideoPlayback;
//视频广告播放结束
ATInterstitialAd.Instance.client.onAdVideoEndEvent += endVideoPlayback;
//视频广告播放失败
ATInterstitialAd.Instance.client.onAdVideoFailureEvent += failVideoPlayback;
进阶监听设置
//广告源启动请求
ATInterstitialAd.Instance.client.onAdSourceAttemptEvent += startLoadingADSource;
//广告源加载成功
ATInterstitialAd.Instance.client.onAdSourceFilledEvent += finishLoadingADSource;
//广告源加载失败
ATInterstitialAd.Instance.client.onAdSourceLoadFailureEvent += failToLoadADSource;
//广告源Bidding启动
ATInterstitialAd.Instance.client.onAdSourceBiddingAttemptEvent += startBiddingADSource;
//广告源Bidding成功
ATInterstitialAd.Instance.client.onAdSourceBiddingFilledEvent += finishBiddingADSource;
//广告源Bidding失败
ATInterstitialAd.Instance.client.onAdSourceBiddingFailureEvent += failBiddingADSource;
方法定义参数如下代码(注意 : 方法名可参考以下代码或者自定义方法名,但参数必须一致)
//sender 为广告类型对象,erg为返回信息
//广告被点击
public void onAdClick(object sender,ATAdEventArgs erg)
{
Debug.Log("Developer callback onInterstitialAdClick :" + erg.placementId);
}
//广告被关闭
public void onAdClose(object sender,ATAdEventArgs erg)
{
Debug.Log("Developer callback onInterstitialAdClose :" + erg.placementId);
}
//广告视频播放结束,部分广告平台有此回调
public void endVideoPlayback(object sender,ATAdEventArgs erg)
{
Debug.Log("Developer callback onInterstitialAdEndPlayingVideo :" + erg.placementId);
}
//广告视频播放失败,部分广告平台有此回调
public void failVideoPlayback(object sender,ATAdEventArgs erg)
{
Debug.Log("Developer callback onInterstitialAdFailedToPlayVideo :" + erg.placementId + "--code:" + erg.code + "--msg:" + erg.message);
}
//广告加载成功
public void onAdLoad(object sender,ATAdEventArgs erg)
{
Debug.Log("Developer callback onInterstitialAdLoad :" + erg.placementId);
}
//广告加载失败
public void onAdLoadFail(object sender,ATAdErrorEventArgs erg )
{
Debug.Log("Developer callback onInterstitialAdLoadFail :" + erg.placementId + "--erg.code:" + code + "--msg:" + erg.message);
}
//广告展示成功
public void onShow(object sender,ATAdEventArgs erg)
{
Debug.Log("Developer callback onInterstitialAdShow :" +erg. placementId);
}
//广告视频开始播放,部分平台有此回调
public void startVideoPlayback(object sender,ATAdEventArgs erg)
{
Debug.Log("Developer callback onInterstitialAdStartPlayingVideo :" + erg.placementId);
}
//广告展示失败
public void failVideoPlayback(object sender,ATAdEventArgs erg)
{
Debug.Log("Developer callback onInterstitialAdFailedToShow :" + erg.placementId);
}
// v5.8.10 新增广告源层级回调
// 广告源开始加载
public void startLoadingADSource(object sender,ATAdEventArgs erg){
Debug.Log("Developer startLoadingADSource------");
}
// 广告源加载完成
public void finishLoadingADSource(object sender,ATAdEventArgs erg){
Debug.Log("Developer finishLoadingADSource------");
}
// 广告源失败
public void failToLoadADSource(object sender,ATAdEventArgs erg){
Debug.Log("Developer failToLoadADSource------");
}
// 广告源开始bidding
public void startBiddingADSource(object sender,ATAdEventArgs erg){
Debug.Log("Developer startBiddingADSource------");
}
// 广告源bidding成功
public void finishBiddingADSource(object sender,ATAdEventArgs erg){
Debug.Log("Developer finishBiddingADSource------");
}
// 广告源bidding失败
public void failBiddingADSource(object sender,ATAdEventArgs erg){
Debug.Log("Developer failBiddingADSource------");
}
您可以实现ATInterstitialAdListener接口的类,来获得有关插屏广告事件的通知:(注意:对于Android来说,所有回调方法均不在Unity的主线程)
class InterstitalCallback : ATInterstitialAdListener
{
//广告被点击
public void onInterstitialAdClick(string placementId, ATCallbackInfo callbackInfo)
{
Debug.Log("Developer callback onInterstitialAdClick :" + placementId);
}
//广告被关闭
public void onInterstitialAdClose(string placementId, ATCallbackInfo callbackInfo)
{
Debug.Log("Developer callback onInterstitialAdClose :" + placementId);
}
//广告视频播放结束,部分广告平台有此回调
public void onInterstitialAdEndPlayingVideo(string placementId, ATCallbackInfo callbackInfo)
{
Debug.Log("Developer callback onInterstitialAdEndPlayingVideo :" + placementId);
}
//广告视频播放失败,部分广告平台有此回调
public void onInterstitialAdFailedToPlayVideo(string placementId, string code, string message)
{
Debug.Log("Developer callback onInterstitialAdFailedToPlayVideo :" + placementId + "--code:" + code + "--msg:" + message);
}
//广告加载成功
public void onInterstitialAdLoad(string placementId)
{
Debug.Log("Developer callback onInterstitialAdLoad :" + placementId);
}
//广告加载失败
public void onInterstitialAdLoadFail(string placementId, string code, string message)
{
Debug.Log("Developer callback onInterstitialAdLoadFail :" + placementId + "--code:" + code + "--msg:" + message);
}
//广告展示成功
public void onInterstitialAdShow(string placementId, ATCallbackInfo callbackInfo)
{
Debug.Log("Developer callback onInterstitialAdShow :" + placementId);
}
//广告视频开始播放,部分平台有此回调
public void onInterstitialAdStartPlayingVideo(string placementId, ATCallbackInfo callbackInfo)
{
Debug.Log("Developer callback onInterstitialAdStartPlayingVideo :" + placementId);
}
//广告展示失败
public void onInterstitialAdFailedToShow(string placementId)
{
Debug.Log("Developer callback onInterstitialAdFailedToShow :" + placementId);
}
// v5.8.10 新增广告源层级回调
// 广告源开始加载
public void startLoadingADSource(string placementId, ATCallbackInfo callbackInfo){
Debug.Log("Developer startLoadingADSource------");
}
// 广告源加载完成
public void finishLoadingADSource(string placementId, ATCallbackInfo callbackInfo){
Debug.Log("Developer finishLoadingADSource------");
}
// 广告源失败
public void failToLoadADSource(string placementId,ATCallbackInfo callbackInfo,string code, string message){
Debug.Log("Developer failToLoadADSource------");
}
// 广告源开始bidding
public void startBiddingADSource(string placementId, ATCallbackInfo callbackInfo){
Debug.Log("Developer startBiddingADSource------");
}
// 广告源bidding成功
public void finishBiddingADSource(string placementId, ATCallbackInfo callbackInfo){
Debug.Log("Developer finishBiddingADSource------");
}
// 广告源bidding失败
public void failBiddingADSource(string placementId,ATCallbackInfo callbackInfo,string code, string message){
Debug.Log("Developer failBiddingADSource------");
}
}
注: 您在本节中看到的代码段摘自我们Demo的interstitialScenes.cs demo project.