iOS广告页的实现及注意点

在大多数app启动过程中都会出现广告页,那么现在说说到底是如何实现的。
实现思路:
  • 自定义一个广告页viewController(里面包含广告图及倒计时按钮),根据情况切换根控制器。
  • 每次进入app默认将广告页控制器作为self.window.rootViewController
  • 当点击跳过按钮或倒计时结束,self.window.rootViewController切换为TabBarController;
  • 当点击图片时self.window.rootViewController切换为TabBarController,并在主线程中发送通知让首页push到加载广告内容的webViewController中,当pop回来时回到首页。
注意点:
  • 点击跳过按钮移除该view,进入首页
  • 点击图片跳转到webView加载的视图中,此时可以返回到首页(这里发出通让首页控制器跳转到webView中)
  • 没有网络时也会加载,此时我们要从本地取出上次加载的广告页图片及对应的url
  • 倒数时间完成进入首页
  • 关于通知的的发送与接收必须要保证在同一线程中

在这里我是用了Masonry SDWebImage这两个框架,具体作用你们都懂得。
在实际项目中我们会用AFN请求网络数据,并且封装成model使用,这里我就直接设置imageUrl了。。。
自定义广告页view
ZSCustomAdvertisementViewController.h

#import <UIKit/UIKit.h>
typedef void (^ CustomAdvertisementViewClickBlock)(void);
typedef void (^ CustomSkipButtonClickBlock)(void);
@interface ZSCustomAdvertisementViewController : UIViewController
///图片链接
@property (nonatomic,copy) NSString *imageUrl;
///持续时间
@property (nonatomic,assign) NSInteger duration;
///是否加载成功
@property (nonatomic,assign) BOOL isLoadSuccess;
///图片点击的block
@property (nonatomic,copy) CustomAdvertisementViewClickBlock imageClickBlock;
///跳过按钮的block
@property (nonatomic,copy) CustomSkipButtonClickBlock skipButtonClickBlock;
@end

ZSCustomAdvertisementViewController.m

#import "ZSCustomAdvertisementViewController.h"
#import "UIImageView+WebCache.h"
#import "Masonry.h"
@interface ZSCustomAdvertisementViewController ()

///广告图
@property (nonatomic,strong) UIImageView *advertisementImageView;
///倒计时
@property (nonatomic,strong) UIButton *skipButton;
///定时器
@property (nonatomic,strong) NSTimer *timer;
@end

@implementation ZSCustomAdvertisementViewController
#pragma mark -- 懒加载
- (UIImageView *)advertisementImageView {
    if (_advertisementImageView == nil) {
        _advertisementImageView = [[UIImageView alloc]initWithFrame:self.view.bounds];
        [self.view addSubview:_advertisementImageView];
        [_advertisementImageView sd_setImageWithURL:[NSURL URLWithString:self.imageUrl] placeholderImage:nil];
        [_advertisementImageView sd_setImageWithURL:[NSURL URLWithString:self.imageUrl] placeholderImage:nil completed:^(UIImage * _Nullable image, NSError * _Nullable error, SDImageCacheType cacheType, NSURL * _Nullable imageURL) {
            [self downloadImage];
        }];
        _advertisementImageView.userInteractionEnabled = YES;
        UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(imageClickBlock:)];
        [_advertisementImageView addGestureRecognizer:tap];
    }
    return _advertisementImageView;
}

- (UIButton *)skipButton {
    if (_skipButton == nil) {
        _skipButton = [UIButton buttonWithType:UIButtonTypeCustom];
        _skipButton.layer.cornerRadius = 10;
        _skipButton.clipsToBounds = YES;
        _skipButton.layer.shouldRasterize = YES;
        _skipButton.layer.rasterizationScale = [UIScreen mainScreen].scale;
        [_skipButton setTitle:[NSString stringWithFormat:@"%zds跳过",self.duration] forState:UIControlStateNormal];
        _skipButton.backgroundColor = [UIColor clearColor];
        [_skipButton setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];
        _skipButton.layer.borderColor = [UIColor whiteColor].CGColor;
        _skipButton.layer.borderWidth = 1;
        [_skipButton addTarget:self action:@selector(countButtonClick) forControlEvents:UIControlEventTouchUpInside];
        _timer = [NSTimer timerWithTimeInterval:1 target:self selector:@selector(countTime) userInfo:nil repeats:YES];
        [[NSRunLoop currentRunLoop]addTimer:_timer forMode:NSRunLoopCommonModes];
    }
    return _skipButton;
}

