iOS开屏广告解决方案XHLaunchAd 3.0

作者: 朱晓辉 | 来源:发表于2016-12-07 21:30 被阅读5095次
header.png

一.前言:

1.之前由于项目需要,写了一个开屏广告组件XHLaunchAd,主要自用,后来发现越来越多的开发者,有这个需求.
2.随着使用人数的增加,部分开发者使用者提出了一些需求和问题,XHLaunchAd并不能很好的解决.
3.于是决定最近抽时间,把这个组件优化重构一下,解决网友之前提出一些问题和需求,并增加一些新功能,发布v3.0.0版本.
4.该项目目前已经收到 700 多个 star ,目前已经更新到v3.0.1版本
5.代码地址: https://github.com/CoderZhuXH/XHLaunchAd

-> XHLaunchAd (3.0.1)
   开屏广告解决方案,支持图片/视频、静态/动态、全屏/半屏广告,支持iPhone/iPad,自带图片下载、缓存功能,无其他三方依赖
   pod 'XHLaunchAd', '~> 3.0.1'
   - Homepage: https://github.com/CoderZhuXH/XHLaunchAd
   - Source:   https://github.com/CoderZhuXH/XHLaunchAd.git
   - Versions: 3.0.1, 3.0.0, 2.2.2, 2.2.1, 2.2.0, 2.1.9, 2.1.8, 2.1.7, 2.1.6,
   2.1.5, 2.1.4, 2.1.3, 2.1.2, 2.1.1, 2.1.0, 2.0.1, 2.0, 1.2, 1.1.4, 1.1.3,
   1.1.2, 1.1, 1.0 [master repo]

二.主要更新:

1.增加mp4视频开屏广告
2.增加对本地资源支持
3.增加预缓存接口
4.增加更多属性及接口,具有更强的自定义性
5.可设置显示完成动画类型
6.可自定义跳过按钮
7.拥有更优雅的接入接口
8.优化缓存机制,bug fix等等

三.接入后效果:

ScreenShot00.gif ScreenShot06.gif ScreenShot05.gif ScreenShot02.gif ScreenShot01.gif

四.使用方法:

在AppDelegate didFinishLaunchingWithOptions方法中添加下面代码(提前设置App启动页为LaunchImage)

-1.添加图片开屏广告⬇️

--1.1使用默认配置快速初始化
//1.使用默认配置初始化
    XHLaunchImageAdConfiguration *imageAdconfiguration = [XHLaunchImageAdConfiguration defaultConfiguration];
    //广告图片URLString/或本地图片名(.jpg/.gif请带上后缀)
    imageAdconfiguratuin.imageNameOrURLString = @"image0.jpg";
    //广告点击打开链接
    imageAdconfiguration.openURLString = @"http://www.returnoc.com";
    //显示图片开屏广告
    [XHLaunchAd imageAdWithImageAdConfiguration:imageAdconfiguration delegate:self];
--1.2自定义配置初始化
//2.自定义配置初始化
    XHLaunchImageAdConfiguration *imageAdconfiguration = [XHLaunchImageAdConfiguration new];
    //广告停留时间
    imageAdconfiguration.duration = 5;
    //广告frame
    imageAdconfiguration.frame = CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, [UIScreen mainScreen].bounds.size.height-150);
    //广告图片URLString/或本地图片名(.jpg/.gif请带上后缀)
    imageAdconfiguration.imageNameOrURLString = @"image0.jpg";
    //网络图片缓存机制(只对网络图片有效)
    imageAdconfiguration.imageOption = XHLaunchAdImageRefreshCached;
    //图片填充模式
    imageAdconfiguration.contentMode = UIViewContentModeScaleToFill;
    //广告点击打开链接
    imageAdconfiguration.openURLString = @"http://www.returnoc.com";
    //广告显示完成动画
    imageAdconfiguration.showFinishAnimate =ShowFinishAnimateFadein;
    //跳过按钮类型
    imageAdconfiguration.skipButtonType = SkipTypeTimeText;
    //后台返回时,是否显示广告
    imageAdconfiguration.showEnterForeground = NO;
    //显示图片开屏广告
    [XHLaunchAd imageAdWithImageAdConfiguration:imageAdconfiguration delegate:self]; 
    

-2.添加视频开屏广告⬇️

--2.1 使用默认配置快速初始化
//1.使用默认配置初始化
    XHLaunchVideoAdConfiguration *videoAdconfiguration = [XHLaunchVideoAdConfiguration defaultConfiguration];
    //广告视频URLString/或本地视频名(请带上后缀)
    videoAdconfiguration.videoNameOrURLString = @"video0.mp4";
    //广告点击打开链接
    videoAdconfiguration.openURLString = @"http://www.returnoc.com";
    //显示视频开屏广告
    [XHLaunchAd videoAdWithVideoAdConfiguration:videoAdconfiguration delegate:self];
