123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162 |
- //
- // GDTUnifiedNativeAdView.h
- // GDTMobSDK
- //
- // Created by nimomeng on 2018/10/10.
- // Copyright © 2018 Tencent. All rights reserved.
- //
- #import <UIKit/UIKit.h>
- #import "GDTLogoView.h"
- #import "GDTMediaView.h"
- #import "GDTUnifiedNativeAdDataObject.h"
- #import "GDTSDKDefines.h"
- #import "GDTVideoAdReporter.h"
- @class GDTUnifiedNativeAdView;
- //视频广告时长Key
- extern NSString* const kGDTUnifiedNativeAdKeyVideoDuration;
- @protocol GDTUnifiedNativeAdViewDelegate <GDTAdDelegate
- >
- @optional
- /**
- 广告曝光回调
- @param unifiedNativeAdView GDTUnifiedNativeAdView 实例
- */
- - (void)gdt_unifiedNativeAdViewWillExpose:(GDTUnifiedNativeAdView *)unifiedNativeAdView;
- /**
- 广告点击回调
- @param unifiedNativeAdView GDTUnifiedNativeAdView 实例
- */
- - (void)gdt_unifiedNativeAdViewDidClick:(GDTUnifiedNativeAdView *)unifiedNativeAdView;
- /**
- 广告详情页关闭回调
- @param unifiedNativeAdView GDTUnifiedNativeAdView 实例
- */
- - (void)gdt_unifiedNativeAdDetailViewClosed:(GDTUnifiedNativeAdView *)unifiedNativeAdView;
- /**
- 当点击应用下载或者广告调用系统程序打开时调用
-
- @param unifiedNativeAdView GDTUnifiedNativeAdView 实例
- */
- - (void)gdt_unifiedNativeAdViewApplicationWillEnterBackground:(GDTUnifiedNativeAdView *)unifiedNativeAdView;
- /**
- 广告详情页面即将展示回调
- @param unifiedNativeAdView GDTUnifiedNativeAdView 实例
- */
- - (void)gdt_unifiedNativeAdDetailViewWillPresentScreen:(GDTUnifiedNativeAdView *)unifiedNativeAdView;
- /**
- 视频广告播放状态更改回调
- @param nativeExpressAdView GDTUnifiedNativeAdView 实例
- @param status 视频广告播放状态
- @param userInfo 视频广告信息
- */
- - (void)gdt_unifiedNativeAdView:(GDTUnifiedNativeAdView *)unifiedNativeAdView playerStatusChanged:(GDTMediaPlayerStatus)status userInfo:(NSDictionary *)userInfo;
- @end
- @interface GDTUnifiedNativeAdView : UIView
- /**
- 绑定的数据对象
- */
- @property (nonatomic, strong, readonly) GDTUnifiedNativeAdDataObject *dataObject;
- /**
- 视频广告的媒体View,绑定数据对象后自动生成,可自定义布局
- */
- @property (nonatomic, strong, readonly) GDTMediaView *mediaView;
- /**
- 腾讯广告 LogoView,自动生成,可自定义布局
- */
- @property (nonatomic, strong, readonly) GDTLogoView *logoView;
- /**
- 广告 View 时间回调对象
- */
- @property (nonatomic, weak) id<GDTUnifiedNativeAdViewDelegate> delegate;
- /**
- * viewControllerForPresentingModalView
- * 详解:开发者需传入用来弹出目标页的ViewController,一般为当前ViewController
- */
- @property (nonatomic, weak) UIViewController *viewController;
- /**
- * 自定义视频播放器视频播放状态上报器,不能与GDTMediaView同时使用
- */
- @property (nonatomic, strong, readonly, nullable) id<GDTVideoAdReporter> videoAdReporter;
- /**
- * 当使用自定义播放器进行播放时,设置广告的容器,此时将不再以GDTUnifiedNativeAdView当作广告容器,
- * 当不能使用自定义播放器时,设置此属性无效
- */
- @property (nonatomic, weak) UIView * _Nullable customPlayerContainer;
- /**
- 自渲染2.0视图注册方法
-
- @warning 调用方法之前请先判断[dataObject isAdValid]是否为YES,当为NO时调用不生效
- @warning 需要注意的是 -[GDTUnifiedNativeAdView registerDataObject:clickableViews:]方法需要避免重复多次调用的情况
- @warning 当广告不需要展示并且销毁的时候,需要调用 -[GDTUnifiedNativeAdView unregisterDataObject]方法,即registerDataObject方法需要与unregisterDataObject方法成对调用
-
- @param dataObject 数据对象,必传字段
- @param clickableViews 可点击的视图数组,此数组内的广告元素才可以响应广告对应的点击事件
- */
- - (void)registerDataObject:(GDTUnifiedNativeAdDataObject *_Nonnull)dataObject
- clickableViews:(NSArray<UIView *> *_Nonnull)clickableViews;
- /**
- 自渲染2.0视图注册方法
-
- @warning 调用方法之前请先判断[dataObject isAdValid]是否为YES,当为NO时调用不生效
- @warning 需要注意的是 -[GDTUnifiedNativeAdView registerDataObject:clickableViews:customClickableViews:]方法需要避免重复多次调用的情况
- @warning 当广告不需要展示并且销毁的时候,需要调用 -[GDTUnifiedNativeAdView unregisterDataObject]方法,即registerDataObject方法需要与unregisterDataObject方法成对调用
-
- @param dataObject 数据对象,必传字段
- @param clickableViews 可点击的视图数组,此数组内的广告元素才可以响应广告对应的点击事件
- @param customClickableViews 与clickableViews参数已无任何区别,未来在某个SDK版本即将废弃
- */
- - (void)registerDataObject:(GDTUnifiedNativeAdDataObject *_Nonnull)dataObject
- clickableViews:(NSArray<UIView *> *_Nonnull)clickableViews customClickableViews:(NSArray <UIView *> *_Nullable)customClickableViews GDT_DEPRECATED_MSG_ATTRIBUTE("接口即将废弃,请使用registerDataObject:clickableViews接口");
- /**
- 注册可点击的callToAction视图的方法
- 建议开发者使用GDTUnifiedNativeAdDataObject中的callToAction字段来创建视图,并取代自定义的下载或打开等button,
- 调用此方法之前必须先调用registerDataObject:clickableViews
- @param callToActionView CTA视图, 系统自动处理点击事件
- */
- - (void)registerClickableCallToActionView:(UIView *_Nonnull)callToActionView;
- /**
- 注销数据对象,在 tableView、collectionView 等场景需要复用 GDTUnifiedNativeAdView 时,
- 需要在合适的时机,例如 cell 的 prepareForReuse 方法内执行 unregisterDataObject 方法,
- 将广告对象与 GDTUnifiedNativeAdView 解绑,具体可参考示例 demo 的 UnifiedNativeAdBaseTableViewCell 类
- */
- - (void)unregisterDataObject;
- @end
|