最近项目里有一个广告启动页的需求跟进,就是现在很多App都会有的启动页广告。我首先想到的自然是去github上找现成的第三方,但找来找去都不太符合我们的需求。很多第三方都只实现了展示广告页的功能,但应用到实际的使用还是有很多逻辑没有实现。
首先下载广告和展示广告应该是异步的,因为下载图片需要时间,尤其是广告图片往往会根据API动态改变,很多时候需要先请求API拿到新的图片地址才能下载和展示图片,对于启动广告这种争分夺秒的场景来说很不划算。因此我设计了一下我的启动页的流程图。
首先获取广告数据和展示广告数据的功能是分开且异步的。 当你从后端拿到广告数据后,就会立刻对数据进行分析。首先判断该数据是否已经储存在了本地。如果是则不做任何操作。如果不存在,则将图片下载下来,并将本地路径和跳转链接一并存储在UserDefaults中。
而与此同时,广告显示并不受当前广告数据的影响,直接读取本地数据。如果存在(表明之前启动过程中已经下载过数据),则直接展示,如果没有(可能是用户第一次启动,也有可能是之前请求的是一个空的广告数据,即远程关闭了广告显示功能),则直接跳过显示广告的功能。
逻辑看起来似乎有点乱,实际使用的结果应该是:首次启动App没有广告页,之后启动都会显示之前储存在本地的数据。这会带来一个问题,就是当天发布的新广告可能无法立即显示在App上,但因为启动广告页不会频繁的变动,不会特别明显。如果需要精确到某一天,可以在广告数据中加入时间戳,然后储存两组数据,一组是当前显示的数据,另外一组是提前下载好的将要展示的数据,这也需要后端配合,提前更新API数据。此外如果想暂时取消掉启动页广告,只要发送一个空的广告数据,前端没有检测到图片,就自然不展示了。 最后很多公司都有跳转到App内特定页面到需求,我也在公司的项目内做了实现,主要就是将URL替换成页面的数据,因为每家公司的Model格式都不相似,就没有在这个Demo里实现。
不过在测试过程中遇到了一个问题,启动页有机率会延迟出现,导致屏幕先短暂出现正常的VC,然后再出现广告页的情况。后来我发现,将广告展示代码放入AppDelegate、UITabbarController的初始化方法中,会因为这些类的初始化代码是异步运行的,导致可能会出现界面早于启动页出现的情况。解决方法是将展示代码放在App启动的第一个子VC的初始化方法中。
最后的实现效果
我将这个功能封装了一下,一个文件,两行代码即可实现。 https://github.com/jihongboo/LaunchADView