Skip to main content

横幅广告

一、注意事项#

  • 禁止在onAdLoadFailed回调中执行广告加载的方法,否则会引起死循环。
  • 开发者可以参考Demo中的banner.dart集成。

二、集成步骤#

1、请求广告#

//设置参数
Map customMap = {};
Map extraMap = TPBannerManager.createBannerExtraMap(
height: 60, width: 320, customMap: customMap, sceneId: sceneId);
//请求广告
TPBannerManager.loadBannerAd("在TP平台创建的广告位ID", extraMap: extraMap);

参数说明

unitId:TradPlus后台创建的广告位ID#
  • 开发者需正确填入,例如:unitId设置前后有空格,均会导致广告因拉不到配置而请求失败。
extraMap:额外参数#
  • width 横幅容器的宽度

  • height 横幅容器的高度

  • customMap:设置流量分组相关属性参数

  • localParams:设置本地参数。仅Android支持。个别广告平台特殊需要设定的参数。

  • sceneId :广告场景ID (推荐)

    开发者可在在TradPlus后台创建,位置如下:应用管理--广告场景。 具体如何调用,可以参考广告场景的调用时机和用途说明。 进入广告场景时传入sceneId,展示广告时也需传入sceneId,否则会影响统计。

2、检查是否有可用广告#

  • 开发者在监听到onAdLoaded回调后调用。
  • 建议开发者展示广告前,调用该API判断是否有可用广告,有广告再调用show方法
  • true表示有可用广告,false表示暂时无可用广告
bool isReady = await TPBannerManager.bannerAdReady("unitId");

3、进入广告场景#

//sceneId在TradPlus后台创建, 具体可参考load的参数说明
TPBannerManager.entryBannerAdScenario(unitId, sceneId: sceneId);

4、展示广告#

Flutter插件版本 v1.0.4+,iOS v8.5.0+, Android v8.8.0.1+

横幅广告支持原生广告混用,开发者可以通过可选参数 className 传入自定义原生模版名称。

//className 可选参数 (v1.0.4+)
return TPBannerViewWidget(unitId,className:"className");

5、监听回调#

参数说明

基础回调监听#

addListener() {
listener = TPBannerAdListener(
//加载完成
// V1.1.2 回调机制优化,开发者主动调用一次load才会对应回调一次loaded,不调用不回调
onAdLoaded: (adUnitId, adInfo) {
},
//加载失败
onAdLoadFailed: (adUnitId, error) {
},
//广告展示
onAdImpression: (adUnitId, adInfo) {
},
//展示失败
onAdShowFailed: (adUnitId, adInfo, error) {
},
//广告点击
onAdClicked: (adUnitId, adInfo) {
},
//广告关闭
onAdClosed: (adUnitId, adInfo) {
},
//单层广告源加载失败
oneLayerLoadFailed: (adUnitId, adInfo, error) {
},
)
//设置监听
TPBannerManager.setBannerListener(listener!);
}

广告源维度回调监听(可选)#

...
//广告源维度监听回调(可选)
onAdStartLoad: (adUnitId, adInfo) {
// 每次调用load方法时返回的回调
},
onBiddingStart: (adUnitId, adInfo) {
// Bidding开始加载
},
onBiddingEnd: (adUnitId, adInfo, error) {
// Bidding加载结束
// 配置Bidding广告源可监听
// 测试时,通过error获取bidding加载失败的原因
},
oneLayerStartLoad: (adUnitId, adInfo) {
// 每层waterfall向三方广告源发起请求前,触发的回调
},
oneLayerLoaded: (adUnitId, adInfo) {
// 后台配置多个广告源,每个广告源加载成功后会都会回调一次
},
onAdAllLoaded: (adUnitId, isSuccess) {
// 广告位的状态
// isSuccess 返回true,表示此次请求,有广告源加载成功
// isSuccess 返回false,表示此次请求,广告位adUnitId下所有广告源加载失败
},
onAdIsLoading: (adUnitId) {
// V1.0.5 新增
// 调用load之后如果收到此回调,说明广告位仍处于加载状态,无法触发新的一轮广告加载。
}
...

下载监听 快手、穿山甲支持(可选)(仅Android支持)#

...
onDownloadStart: (adUnitId, totalBytes, currBytes, fileName, appName) {
// 开始下载回调
// totalBytes:文件总大小(单位:字节)
// currBytes:当前已下载的大小(单位:字节)
// fileName:文件名称
// appName:文件对应的应用名称
},
onDownloadUpdate: (adUnitId, totalBytes, currBytes, fileName, appName, progress) {
// 下载进度更新回调
// progress:下载进度
},
onDownloadPause: (adUnitId, totalBytes, currBytes, fileName, appName) {
// 暂停下载回调
},
onDownloadFinish: (adUnitId, totalBytes, currBytes, fileName, appName) {
// 下载完成回调
},
onDownloadFail: (adUnitId, totalBytes, currBytes, fileName, appName) {
// 下载失败回调
},
onInstall: (adUnitId, totalBytes, currBytes, fileName, appName) {
// Apk安装完成回调
}
...