--2.2 自定义配置初始化
//2.自定义配置
    XHLaunchVideoAdConfiguration *videoAdconfiguration = [XHLaunchVideoAdConfiguration new];
    //广告停留时间
    videoAdconfiguration.duration = 5;
    //广告frame
    videoAdconfiguration.frame = CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, [UIScreen mainScreen].bounds.size.height);
    //广告视频URLString/或本地视频名(请带上后缀)
    videoAdconfiguration.videoNameOrURLString = @"video1.mp4";
    //视频填充模式
    videoAdconfiguration.scalingMode = MPMovieScalingModeAspectFill;
    //广告点击打开链接
    videoAdconfiguration.openURLString =  @"http://www.returnoc.com";
    //广告显示完成动画
    videoAdconfiguration.showFinishAnimate =ShowFinishAnimateFadein;
     //跳过按钮类型
    videoAdconfiguration.skipButtonType = SkipTypeTimeText;
    //后台返回时,是否显示广告
    videoAdconfiguration.showEnterForeground = NO;
    //显示视频开屏广告
    [XHLaunchAd videoAdWithVideoAdConfiguration:videoAdconfiguration delegate:self];

注意:

若你的广告图片/视频URL来源于数据请求,请在请求数据前设置等待时间,在数据请求成功回调里,配置广告,如下:
//1.因为数据请求是异步的,请在数据请求前,调用下面方法配置数据等待时间.
//2.设为3即表示,启动页将停留3s等待服务器返回广告数据,3s内等到广告数据,将正常显示广告,否则将自动进入window的RootVC

  //设置数据等待时间
    [XHLaunchAd setWaitDataDuration:3];
    //广告数据请求
    [Network getLaunchAdImageDataSuccess:^(NSDictionary * response) {
        
      //在此处利用服务器返回的广告数据,按上面示例添加开屏广告代码
      XHLaunchImageAdConfiguration *imageAdconfiguration = [XHLaunchImageAdConfiguration ... 
     //配置相关参数.... 
     //显示开屏广告
     [XHLaunchAd imageAdWithImageAdConfiguration:imageAdconfiguration delegate:self];
              
    } failure:^(NSError *error) {
    }];   
    

-3.点击事件

/**
 *  广告点击事件 回调
 */
- (void)xhLaunchAd:(XHLaunchAd *)launchAd clickAndOpenURLString:(NSString *)openURLString;
{
    if(openURLString)
    {
         //跳转到广告详情页面
        WebViewController *VC = [[WebViewController alloc] init];
        VC.URLString = openURLString;
        [self.window.rootViewController presentViewController:VC animated:YES completion:nil];
        
    }
}

-4.自定义跳过按钮

//1.XHLaunchImageAdConfiguration 和XHLaunchVideoAdConfiguration 均有一个configuration.customSkipView 属性
//2.自定义一个skipView 赋值给configuration.customSkipView属性 便可替换默认跳过按钮 如下:
configuration.customSkipView = [self customSkipView];

-(UIView *)customSkipView
{
    UIButton *button = [UIButton buttonWithType:UIButtonTypeCustom];
    button.backgroundColor =[ UIColor clearColor];
    button.layer.cornerRadius = 3.0;
    button.layer.borderWidth = 1.0;
    button.layer.borderColor = [UIColor whiteColor].CGColor;
    [button setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];
    button.titleLabel.font = [UIFont systemFontOfSize:13];
    button.frame = CGRectMake(15,[UIScreen mainScreen].bounds.size.height-55, 85, 40);
    [button addTarget:self action:@selector(skipAction) forControlEvents:UIControlEventTouchUpInside];
    return button;
}

-(void)skipAction
{
    [XHLaunchAd skipAction];
}

/**
 *  代理方法-倒计时回调
 *
 *  @param launchAd XHLaunchAd
 *  @param duration 倒计时时间
 */
-(void)xhLaunchAd:(XHLaunchAd *)launchAd customSkipView:(UIView *)customSkipView duration:(NSInteger)duration
{
    UIButton *button = (UIButton *)customSkipView;//此处转换为你之前的类型
    //设置自定义跳过按钮倒计时
    [button setTitle:[NSString stringWithFormat:@"自定义%lds",duration] forState:UIControlStateNormal];
}

-5.预缓存接口(如果你需要提前下载并缓存广告图片或视频 请调用下面方法)

/**
 *  批量下载并缓存image(异步)
 *
 *  @param urlArray image URL Array
 */
+(void)downLoadImageAndCacheWithURLArray:(NSArray <NSURL *> * )urlArray;

/**
 *  批量下载并缓存视频(异步)
 *
 *  @param urlArray 视频URL Array
 */
+(void)downLoadVideoAndCacheWithURLArray:(NSArray <NSURL *> * )urlArray;

-6.其他代理方法

/**
 *  图片下载完成/或本地图片读取完成 回调
 *
 *  @param launchAd XHLaunchAd
 *  @param image    image
 */
-(void)xhLaunchAd:(XHLaunchAd *)launchAd imageDownLoadFinish:(UIImage *)image
{
    NSLog(@"图片下载完成/或本地图片读取完成回调");
}
/**
 *  视频下载完成回调
 *
 *  @param launchAd XHLaunchAd
 *  @param pathURL  视频保存在本地的path
 */
-(void)xhLaunchAd:(XHLaunchAd *)launchAd videoDownLoadFinish:(NSURL *)pathURL
{
    NSLog(@"video下载/加载完成/保存path = %@",pathURL.absoluteString);
}

/**
 *  视频下载进度回调
 */
-(void)xhLaunchAd:(XHLaunchAd *)launchAd videoDownLoadProgress:(float)progress total:(unsigned long long)total current:(unsigned long long)current
{
    NSLog(@"总大小=%lld,已下载大小=%lld,下载进度=%f",total,current,progress);
    
}
/**
 *  广告显示完成
 */
-(void)xhLaunchShowFinish:(XHLaunchAd *)launchAd
{
    NSLog(@"广告显示完成");
}

/**
 如果你想用SDWebImage等框架加载网络广告图片,请实现此代理
 
 @param launchAd          XHLaunchAd
 @param launchAdImageView launchAdImageView
 @param url               图片url
 */
-(void)xhLaunchAd:(XHLaunchAd *)launchAd launchAdImageView:(UIImageView *)launchAdImageView URL:(NSURL *)url
{
    [launchAdImageView sd_setImageWithURL:url];

}

-7.其他操作


/**
 *  清除XHLaunch本地缓存
 */
+(void)clearDiskCache;

/**
 *  获取XHLaunch本地缓存大小(M)
 */
+(float)diskCacheSize;

/**
 *  缓存路径
 */
+(NSString *)xhLaunchAdCachePath;

五.小结:

XHLaunchAd 3.0 拥有更灵活的调用方式和更优雅的接口,后期我还会持续维护并更新他,希望能给更多开发者带来便利!

相关文章

网友评论

  • ChenL:你好多张静态图片手动滚动支持吗?
  • 027c0bd415ac:你好,我加载一个本地9M的GIF图片,播放的特别慢。在电脑上看GIF就就是正常的播放速度
    ChenL:你好 我也遇到了这个问题,你是怎么解决的啊?
  • 禾乃立川:楼主,我拿进项目中用,为什么会闪现一下首页再进入广告页呢
  • RobinZhao:您好,一般都是从服务端获取资源,这个会不是增加太多的冷启动时间
  • 成小知:你好,我那个启动页的时间会很久至少3秒呢
  • 西贝人立口:我在didFinishLaunchingWithOptions这个方法里面写了一个[self createLaunchAD];然后在createLaunchAD这个方法里面没有设置[XHLaunchAd setLaunchSourceType:SourceTypeLaunchImage];这个方法,想问下是必须设置吗?我在项目中没有设置这个方法,然后启动项目的时候没有显示广告图片,只有启动图,这是啥情况?
    朱晓辉:这个是可选的,不设置默认SourceTypeLaunchImage,可以检查下你初始化代码...
  • 西贝人立口:[XHLaunchAd setLaunchSourceType:SourceTypeLaunchImage];这个方法是必须设置吗?我在项目中没有设置这个方法,然后启动项目的时候没有显示广告图片,只有启动图,这是啥情况?
  • 西贝人立口:[XHLaunchAd setLaunchSourceType:SourceTypeLaunchImage];这个方法是必须设置吗?我在项目中没有设置这个方法,然后启动项目的时候没有显示广告图片,只有启动图,这是啥情况?
  • Heaven7th:楼主, 弱弱的问下, 接收到通知点击跳转肯定要放在广告展示完成那里具体怎么做,xhLaunchAdShowFinish这个方法是结束广告,然后,我用极光推送进行跳转处理, 这两个方法怎么关联一下?
    Heaven7th:@朱晓辉 你好,我看了setupLaunchAd的加载Windows的方法, 可是还是不行, 就是极光推送进入app的时候还是会显示广告页, 没办法取消, 有什么好方法吗, 已经把showEnterForeground设置成NO了,求帮助, 谢谢
    朱晓辉:@Heaven7th 正常跳转就可以了,启动广告显示在一个独立window上,不影响你的业务逻辑
    Heaven7th:老是每次点击推送进入app的时候先启动广告, 然后跳转到推送页面
  • betterton:开屏第一下点不中 感觉要展示了广告1s后才能点击响应 有人遇到这个问题吗
    betterton:找到问题了 是adImgView.alpha的问题 有个1s的透明度动画 去掉就好了
  • Xavier_Lost:为什么不使用adImageView.image = [UIImage imageNamed:configuration.imageNameOrURLString];
    而是adImageView.image = [UIImage imageWithData:data];
    我的图片一般放在Assets.xcassets,并不能用[[NSBundle mainBundle] pathForResource:name ofType:nil] 获取到,感觉两种都可以就好了
    朱晓辉:@略_0727 方案一加载本地图片,图片资源会常驻内存,显示完后内存不会释放,考虑到有些广告占用内存挺大的,暂采用方案二!
  • 1b20e394625f:更新到最新版本3.7.2 ,报错:could not build module'XHLaunchAd',请问是什么回事?
    朱晓辉:@荼蘼_d982 我这边是可以的,发个异常Demo过来,邮箱it7090@163.com
    1b20e394625f:@朱晓辉 你好,我是pod进来的,没直接拖进去,改成3.5.8的库就可以
    朱晓辉:@荼蘼_d982 请检查下,该库是否有参与编译,Xcode9直接把库拖进项目,默认不参与编译的!
  • Monster_Lai:你好 请问下如果服务器一次返回多个广告 第一次不显示 先缓存下来后。后面启动时随机显示或者后台推荐显示,用这个库能实现吗?
    朱晓辉:先批量缓存广告图片,在根据推荐显示哪个广告,设置广告数据源!
    Monster_Lai:@朱晓辉 我现在就是卡在这了,只缓存了URL。我们怎么来推荐显示呢?
    朱晓辉:@Monster_Lai 可以!有提供批量缓存接口!
  • c2fffd2b0090:你好 ,我有个建议 :就是广告图片出现的时候显得比较生硬,加个渐变动画或许比较好一点。
    朱晓辉:@打了鸡血 好建议!后续版本迭代时会考虑加上
  • Wuyd2019:XHLaunchAdView.m文件第44行代码和YLGIFImage冲突了,无论是pods还是手动导入都会报错( clang: error: linker command failed with exit code 1 (use -v to see invocation) )
    const NSTimeInterval kMaxTimeStep = 1; // note: To avoid spiral-o-death
    朱晓辉:已修复,请重新下载最新版本v3.6.0
  • 这个汤圆没有馅:今天发现一个很奇怪的现象,网络请求的gif广告,倒计时会显示但是gif动态图不显示
  • 24Kr:不知道为什么pod这个特别慢,pod其他的,第一次也不会这么慢
  • 37ca5cd63091:您好 大神 为什么每次我进来的时候倒计时如果是5秒的话 前两秒是非常快的 后面3秒是正常的 这个bug怎么解决 谢谢
  • dfe54fe834d4:倒计时的时候偶尔会卡住怎么回事呢
    QL_fish:我也遇到了相同的问题,等待解决
  • 知了此生:怎么让它只显示一次啊,第二次进入没有改变图片URL,就不显示广告
    知了此生:@鬼谷门生 我是在第一次加载广告之后在本地存储是否加载的标记,当标记为yes的时候,不再加载广告,为no的时候加载广告;不仅是这样,我还存储了上一次加载的广告的字段,在本次加载的时候先对比存储的广告字段,若一样,则看标记字段,如果不一样直接加载广告;其实主要是第一次安装的时候广告页是不加载的,所以广告字段存储下来但是标记字段应存为no。
    知了此生:@鬼谷门生 我自己添加了标记,这样就解决了
    鬼谷门生:每次进去都会显示同一广告吗 你用的是本地的数据?
  • f24e9d691049:XHLaunchAdConfiguratuon 这个是pod库里面的文件名 应该是拼写错误了吧 本该使用XHLaunchAdConfiguration的
    朱晓辉:@鬼谷门生 视频需要先缓存,后显示, 显示的时候是取缓存的,首次下载视频的那次,将不显示广告,显示完启动页,就会进入APP首页.
    鬼谷门生:@朱晓辉 大神你好 你的网络加载视频说明的是需要先缓存下次显示 那么要显示的时候需要从缓存中读取然后显示吗 那么每一次用网络请求显示视频广告当前请求又应该显示什么内容呢 当前请求显示自定义视图?
    朱晓辉:已修正:smile: :smile:
  • Mccc_:我也用过一次,不过第二次,有一个需求不能用了。需求是从广告页面,可以跳转到商品详情去。可以完成整个业务逻辑。遇到的问题是:没办法解决导航栏的问题。因为,初始的时候导航控制器不存在。不知道我说的清不清楚
    拿铁加冰:@满聪 可以发送通知啊,到首页的时候自动执行跳转到详情页
  • 难却却:从上个版本就开始关注了,厉害了我的哥

本文标题:iOS开屏广告解决方案XHLaunchAd 3.0

本文链接:https://www.haomeiwen.com/subject/uwljmttx.html