#pragma mark -- Action
///点击图片跳转webview
-(void)imageClickBlock:(UITapGestureRecognizer *)tap {
    [self invalidatedTimer];
    if (self.imageClickBlock) {
        self.imageClickBlock();
    }
}
///点击跳过按钮
- (void)countButtonClick {
    if (self.skipButtonClickBlock) {
        self.skipButtonClickBlock();
    }
}
///定时器方法
- (void)countTime {
    self.duration --;
    [self.skipButton setTitle:[NSString stringWithFormat:@"%zds跳过",self.duration] forState:UIControlStateNormal];
    if (self.duration <= 0) {
        [self invalidatedTimer];
        //切换根控制器
        if (self.skipButtonClickBlock) {
            self.skipButtonClickBlock();
        }
        return;
    }
}
///销毁定时器
- (void)invalidatedTimer {
    [_timer invalidate];
    _timer = nil;
}

#pragma mark -- 下载图片到本地
- (void)downloadImage {
    NSString *path = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
    NSString *imagePath = [path stringByAppendingPathComponent:@"currentImage.png"];
    [UIImagePNGRepresentation(self.advertisementImageView.image) writeToFile:imagePath atomically:YES];
}
///获取沙盒中图片
- (UIImage *)getDocumentImage {
    NSString *path = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
    NSString *imagePath = [path stringByAppendingPathComponent:@"currentImage.png"];
    return [UIImage imageWithContentsOfFile:imagePath];
}


- (void)viewDidLoad {
    [super viewDidLoad];
    [self.advertisementImageView addSubview:self.skipButton];
    [self.skipButton mas_makeConstraints:^(MASConstraintMaker *make) {
        make.top.mas_equalTo(80);
        make.right.equalTo(self.advertisementImageView).offset(-30);
        make.width.mas_equalTo(80);
        make.height.mas_equalTo(40);
    }];
}

AppDelegate

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    self.window = [[UIWindow alloc]initWithFrame:[UIScreen mainScreen].bounds];
    self.window.backgroundColor = [UIColor whiteColor];
    TabViewController *taVc = [[TabViewController alloc]init];
    ZSCustomAdvertisementViewController *vc1 = [[ZSCustomAdvertisementViewController alloc]init];
    self.window.rootViewController = vc1;
    vc1.imageUrl = @"http://img06.tooopen.com/images/20171116/tooopen_sy_228521528924.jpg";
    vc1.duration = 4;
    vc1.skipButtonClickBlock = ^{
        self.window.rootViewController = taVc;
    };
    //图片点击的block执行
    vc1.imageClickBlock = ^{
        self.window.rootViewController = taVc;
//这里尤为重要,要保证发送和接收方都在同一线程
        dispatch_async(dispatch_get_main_queue(), ^{
            [[NSNotificationCenter defaultCenter]postNotificationName:@"pushController" object:nil];
        });
    };
    [self.window makeKeyAndVisible];
    return YES;
}

最后在首页控制器的viewDidLoad中注册通知,并在通知方法中跳转控制器

- (void)viewDidLoad {
    [super viewDidLoad];
    self.view.backgroundColor = [UIColor blueColor];
    [[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(pushController) name:@"pushController" object:nil];
    self.title = @"首页";

}

- (void)pushController {
    self.hidesBottomBarWhenPushed = YES;
    SecondViewController *seVc = [[SecondViewController alloc]init];
    [self.navigationController pushViewController:seVc animated:YES];
    self.hidesBottomBarWhenPushed = NO;
}
效果图
广告页.gif
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,402评论 6 499
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,377评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,483评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,165评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,176评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,146评论 1 297
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,032评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,896评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,311评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,536评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,696评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,413评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,008评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,659评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,815评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,698评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,592评论 2 353

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,072评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,093评论 4 62
  • 今天晚上的特需时光是跟孩子用一张大纸一起折船,刚开始她看着我学着折,快折好的时候,她自己觉得折的不好,情绪就不对了...
    曾萍萍阅读 115评论 0 0
  • 最新资讯: 近日,莆田一男子在高速上骑摩托车,交警发现后急忙上前去劝阻,男子的情绪显得十分激动,丢下车就要离开。 ...
    颖丶Fly阅读 127评论 0 0
  • 顺风车到北京八个小时,北京六环司机师傅开车超过十二小时,太疲惫没有送我回家,打了个专车。 坐上车司机师傅问准备好了...
    杜子_阅读 246评论 0 1