【快应用】快应用中开屏广告模拟

2023-10-25 14:36
文章标签 应用 模拟 广告 开屏

本文主要是介绍【快应用】快应用中开屏广告模拟,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 【关键词】

开屏、原生广告、stack

【问题背景】

快应用中目前暂时不支持开屏广告,开发者如想在应用启动时展示广告,可以在快应用中用原生广告来模拟替代,从而来实现开屏广告的效果。

【问题分析】

实现上是比较简单的,首先需要将首页替换成一个只有原生广告展示的ux页面,然后在展示几秒后,通过router接口跳转到快应用的实际首页。

同时在模拟的开屏广告页上还需要加个关闭广告的按钮,可以点击后提前关闭广告跳转到后续页面。

【解决方案】

布局方面实现:

1、  由于原生广告返回的可能是图片或者视频,需要使用stack组件将它们堆叠在一起实现,后续可以根据原生广告请求返回的值来决定使用image还是video组件。

    <stack class="stackstyle" onclick="reportNativeClick()"><image if="native.isShowImg" class="img" src="{{native.adImgSrc}}"></image><video id="video" if="native.isShowVideo" src="{{native.adVideoSrc}}" autoplay="true" onclick="reportNativeClick()" class="video"></video></stack>

2、  关闭按钮实现,通过position属性将关闭按钮固定在右上角。

