NativeAd

出自TAMedia
於 2015年9月23日 (三) 02:19 由 imported>Wikiuser 所做的修訂
跳至導覽 跳至搜尋

請依照 開始使用Getting Started 章節進行SDK 的安裝 並以下述的方式啟動原生性廣告服務

// NADViewController.h
// 匯入 TAMedia SDK 定義
#import "TADNativeAd.h"
@interface NADViewController: UIViewController <TADNativeAdDelegate>
{
// 以 instant variable 的方式, 宣告 TADNatvieAd 物件
TADNativeAd * nativeAd;
}
@end
// NADViewController.m
- (void)viewDidLoad
{
[super viewDidLoad];
// Do any additional setup after loading the view.
self.view.backgroundColor = [UIColor whiteColor];
self.title = @"TAMedia NAD";
UIButton *fireButton1 = [UIButton buttonWithType:UIButtonTypeRoundedRect];
fireButton1.frame = CGRectMake(10, 120, 200, 40);
fireButton1.backgroundColor = [UIColor colorWithRed:239/255.0 green:239/255.0 blue:239/255.0 alpha:1.0];
[fireButton1 setTitle:@"Native Ad" forState:UIControlStateNormal];
[fireButton1 setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
[fireButton1 addTarget:self action:@selector(requestAd1) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:fireButton1];
}
- (void)requestAd1
{
TADRequest *request = [TADRequest request];
// Type: TADGender
request.gender = [_GENDER_];
// Set birthday
[request setBirthdayWithYear:[_YEAR_] month:[_MONTH_] day:[_DAY_]];
// Set location
[request setLocationWithLatitude:[_LATITUDE_] longitude:[_LONGITUDE_] accuracy:[_ACCURACY_]];
// NAD 物件初始化, 帶入自訂的origin
if (!nativeAd) {
nativeAd = [[TADNativeAd alloc] initWithAdUnitId: [_YOUR_AD_UNIT_ID_]];
}
// 必須要設定delegate
nativeAd.delegate = self;
// 載入廣告
[nativeAd loadRequest:request];
}
- (void)nativeAdDidReceiveAd:(TADNativeAd *)ad {
// 表示本次請求收到廣告, 藉由 getNativeAdContent 取得包含回覆內容的 NSDictionary
NSDicationary *dicNad = [nativeAd getNativeAdContent];
}

特別注意, 在 ViewController 的 view 即將消失前, 必須要將 nativeAd 本身以及其 delegate 設定為 nil

// NADViewController.m
- (void)viewWillDisappear:(BOOL)animated {
// viewController 的 view 消失前, 必須將 nativeAd 及其 delegate 設為 nil
 if (nativeAd!= nil) {
 nativeAd.delegate = nil;
 nativeAd = nil;
 }
}

TADNativeAdDelegate

@protocol TADNativeAdDelegate <NSObject>
@optional
//廣告載入成功後被呼叫, 在這裏利用 [nativeAd getNativeAdContent] 取得回覆的 dictionary
- (void)nativeAdDidReceiveAd:(TADNativeAd *)ad;
//廣告載入失敗後被呼叫
- (void)nativeAd:(TADNativeAd *)ad didFailToReceiveAdWithError:(TADRequestError *)error;
@end

原生性廣告內容 前述之getNativeAdContent 所取回的NSDictionary 詳細內容如後

{
"LONGSUBJECT": "長標題 long subject ", //表長標題文字, 最長30 個字
"SHORTSUBJECT": "短標題 short subject", // 短標題, 最長4 個字
"BODY": "內文 body",// 內文,提供最長70 個文字
"ICONSQUARE": "小圖示 方 icon square",//提供64x64(px)的圖檔url
"ICONRECTANGLE": "小圖示 長 icon rectangle",//提供96x64(px)的圖檔url
"VIDEO": "影片 video", // 影片內容的url
"IMAGE1280X720": "大圖 1280x720",// 提供1280x720(px)的圖檔url
"IMAGE720X1280": "大圖 720x1280",// 提供˙720x1280(px)的圖檔url
"IMAGE960X640": "大圖 960x640", // 提供960x640(px)的圖檔url
"IMAGE640X960": "大圖 640x960", // 提供640x960(px)的圖檔url
"nurl": "廣告檔次Target URL", //當廣告發生點擊時回報的url
}

※重要, 下表所描述的廣告素材有可能因廣告主未提供素材, 而以空字串提供, 使用上請特別留意

素材 \ 版位 限制條件 條列式 圖片式 (直9:16) 圖片式 (橫 16:9) 圖片式 (直2:3) 圖片式 (橫 3:2) 小圖式 影音式
長標題
(LONGSUBJECT)
30字內 V V V V V V
短標題
(SHORTSUBJECT)
4字內 V V V V V
內文
(BODY)
70字內 V V V V V V
小圖 (方)
(ICONSQUARE)
64x64
jpg/png
V V V
小圖 (長)
(ICONRECTANGLE)
96x64
jpg/png
V V
影片
(VIDEO)
96x64
MP4, 10mb
V
大圖 (直 9:16)
(IMAGE720X1280)
720x1280
jpg/png
V
大圖 (橫 16:9)
(IMAGE1280X720)
1280x720
jpg/png
V
大圖 (橫 2:3)
(IMAGE640X960)
640x960
jpg/png
V
大圖 (橫 3:2)
(IMAGE960X640)
960x640
jpg/png
V V