iOS启动图和开屏广告图,类似网易

466 查看

启动图是在iOS开发过程中必不可少的一个部分,很多app在启动图之后会有一张自定义的开屏广告图,点击该广告图可以跳转到广告图对应的页面。今天呢,和大家分享一下如何添加这张广告图以及点击广告图的跳转。这个广告图是通过将UIImageView添加到UIWindow上实现的。

一.添加本地启动图

1.准备好本地图片
2.找到工程中的Images.xcassets文件,打开LaunchImage,将图片拖到对应的地方,如下图:

11972702-f247659169c59891

添加启动图

3.将LaunchScreen.storyboard文件中右边的Use as Launch Screen选项关闭(不要选择此项)如图:

12972702-01ce8effba53de81

关闭Use as Launch Screen选项

4.将Launch Images Source选择为LaunchImage ,再将Launch Screen File置空。如图:

13972702-6e34e3b251ef2f57

5.可在Appdelegate中设置启动图停留的时间
// 启动页停留1秒 [NSThread sleepForTimeInterval:1];
6.运行工程可看到设置的启动图(如果没有,可将app先删除,然后重新运行一次即可)

二.添加开屏广告图
这个广告图的实现是基于作者周焕强App启动加载广告页面思路,然后自己增加了一些小补充。因为广告是有时效性的,不是每次启动的时候都会去显示这个广告页面。所以这里的原则是,后台返回的数据中包括广告图片、广告图片对应的URL、以及该广告的截止时间。运行程序时会请求广告图数据,将数据保存到本地。再次运行时从本地中将保存的图片取出,同时判断图片的截止日期是否有效,若图片存在且在有效期内,则将广告图显示出来;再次请求广告图数据,以免有新的广告数据。

1.创建自定义的SplashScreenView。我在将ImageView加到Window上时,遇到添加不成功的情况,后面打印window的时候发现,window的hidden属性是YES,于是将其设为NO后就成功了。

2.实现显示广告页的方法,这里会根据保存下来的广告图截止时间和是否有该图片去显示。比较日期的先后,可以先将当前日期和保存下来的广告图转换成相同的日期格式,将两者进行比较,根据比较结果的 升序或降序来判断日期的先后。

3.请求广告数据。请求数据时,先判断该图片是否存在,如果不存在的话,先将旧的图片删除掉,然后去下载新的图片。删除就照片的时候需要注意,先去判断保存下来的图片名字和本地沙盒中存在的图片是否一致,如果不一致,说明图片有更新,此时删除沙盒中的旧图片,如果一致,则不需要进行删除操作,否则找不到已保存的图片

最后的效果如图:

14972702-182bf3ec728102e9

启动图和开屏广告图.gif

demo地址