<text class="closebtn" onclick="closeAd">关闭{{value}}</text>.closebtn {width: 80px;height: 60px;border-radius: 30px;font-size: 25px;text-align: center;border: 1px solid #d1cdcd;right: 10;top: 10;position: absolute;}

主要逻辑代码实现:

1、  开屏广告的请求与展示(其实就是原生广告的请求与展示)

2、  通过定时器来实现一个倒计时效果,在广告展示几秒后自动跳转下一页面。

3、  关闭按钮点击,关闭广告展示和立即跳转下一页面。

        onShow(options) {'// Do something .'this.showNativeAd()this.cutdown()setTimeout(() => {router.replace({uri: '/Hello',})}, 4000);},cutdown() {var timer = setInterval(() => {this.value--}, 1000);if (this.value === 0) {clearInterval(timer);}console.log(222);},

【完整代码】

<template><!-- Only one root node is allowed in template. --><div class="container"><stack class="stackstyle" onclick="reportNativeClick()"><image if="native.isShowImg" class="img" src="{{native.adImgSrc}}"></image><video id="video" if="native.isShowVideo" src="{{native.adVideoSrc}}" autoplay="true" onclick="reportNativeClick()" class="video"></video></stack><text class="closebtn" onclick="closeAd">关闭{{value}}</text></div></template><style>.container {flex-direction: column;justify-content: center;align-items: center;}.title {font-size: 100px;}.img {width: 100%;height: 100%;object-fit: fill;}.video {width: 100%;height: 100%;}.stackstyle {width: 100%;height: 100%;}.closebtn {width: 80px;height: 60px;border-radius: 30px;font-size: 25px;text-align: center;border: 1px solid #d1cdcd;right: 10;top: 10;position: absolute;}</style><script>import ad from '@service.ad';import prompt from '@system.prompt';import router from '@system.router';let nativeAd;module.exports = {data: {componentName: "ad",provider: "",native: {adUnitId: "testb65czjivt9",isShow: false,adData: {},isShowImg: true,isShowVideo: false,isShowData: true,errStr: "",adImgSrc: "",adVideoSrc: ""},value: 4},onShow(options) {'// Do something .'this.showNativeAd()this.cutdown()setTimeout(() => {router.replace({uri: '/Hello',})}, 4000);},cutdown() {var timer = setInterval(() => {this.value--}, 1000);if (this.value === 0) {clearInterval(timer);}console.log(222);},closeAd() {this.native.isShowImg = falsethis.native.isShowVideo = falseclearTimeout(this.timerr);router.replace({uri: '/Hello',})},getAdProvider: function () {this.provider = ad.getProvider();prompt.showToast({message: "getProvider : " + this.provider,duration: 2000,gravity: "center"});},showNativeAd() {this.getAdProvider();if (this.provider !== "huawei") {console.info("the device  does not support ad.");return;}nativeAd = ad.createNativeAd({ adUnitId: this.native.adUnitId });nativeAd.onLoad(data => {console.info("ad data loaded: " + JSON.stringify(data));this.native.adData = data.adList[0];if (this.native.adData) {if (this.native.adData.imgUrlList) {this.native.adImgSrc = this.native.adData.imgUrlList[0];console.info(" this.native.adImgSrc =" + this.native.adImgSrc);this.native.isShowImg = true;} else {this.native.isShowImg = false;this.native.adImgSrc = "";}if (this.native.adData.videoUrlList && this.native.adData.videoUrlList[0]) {this.native.adVideoSrc = this.native.adData.videoUrlList[0];this.native.isShowVideo = true;} else {this.native.isShowVideo = false;this.native.adVideoSrc = "";}this.native.isShow = true;this.native.errStr = "";this.reportNativeShow();}});nativeAd.onError(e => {console.error("load ad error:" + JSON.stringify(e));this.native.isShowImg = false;this.native.isShowVideo = false;this.native.isShow = false;this.native.errStr = JSON.stringify(e);});nativeAd.load();},reportNativeShow() {if (nativeAd) {nativeAd.reportAdShow({ adId: this.native.adData.adId });}},reportNativeClick() {nativeAd.reportAdClick({adId: this.native.adData.adId});},}</script>

这篇关于【快应用】快应用中开屏广告模拟的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/283225

相关文章

Java Stream 的 Collectors.toMap高级应用与最佳实践

《JavaStream的Collectors.toMap高级应用与最佳实践》文章讲解JavaStreamAPI中Collectors.toMap的使用,涵盖基础语法、键冲突处理、自定义Map... 目录一、基础用法回顾二、处理键冲突三、自定义 Map 实现类型四、处理 null 值五、复杂值类型转换六、处理

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

Java Stream流之GroupBy的用法及应用场景

《JavaStream流之GroupBy的用法及应用场景》本教程将详细介绍如何在Java中使用Stream流的groupby方法,包括基本用法和一些常见的实际应用场景,感兴趣的朋友一起看看吧... 目录Java Stream流之GroupBy的用法1. 前言2. 基础概念什么是 GroupBy?Stream

python中列表应用和扩展性实用详解

《python中列表应用和扩展性实用详解》文章介绍了Python列表的核心特性:有序数据集合,用[]定义,元素类型可不同,支持迭代、循环、切片,可执行增删改查、排序、推导式及嵌套操作,是常用的数据处理... 目录1、列表定义2、格式3、列表是可迭代对象4、列表的常见操作总结1、列表定义是处理一组有序项目的

python运用requests模拟浏览器发送请求过程

《python运用requests模拟浏览器发送请求过程》模拟浏览器请求可选用requests处理静态内容,selenium应对动态页面,playwright支持高级自动化,设置代理和超时参数,根据需... 目录使用requests库模拟浏览器请求使用selenium自动化浏览器操作使用playwright

C#中的Converter的具体应用

《C#中的Converter的具体应用》C#中的Converter提供了一种灵活的类型转换机制,本文详细介绍了Converter的基本概念、使用场景,具有一定的参考价值,感兴趣的可以了解一下... 目录Converter的基本概念1. Converter委托2. 使用场景布尔型转换示例示例1:简单的字符串到

Spring Boot Actuator应用监控与管理的详细步骤

《SpringBootActuator应用监控与管理的详细步骤》SpringBootActuator是SpringBoot的监控工具,提供健康检查、性能指标、日志管理等核心功能,支持自定义和扩展端... 目录一、 Spring Boot Actuator 概述二、 集成 Spring Boot Actuat