GDTUnifiedNativeAdDataObject.h 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. //
  2. // GDTUnifiedNativeAdDataObject.h
  3. // GDTMobSDK
  4. //
  5. // Created by nimomeng on 2018/10/10.
  6. // Copyright © 2018 Tencent. All rights reserved.
  7. //
  8. #import <Foundation/Foundation.h>
  9. #import <UIKit/UIKit.h>
  10. #import "GDTVideoConfig.h"
  11. #import "GDTSDKDefines.h"
  12. #import "GDTAdProtocol.h"
  13. typedef NS_ENUM(NSInteger, GDTVastAdEventType) {
  14. GDTVastAdEventTypeUnknow,
  15. GDTVastAdEventTypeLoaded,
  16. GDTVastAdEventTypeStarted,
  17. GDTVastAdEventTypeFirstQuartile,
  18. GDTVastAdEventTypeMidPoint,
  19. GDTVastAdEventTypeThirdQuartile,
  20. GDTVastAdEventTypeComplete,
  21. GDTVastAdEventTypeAllAdsComplete,
  22. GDTVastAdEventTypeExposed,
  23. GDTVastAdEventTypeClicked,
  24. };
  25. @interface GDTUnifiedNativeAdDataObject : NSObject <GDTAdProtocol>
  26. /**
  27. 广告标题
  28. */
  29. @property (nonatomic, copy, readonly) NSString *title;
  30. /**
  31. 广告描述
  32. */
  33. @property (nonatomic, copy, readonly) NSString *desc;
  34. /**
  35. 素材宽度,单图广告代表大图 imageUrl 宽度、多图广告代表小图 mediaUrlList 宽度
  36. */
  37. @property (nonatomic, readonly) NSInteger imageWidth;
  38. /**
  39. 素材高度,单图广告代表大图 imageUrl 高度、多图广告代表小图 mediaUrlList 高度
  40. */
  41. @property (nonatomic, readonly) NSInteger imageHeight;
  42. /**
  43. 应用类广告App 图标Url
  44. */
  45. @property (nonatomic, copy, readonly) NSString *iconUrl;
  46. /**
  47. 广告大图Url, 建议使用 bindImageViews:placeholder: 方法替代
  48. */
  49. @property (nonatomic, copy, readonly) NSString *imageUrl;
  50. /**
  51. 三小图广告的图片Url集合, 建议使用 bindImageViews:placeholder: 方法替代
  52. */
  53. @property (nonatomic, copy, readonly) NSArray *mediaUrlList;
  54. /**
  55. 应用类广告的星级(5星制度)
  56. */
  57. @property (nonatomic, readonly) CGFloat appRating;
  58. /**
  59. 应用类广告的价格
  60. */
  61. @property (nonatomic, strong, readonly) NSNumber *appPrice;
  62. /**
  63. 是否为应用类广告
  64. */
  65. @property (nonatomic, readonly) BOOL isAppAd;
  66. /**
  67. 是否为视频广告
  68. */
  69. @property (nonatomic, readonly) BOOL isVideoAd;
  70. /**
  71. 是否为三小图广告
  72. */
  73. @property (nonatomic, readonly) BOOL isThreeImgsAd;
  74. /**
  75. 是否为微信原生页广告 (可针对此广告类型来控制按钮展示文案为"去微信看看")
  76. */
  77. @property (nonatomic, readonly) BOOL isWechatCanvasAd;
  78. /**
  79. 返回广告的eCPM,单位:分
  80. @return 成功返回一个大于等于0的值,-1表示无权限或后台出现异常
  81. */
  82. @property (nonatomic, readonly) NSInteger eCPM;
  83. /**
  84. 返回广告的eCPM等级
  85. @return 成功返回一个包含数字的string,@""或nil表示无权限或后台异常
  86. */
  87. @property (nonatomic, readonly) NSString *eCPMLevel;
  88. /**
  89. 广告对应的按钮展示文案
  90. 此字段可能为空
  91. */
  92. @property (nonatomic, readonly) NSString *buttonText;
  93. /**
  94. 广告对应的CTA文案,自定义CTA视图时建议使用此字段
  95. 广告对应的callToAction文案,比如“立即预约”或“电话咨询”, 自定义callToAction视图时建议使用此字段
  96. 该字段在部分广告类型中可能为空
  97. */
  98. @property (nonatomic, readonly) NSString *callToAction;
  99. /**
  100. 返回广告是否可以跳过,用于做前贴片场景
  101. @return YES 表示可跳过、NO 表示不可跳过
  102. */
  103. @property (nonatomic, readonly) BOOL skippable;
  104. /**
  105. 视频广告播放配置
  106. */
  107. @property (nonatomic, strong) GDTVideoConfig *videoConfig;
  108. /**
  109. * 视频广告时长,单位 ms
  110. */
  111. @property (nonatomic, readonly) CGFloat duration;
  112. /**
  113. * VAST Tag Url,可能为空。
  114. */
  115. @property (nonatomic, copy, readonly) NSString *vastTagUrl;
  116. /**
  117. * VAST Content,可能为空。
  118. */
  119. @property (nonatomic, copy, readonly) NSString *vastContent;
  120. /**
  121. * 是否为 VAST 广告
  122. */
  123. @property (nonatomic, assign, readonly) BOOL isVastAd;
  124. /**
  125. * 广告是否有效,以下情况会返回NO,建议在展示广告之前判断,否则会影响计费或展示失败
  126. * a.广告过期
  127. */
  128. @property (nonatomic, readonly) BOOL isAdValid;
  129. /**
  130. 判断两个自渲染2.0广告数据是否相等
  131. @param dataObject 需要对比的自渲染2.0广告数据对象
  132. @return YES or NO
  133. */
  134. - (BOOL)equalsAdData:(GDTUnifiedNativeAdDataObject *)dataObject;
  135. /**
  136. * 绑定展示的图片视图
  137. *
  138. * @param imageViews 进行渲染的 imageView
  139. * @param placeholder 图片加载过程中的占位图
  140. */
  141. - (void)bindImageViews:(NSArray<UIImageView *> *)imageViews placeholder:(UIImage *)placeholder;
  142. /**
  143. * 竞胜之后调用, 需要在调用广告 show 之前调用
  144. *
  145. * @param winInfo 字典类型,支持的key为以下,注:key是个宏定义,在GDTAdProtocol.h中有定义,可以参考demo中的使用方法
  146. * GDT_M_W_E_COST_PRICE:竞胜价格 (单位: 分),值类型为NSNumber *
  147. * GDT_M_W_H_LOSS_PRICE:最高失败出价,值类型为NSNumber *
  148. *
  149. */
  150. - (void)sendWinNotificationWithInfo:(NSDictionary *)winInfo;
  151. /**
  152. * 竞败之后调用
  153. *
  154. * @pararm lossInfo 竞败信息,字典类型,支持的key有
  155. * GDT_M_L_WIN_PRICE :竞胜价格 (单位: 分),值类型为NSNumber *
  156. * GDT_M_L_LOSS_REASON :优量汇广告竞败原因,竞败原因参考枚举GDTAdBiddingLossReason中的定义,值类型为NSNumber *
  157. * GDT_M_ADNID :竞胜方渠道ID,值类型为NSString *
  158. */
  159. - (void)sendLossNotificationWithInfo:(NSDictionary *)lossInfo;
  160. /**
  161. * S2S bidding 竞胜之后调用, 需要在调用广告 show 之前调用
  162. * @param eCPM - 曝光扣费, 单位分,若优量汇竞胜,在广告曝光时回传,必传
  163. * 针对本次曝光的媒体期望扣费,常用扣费逻辑包括一价扣费与二价扣费,当采用一价扣费时,胜者出价即为本次扣费价格;当采用二价扣费时,第二名出价为本次扣费价格.
  164. */
  165. - (void)setBidECPM:(NSInteger)eCPM;
  166. @end