中国优质的IT技术网站
专业IT技术创作平台
IT职业在线教育平台
如何展示一个原生广告
微信扫码分享
import { router } from '@kit.ArkUI'; import { advertising, identifier } from '@kit.AdsKit'; import { common, abilityAccessCtrl } from '@kit.AbilityKit'; import { BusinessError } from '@kit.BasicServicesKit'; import { hilog } from '@kit.PerformanceAnalysisKit'; const TAG = 'Ads Demo-LoadAd'; /** * 原生广告页面 */ @Entry @Component export struct LoadAd { private context: common.UIAbilityContext = getContext(this) as common.UIAbilityContext; private oaid: string = ''; // 广告展示参数 private adDisplayOptions: advertising.AdDisplayOptions = { // 是否静音,默认不静音 mute: false } // 原生广告配置 private adOptions: advertising.AdOptions = { // 是否允许流量下载 0不允许 1允许,不设置以广告主设置为准 allowMobileTraffic: 0, // 是否希望根据 COPPA 的规定将您的内容视为面向儿童的内容: -1默认值,不确定 0不希望 1希望 tagForChildProtection: -1, // 是否希望按适合未达到法定承诺年龄的欧洲经济区 (EEA) 用户的方式处理该广告请求: -1默认值,不确定 0不希望 1希望 tagForUnderAgeOfPromise: -1, // 设置广告内容分级上限: W: 3+,所有受众 PI: 7+,家长指导 J:12+,青少年 A: 16+/18+,成人受众 adContentClassification: 'A' } // 原生视频广告请求参数 private nativeVideoAdReqParams: advertising.AdRequestParams = { adId: 'testy63txaom86', adType: AdType.NATIVE_AD, adCount: 1, // 原生广告自定义扩展参数。等所有广告素材下载完后再回调 enableDirectReturnVideoAd: true } // 原生大图广告请求参数 private nativeBigImageAdReqParams: advertising.AdRequestParams = { adId: 'testu7m3hc4gvm', adType: AdType.NATIVE_AD, adCount: 1, // 原生广告自定义扩展参数。等所有广告素材下载完后再回调 enableDirectReturnVideoAd: true } // 原生三图广告请求参数 private nativeThreeImageAdReqParams: advertising.AdRequestParams = { adId: 'testr6w14o0hqz', adType: AdType.NATIVE_AD, adCount: 1, // 原生广告自定义扩展参数。等所有广告素材下载完后再回调 enableDirectReturnVideoAd: true } // 原生小图广告请求参数 private nativeSmallImageAdReqParams: advertising.AdRequestParams = { adId: 'testb65czjivt9', adType: AdType.NATIVE_AD, adCount: 1, // 原生广告自定义扩展参数。等所有广告素材下载完后再回调 enableDirectReturnVideoAd: true } aboutToAppear() { try { // 使用Promise回调方式获取OAID this.requestOAIDTrackingConsentPermissions(this.context); } catch (error) { hilog.error(0x0000, TAG, '%{public}s', `catch err, code: ${error.code}, message: ${error.message}`); } hilog.info(0x0000, TAG, '%{public}s', 'aboutToAppear'); } build() { Column() { this.actionBar($r("app.string.ads_demo_title")) Column() { // 跳转到原生视频广告展示页面 this.customButton($r("app.string.request_native_video_ad_btn"), () => { this.requestAd(this.nativeVideoAdReqParams, this.adOptions); }) // 跳转到原生大图广告展示页面 this.customButton($r("app.string.request_native_big_image_ad_btn"), () => { this.requestAd(this.nativeBigImageAdReqParams, this.adOptions); }) // 跳转到原生小图广告展示页面 this.customButton($r("app.string.request_native_small_image_ad_btn"), () => { this.requestAd(this.nativeSmallImageAdReqParams, this.adOptions); }) // 跳转到原生三图广告展示页面 this.customButton($r("app.string.request_native_three_image_ad_btn"), () => { this.requestAd(this.nativeThreeImageAdReqParams, this.adOptions); }) }.width('100%').height('80%').justifyContent(FlexAlign.Center) } .width('100%') .height('100%') } private requestAd(adReqParams: advertising.AdRequestParams, adOptions: advertising.AdOptions): void { // 给AdRequestParams设置oaid参数 adReqParams.oaid = this.oaid; // 广告请求回调监听 const adLoaderListener: advertising.AdLoadListener = { // 广告请求失败回调 onAdLoadFailure: (errorCode: number, errorMsg: string) => { hilog.error(0x0000, TAG, '%{public}s', `request ad errorCode is: ${errorCode}, errorMsg is: ${errorMsg}`); }, // 广告请求成功回调 onAdLoadSuccess: (ads: Array<advertising.Advertisement>) => { hilog.info(0x0000, TAG, '%{public}s', 'succeeded in requesting ad!'); // 保存请求到的广告内容用于展示 if (canIUse('SystemCapability.Advertising.Ads')) { if (ads[0].adType === AdType.NATIVE_AD) { // 调用原生广告展示页面 routePage('pages/NativeAdPage', ads, this.adDisplayOptions); } else { hilog.warn(0x0000, TAG, '%{public}s', 'error adType'); } } } }; // 创建AdLoader广告对象 const load: advertising.AdLoader = new advertising.AdLoader(this.context); // 调用广告请求接口 hilog.info(0x0000, TAG, '%{public}s', 'request ad!'); load.loadAd(adReqParams, adOptions, adLoaderListener); } private requestOAIDTrackingConsentPermissions(context: common.Context): void { // 进入页面时触发动态授权弹框,向用户请求授权广告跟踪权限 const atManager: abilityAccessCtrl.AtManager = abilityAccessCtrl.createAtManager(); try { atManager.requestPermissionsFromUser(context, ['ohos.permission.APP_TRACKING_CONSENT']).then((data) => { if (data.authResults[0] == 0) { hilog.info(0x0000, TAG, '%{public}s', 'succeeded in requesting permission'); identifier.getOAID().then((data: string) => { this.oaid = data; hilog.info(0x0000, TAG, '%{public}s', `succeeded in getting adsIdentifierInfo by promise`); }).catch((error: BusinessError) => { hilog.error(0x0000, TAG, '%{public}s', `getAdsIdentifierInfo failed, message: ${error.message}`); }) } else { hilog.info(0x0000, TAG, '%{public}s', 'user rejected'); } }).catch((err: BusinessError) => { hilog.error(0x0000, TAG, '%{public}s', `request permission failed, error: ${err.code} ${err.message}`); }) } catch (err) { hilog.error(0x0000, TAG, '%{public}s', `catch err, code: ${err.code}, msg: ${err.message}`); } } @Builder actionBar(title: Resource | string) { Row() { if (title) { Text(title) .fontSize(24) .fontColor(Color.White) .fontWeight(FontWeight.Medium) .margin({ left: 16 }) } } .width('100%') .height('10%') .padding({ top: 16, bottom: 16, left: 24, right: 24 }) .backgroundColor(Color.Black) } @Builder customButton(mText: string | Resource, mOnClick: (event?: ClickEvent) => void) { Column() { Button(mText) .backgroundColor('#d3d4d6') .fontSize(20) .fontColor('#000') .fontWeight(FontWeight.Normal) .align(Alignment.Center) .type(ButtonType.Capsule) .width('90%') .height(40) .margin({ top: 10, bottom: 5 }) .onClick(mOnClick); } } } enum AdType { // 原生广告的类型 NATIVE_AD = 3 } async function routePage(pageUri: string, ads: Array<advertising.Advertisement | null>, displayOptions: advertising.AdDisplayOptions) { let options: router.RouterOptions = { url: pageUri, params: { ads: ads, displayOptions: displayOptions } } try { hilog.info(0x0000, TAG, '%{public}s', `routePage + ${pageUri}`); router.pushUrl(options); } catch (error) { hilog.error(0x0000, TAG, '%{public}s', `routePage fail callback, code: ${error.code}, msg: ${error.message}`); } }