iOS
Adiz iOS¶
Adiz iOS 是一個為 iOS 提供的廣告模組,旨在使 Hive 平台上的 AdMob 廣告曝光功能更易於使用。Adiz iOS 提供的廣告類型如下。
- 插頁廣告
- 橫幅廣告
- 原生廣告
- 獎勵廣告
- 獎勵插頁廣告
- 應用開啟廣告
要安裝和使用 Adiz iOS,請按照以下指南進行。
準備¶
安裝¶
將 GADApplicationIdentifier
鍵添加到您的 Xcode 項目的 Info.plist 文件中,並將 AdMobId
值(格式為 ca-app-pub-XXXXX~YYYYY)作為該鍵的值輸入。
此外,對於 iOS 14 及以上版本,請參考 更新您的 info.plist 指南,以將 SKAdNetwork
列表添加到 Info.plist 文件中。
接下來,將以下內容添加到項目的 CocoaPods 配置 (Podfile) 中。
source 'https://github.com/CocoaPods/Specs.git'
source 'https://github.com/Com2uSPlatformCorp/HiveAdiz-iOS.git'
platform :ios, '12.0'
target 'UnityFramework' do
pod 'HiveAdiz', '2.1.1'
end
target 'Unity-iPhone' do
end
use_frameworks!
# fix for dyld issue in pods when using Project
post_install do |installer|
installer.pods_project.targets.each do |target|
target.build_configurations.each do |config|
# xcode 15 Toolchain Issue
xcconfig_path = config.base_configuration_reference.real_path
xcconfig = File.read(xcconfig_path)
xcconfig_mod = xcconfig.gsub(/DT_TOOLCHAIN_DIR/, "TOOLCHAIN_DIR")
File.open(xcconfig_path, "w") { |file| file << xcconfig_mod }
# end
config.build_settings["BUILD_LIBRARY_FOR_DISTRIBUTION"] = "YES"
if config.build_settings['IPHONEOS_DEPLOYMENT_TARGET'].to_f < 12.0
config.build_settings['IPHONEOS_DEPLOYMENT_TARGET'] = '12.0'
end
end
end
end
使用 $pod install
應用 CocoaPod 設定。
測試廣告設定¶
Adiz 可以以兩種方式顯示測試廣告。
- 啟用測試模式:僅顯示由 AdMob 發佈的測試廣告
- 在註冊測試設備後顯示廣告:顯示真實廣告以進行測試,確保不會產生無效流量,並通過註冊將顯示測試廣告的設備來進行
測試模式啟用¶
在開發階段,啟用測試模式,以便點擊測試廣告不會向廣告主收費。當測試模式啟用時,將僅顯示測試廣告。在測試模式下,即使未在控制台中輸入 AdMob 廣告密鑰,也會顯示測試廣告。商業發行期間將停用測試模式。
有兩種方法可以啟用測試模式。
<
Note
當在開發階段未處於測試模式時,對廣告的過度點擊可能會被視為無效流量,並且您的 AdMob 帳戶可能會被報告,從而阻止廣告顯示。
使用 Adiz.setTestMode() 方法¶
測試設備廣告曝光¶
在以下情況下,您需要註冊一個測試設備以顯示測試廣告。
<
在測試設備上有兩種顯示廣告的方法。
<
Note
如果您进行测试而未注册测试设备,实际广告可能会被视为无效流量,这将导致您的 AdMob 帐户被封锁,并可能阻止进一步的广告曝光。通过注册测试设备,在广告曝光期间将显示“测试模式”或“测试广告”(原生广告)。在商业分发期间,您必须停用测试设备。
使用 Adiz.setTestDevice() 方法¶
要注册测试设备,您首先需要检查测试设备 ID。测试设备 ID(示例:B74F6468-1516-467C-99AD-CC5973C5DB52
)可以通过以下两种方式进行验证。
- 在调用
Adiz.Initialize()
后检查 Logcat 日志: - 在調用
Adiz.Initialize()
之後,無論廣告類型如何,都要調用initialize()
→load()
並檢查 Logcat 日誌:
在检查测试设备 ID 后,在现有的 Hive Adiz 初始化代码中执行 Adiz.initialize
之前,添加行 Adiz.SetTestDevice(DEVICE_ID)
。将复制的测试设备 ID 输入到 DEVICE_ID
中。
廣告檢查器使用¶
廣告檢查器是一個應用內的覆蓋工具,實時分析在測試設備上請求和顯示實際廣告的過程。它告訴您加載廣告所需的時間,並提供任何顯示廣告失敗的原因。您還可以指定特定的廣告網絡,以檢查廣告是否正確顯示,如果有問題,您可以在代碼層面進行調試。所有這些都是在廣告檢查器用戶界面旁邊進行的。它包含在 Google Mobile Ads SDK 版本 7.68.0 及以上版本中,可以通過調用 AdizDeveloperTool.OpenAdInspector
來使用。
要使用廣告檢查器,必須設置測試設備上的廣告曝光。
Adiz AppID 設定¶
設定您在 Hive 控制台 AppCenter 中註冊的 Adiz AppID。如果未設定,將使用 Bundle ID。
Hive 控制台伺服器配置¶
設置 Hive 控制台伺服器以供使用。默認為 real
。即使您使用生產伺服器,啟用測試模式也僅會顯示測試廣告。
- Hive 測試控制台伺服器:
AdizZoneType.test
- Hive 沙盒控制台伺服器:
AdizZoneType.sandbox
- Hive 生產控制台伺服器:
AdizZoneType.real
用戶特定的廣告曝光¶
隨著在 iOS 14.5+ 中引入的 ATT(應用追蹤透明度),隱私保護得到了加強。因此,只有在用戶同意在 ATT 同意彈出窗口中進行活動追蹤的情況下,才能顯示用戶特定的廣告。為了通過顯示用戶特定的廣告來最大化廣告收入,您需要創建一個 IDFA(廣告商標識符)消息。
AdMob 在儀表板上遵循以下 IDFA 消息撰寫指南來撰寫和發布您的消息。
在撰寫並發佈 IDFA 訊息後,設置用戶追蹤訪問權限。按照以下步驟將鍵添加到 Info.plist。
- 在 Xcode 项目窗口的项目导航器中选择您的项目。
- 在 TARGETS 列表中选择您的应用。
- 点击 Info 标签。
- 在 Info 标签中点击自定义 iOS 目标属性项。
- 在自定义 iOS 目标属性列表中右键单击。
- 点击添加行菜单。
- 在键字段中输入 NSUserTrackingUsageDescription,并在值字段中添加在 多语言设置文件 > Base.Iproj 文件夹 > InfoPlist.strings 中指定的值。
接下來,撰寫一條消息,請求來自多語言配置文件中指定的應用用戶的許可批准(一般設置 > 訪問許可請求設置)。如果您不輸入許可批准請求彈出消息,則將缺少有關正在使用的用戶訪問許可的附加說明指南,並且應用在審核過程中將被拒絕。
如果您已完成到此步骤,ATT 同意弹出窗口将在 Adiz 初始化 期间自动显示。当用户在 ATT 同意弹出窗口上点击“允许”时,IDFA 将被激活,并将显示个性化广告。
GDPR 同意彈出窗口曝光(歐洲,英國)¶
如果您的遊戲針對歐洲和英國(EEA 和英國),您必須顯示 GDPR(通用數據保護條例)同意彈出窗口。只有當用戶的設備 IP 地址來自歐洲和英國(EEA 和英國)時,才會顯示 GDPR 同意彈出窗口。Adiz 通過 Google UMP(用戶消息平台)支持顯示 GDPR 同意彈出窗口。在 AdMob 控制台中創建 GDPR 消息後,初始化 Adiz 以向來自歐洲和英國的用戶顯示 GDPR 彈出窗口。
Warning
當目標地區在歐洲和英國以外時,例如,如果您計劃僅在國內提供服務,您可以跳過GDPR同意彈出窗口曝光(歐洲,英國)步驟,並使用Adiz.initializeForNonGDPR()
方法進行初始化。
如果您使用Adiz.initialize()
方法進行初始化,則必須在AdMob控制台中創建一條GDPR消息,以便Adiz初始化正常進行。
撰寫 GDPR 訊息¶
訪問 Google AdMob 控制台以撰寫 GDPR 訊息。在撰寫 GDPR 訊息之前,請參考GDPR 訊息撰寫指南。
如果您已撰寫GDPR消息,GDPR同意彈出窗口將在Adiz初始化時自動出現。
Warning
如果您正在使用 Hive SDK,則必須在完成 Hive Adiz 初始化後運行 AuthV4.setup
。如果在顯示 ATT(應用程序跟踪透明度)同意通知後出現 GDPR 同意屏幕,則您的應用可能會在 Apple 應用審核期間被拒絕。
實施GDPR同意/撤回功能¶
GDPR同意彈出窗口中的項目必須提供修改功能,以便用戶可以隨時更改其同意狀態。例如,用戶最初可能不同意GDPR,但後來希望再次同意以查看個性化廣告;或者,相反,用戶最初可能同意了GDPR,但現在希望撤回其同意,因為他們不再想提供個人信息。為了解決這些情況,應用程序開發者必須實施功能,以重新同意每個項目或撤回現有同意。要實施GDPR同意/撤回功能,請按照以下步驟操作。
- 在應用中實現一個按鈕 UI,可以重新打開 GDPR 同意彈出窗口。
- 在實現 Adiz 初始化 時,調用
isPrivacyOptionsRequired()
來顯示按鈕 UI 給來自歐洲和英國的用戶,否則不顯示。如果來自歐洲或英國的用戶點擊該按鈕,則調用showPrivacyOptionsForm
以重新打開 GDPR 同意彈出窗口。這使用戶可以隨時通過按下應用中的 "管理選項" 按鈕來修改他們的 GDPR 詳情同意。下面的showPrivacyOptionsForm
是為了說明而隨意實現的方法,開發者可以根據需要更改實現。
import HiveAdiz
func initialize(_ appId: String) {
// ...
// isPrivacyOptionsRequired is default false
targetViewController.showPrivacyFormButton.isEnabled = AdizConsentManager.isPrivacyOptionsRequired()
// HiveAdiz 初始化
Adiz.initialize(targetViewController) { error, json in
// ...
// showPrivacyOptionsForm 按鈕啟用檢查
targetViewController.showPrivacyFormButton.isEnabled = AdizConsentManager.isPrivacyOptionsRequired()
// ...
}
}
func showPrivacyOptionsForm(_ targetViewController: UIViewController) {
// 顯示GDPR表單
if AdizConsentManager.isPrivacyOptionsRequired() {
AdizConsentManager.showPrivacyOptionsForm(targetViewController) { error in
// 無需進行任何錯誤處理。
}
}
}
#import <HiveAdiz/HiveAdiz-Swift.h>
- (void)initialize: (NSString *)appId {
// ...
// isPrivacyOptionsRequired is default false
targetViewController.showPrivacyFormButton.enabled = [AdizGDPRManager isPrivacyOptionsRequired];
// HiveAdiz 初始化
[Adiz initialize: targetViewController handler:^(AdizError * error, NSDictionary<NSString *,id> * json) {
// ...
// showPrivacyOptionsForm 按鈕啟用檢查
targetViewController.showPrivacyFormButton.enabled = [AdizConsentManager isPrivacyOptionsRequired];
// ...
}];
}
- (void)showPrivacyOptionsForm: (UIViewController*) targetViewController {
// 顯示GDPR表單
if ([AdizConsentManager isPrivacyOptionsRequired]) {
[AdizConsentManager showPrivacyOptionsForm: targetViewController handler:^(AdizError *error) {
// 無需進行任何錯誤處理。
}];
}
}
為未滿GDPR同意年齡的用戶設置標籤 (TFUA)¶
您可以在进行广告请求时为未满同意年龄的用户设置标签(未满同意年龄标签,TFUA),以将居住在欧洲经济区(EEA)、英国和瑞士的用户视为受限数据处理的对象。对于面向儿童的应用程序,您可以使用 AdizConsentManager.SetUserPrivacySettings
来设置用户未满同意年龄。尽管欧洲各国之间存在一些差异,但GDPR将16岁以下定义为需要父母同意的年龄。未成年同意设置必须在执行 Adiz.initialize
之前配置。
Warning
同時將setTagForUnderAgeOfConsent
標籤設置為GDPR同意年齡以下,並將setTagForChildDirectedTreatment
設置為COPPA兒童的true
,則COPPA兒童設置setTagForChildDirectedTreatment
將優先,因此不要同時將它們都設置為true
並同時使用。
Note
當使用 Hive SDK v4 24.2.0 或更高版本與 Adiz 2.0.1 或更高版本一起時,在 Hive SDK 中設置的用戶同意年齡會自動應用,因此無需調用 AdizConsentManager.SetUserPrivacySettings
。
func initialize(_ appId: String) {
bool isTagForUnderAgeOfConsent = false // Change to true if underage
let privacySet = PrivacySettings.Builder()
.setTagForUnderAgeOfConsent(isTagForUnderAgeOfConsent)
AdizConsentManager.setUserPrivacySettings(privacySet.build())
// HiveAdiz 初始化
Adiz.initialize(targetViewController) { error, json in
// ...
}
}
- (void)initialize: (NSString *)appId {
bool isTagForUnderAgeOfConsent = false; // Change to true if underage
PrivacySettingsBuilder* privacySet = [[PrivacySettingsBuilder alloc] init];
privacySet = [builder setTagForUnderAgeOfConsent: isTagForUnderAgeOfConsent];
[AdizConsentManager setUserPrivacySettings: [privacySet build]];
// HiveAdiz 初始化
[Adiz initialize: targetViewController handler:^(AdizError * error, NSDictionary<NSString *,id> * json) {
// ...
}];
}
GDPR 測試設備設置¶
GDPR 同意彈出窗口僅在設備的 IP 地址來自歐洲或英國時顯示。在開發階段,可以強制顯示 GDPR 同意彈出窗口,而不考慮 IP 地址,以測試彈出窗口的顯示,為此,您需要設置一個 GDPR 測試設備。請按照以下步驟設置 GDPR 測試設備。
- 通过初始化来初始化Adiz。这是一个初始化步骤,用于检查测试设备ID,无需编写GDPR同意消息。
检查调试日志以确认设备ID的消息。以下消息是一个示例。
要为此设备启用调试模式,请设置:UMPDebugSettings.testDeviceIdentifiers = @[B74F6468-1516-467C-99AD-CC5973C5DB52] 在消息中检查设备ID(示例:
B74F6468-1516-467C-99AD-CC5973C5DB52
)。- 复制设备ID。
- 在现有的Adiz初始化代码中,在执行
Adiz.initialize
之前添加Adiz.setTestDevice(DEVICE_ID)
。 - 编写GDPR同意消息并重新初始化Adiz,以确保GDPR同意弹出窗口正确显示。
- (void)initialize: (NSString *)appId {
// ...
// 在 Adiz.initialize 之前设置 TestDevice。示例 @"B74F6468-1516-467C-99AD-CC5973C5DB52"
[Adiz setTestDevice: @"B74F6468-1516-467C-99AD-CC5973C5DB52"];
// HiveAdiz 初始化
[Adiz initialize: targetViewController handler:^(AdizError * error, NSDictionary<NSString *,id> * json) {
// ...
}];
}
COPPA 兒童導向處理標籤設定¶
根據《兒童在線隱私保護法》(COPPA),應用程序開發者可以通過在發送廣告請求時設置兒童導向處理標籤(tagForChildDirectedTreatment, TFCD)來指定 Google 是否應將內容視為兒童導向。如果您希望它被視為兒童導向,您必須在執行 Adiz.initialize
之前調用 AdizConsentManager.SetUserPrivacySettings
。在使用 Adiz 與 Hive SDK 時,兒童導向處理標籤會自動應用,因此不需要單獨配置。
func initialize(_ appId: String) {
bool isTagForChildDirectedTreatment = false // Change to true if it is for children
let privacySet = PrivacySettings.Builder()
.setTagForChildDirectedTreatment(isTagForUnderAgeOfConsent)
AdizConsentManager.setUserPrivacySettings(privacySet.build())
// HiveAdiz 初始化
Adiz.initialize(targetViewController) { error, json in
// ...
}
}
- (void)initialize: (NSString *)appId {
bool isTagForChildDirectedTreatment = false; // Change to true if it's for children
PrivacySettingsBuilder* privacySet = [[PrivacySettingsBuilder alloc] init];
privacySet = [builder setTagForChildDirectedTreatment: isTagForChildDirectedTreatment];
[AdizConsentManager setUserPrivacySettings: [privacySet build]];
// HiveAdiz 初始化
[Adiz initialize: targetViewController handler:^(AdizError * error, NSDictionary<NSString *,id> * json) {
// ...
}];
}
添加廣告調解¶
Adiz 可以使用 AdMob 調解顯示廣告。要添加 AdMob 調解,請按照以下步驟操作。
添加 AdMob 中介¶
我们将继续在 AdMob 控制台中集成广告源。请按照下表进行操作。
AppLovin | Pangle | Unity Ads | Meta | |
---|---|---|---|---|
第 1 步 | 設置 AppLovin 配置 | 設置 Pangle 配置 | 設置 Unity Ads 配置 | 設置 Meta 配置 |
第 2 步 | 將 AppLovin 廣告來源添加到 AdMob | 將 Pangle 廣告來源添加到 AdMob | 將 Unity Ads 廣告來源添加到 AdMob | 將 Meta 廣告來源添加到 AdMob |
第 3 步 | 添加 Adiz 適配器 |
添加 Adiz 适配器¶
將依賴項添加到 CocoaPods Podfile。
# ...
$HIVE_ADIZ_VERSION = '2.1.1'
def adiz
pod 'HiveAdiz', $HIVE_ADIZ_VERSION
end
def adizAdapter
pod 'HiveAdizAdapterAppLovin', $HIVE_ADIZ_VERSION
pod 'HiveAdizAdapterPangle', $HIVE_ADIZ_VERSION
pod 'HiveAdizAdapterUnityAds', $HIVE_ADIZ_VERSION
end
target 'MyGame-mobile' do
adiz
adizAdapter
end
# ...
要檢查 Adiz 轉接器配置是否已正確應用,請運行應用程序並檢查 廣告檢查器 屏幕上的配置列表。
Adiz 初始化¶
這是一個必須在顯示所有類型的廣告之前執行的必要步驟。通過初始化 Adiz,您將獲得顯示廣告所需的廣告金鑰。如果您處於測試模式,您將獲得一個測試金鑰。如果您使用的是 Hive SDK,請在調用 AuthV4.setup
後進行 Adiz 初始化。
Warning
如果您使用的是 GDPR 設定,則必須在完成 Hive Adiz 初始化後運行 AuthV4.setup
。如果在顯示 ATT(應用追蹤透明度)同意通知後出現 GDPR 同意畫面,則應用可能會在 Apple 的應用審核中被拒絕。
import HiveAdiz
// Hive Adiz 初始化中
Adiz.initialize(targetViewController) { error, json in
if error.isSuccess,
let responseList = json?["keys"] as? [[String:Any]] {
var interstitialKeyList = [String]()
var bannerKeyList = [String]()
var nativeKeyList = [String]()
var rewardedKeyList = [String]()
var rewardedInterstitialKeyList = [String]()
var appOpenKeyList = [String]()
for response in responseList {
if let isDefault = response["is_default"] as? Bool,
isDefault == false {
let hiveAdKey = response["key"] as? String ?? ""
let hiveForm = response["form"] as? String ?? ""
switch hiveForm {
case "interstitial": interstitialKeyList.append(hiveAdKey)
case "banner": bannerKeyList.append(hiveAdKey)
case "native": nativeKeyList.append(hiveAdKey)
case "rewarded": rewardedKeyList.append(hiveAdKey)
case "rewarded_interstitial": rewardedInterstitialKeyList.append(hiveAdKey)
case "app_open": appOpenKeyList.append(hiveAdKey)
default: break
}
}
}
print("interstitialKeyList \(interstitialKeyList)");
print("bannerKeyList \(bannerKeyList)");
print("nativeKeyList \(nativeKeyList)");
print("rewardedKeyList \(rewardedKeyList)");
print("rewardedInterstitialKeyList \(rewardedInterstitialKeyList)");
print("appOpenKeyList \(appOpenKeyList)");
}
}
#import <HiveAdiz/HiveAdiz-Swift.h>
// 初始化 Hive Adiz
[Adiz initialize: targetViewController handler:^(AdizError * error, NSDictionary<NSString *,id> * json) {
if([error isSuccess] && json[@"keys"] != nil) {
NSArray* responseList = json[@"keys"];
NSMutableArray<NSString*> *interstitialKeyList = [[NSMutableArray alloc] init];
NSMutableArray<NSString*> *bannerKeyList = [[NSMutableArray alloc] init];
NSMutableArray<NSString*> *nativeKeyList = [[NSMutableArray alloc] init];
NSMutableArray<NSString*> *rewardedKeyList = [[NSMutableArray alloc] init];
NSMutableArray<NSString*> *rewardedInterstitialKeyList = [[NSMutableArray alloc] init];
NSMutableArray<NSString*> *appOpenKeyList = [[NSMutableArray alloc] init];
for (NSDictionary* response in responseList) {
// 這是一個設置廣告鍵列表的示例 (is_default = false),當你想直接放置廣告鍵時。
if (response[@"is_default"] != nil && [response[@"is_default"] boolValue] == false) {
NSString* hiveAdKey = response[@"key"];
NSString* hiveForm = response[@"form"];
if ([hiveForm isEqualToString: @"interstitial"]) {
[interstitialKeyList addObject: hiveAdKey];
} else if ([hiveForm isEqualToString: @"banner"]) {
[bannerKeyList addObject: hiveAdKey];
} else if ([hiveForm isEqualToString: @"native"]) {
[nativeKeyList addObject: hiveAdKey];
} else if ([hiveForm isEqualToString: @"rewarded"]) {
[rewardedKeyList addObject: hiveAdKey];
} else if ([hiveForm isEqualToString: @"rewarded_interstitial"]) {
[rewardedInterstitialKeyList addObject: hiveAdKey];
} else if ([hiveForm isEqualToString: @"app_open"]) {
[appOpenKeyList addObject: hiveAdKey];
}
}
}
NSLog(@"interstitialKeyList %@", interstitialKeyList);
NSLog(@"bannerKeyList %@", bannerKeyList);
NSLog(@"nativeKeyList %@", nativeKeyList);
NSLog(@"rewardedKeyList %@", rewardedKeyList);
NSLog(@"rewardedInterstitialKeyList %@", rewardedInterstitialKeyList);
NSLog(@"appOpenKeyList %@", appOpenKeyList);
}
}];
初始化时作为回调接收的 JSON 文件包含一个广告键的列表。广告键的列表具有以下格式。
{
"keys":[
{
"mediation_id":5,
"key":"ca-app-pub-3940256099942544/5354046379",
"form":"rewarded_interstitial",
"is_default":true,
"placement_id":"lobby01"
},
{
"mediation_id":4,
"key":"ca-app-pub-3940256099942544/5224354917",
"form":"rewarded",
"is_default":true,
"placement_id":"game02"
},
{
"mediation_id":3,
"key":"ca-app-pub-3940256099942544/2247696110",
"form":"native",
"is_default":true,
"placement_id":"event01"
},
{
"mediation_id":1,
"key":"ca-app-pub-3940256099942544/1033173712",
"form":"interstitial",
"is_default":true,
"placement_id":"mission01"
},
{
"mediation_id":2,
"key":"ca-app-pub-3940256099942544/6300978111",
"form":"banner",
"is_default":true,
"placement_id":"main01"
},
{
"mediation_id":6,
"key":"ca-app-pub-3940256099942544/9257395921",
"form":"app_open",
"is_default":true,
"placement_id":"appopen01"
}
]
}
在測試模式下初始化時,即使您尚未在控制台中註冊 AdMob 廣告金鑰,您仍會收到測試廣告金鑰的列表。在生產模式下初始化時,您將收到在控制台中註冊的 AdMob 廣告金鑰的列表。
對於每種類型的廣告(form
),一個廣告被用作預設廣告(具有"is_default":true
的廣告)。當任何類型的第一個廣告被註冊時,該廣告將成為預設廣告。創建廣告實例(initialize()
)時,預設廣告不需要輸入廣告鍵(hiveAdKey
)。要更改預設廣告,您必須從控制台刪除現有的預設廣告並註冊一個新的廣告。
設定廣告回調監聽器¶
透過在創建每個廣告實例時實現 AdizListener
,您可以根據廣告狀態的變化接收回調。
名稱 | 描述 | 所需實現 |
---|---|---|
onLoad() | 廣告成功加載 | O |
onFail(error: AdizError) | 失敗(失敗的原因可以通過 error.getCode() 和 error.getMessage() 知道) | O |
onShow() | 廣告顯示成功 | O |
onClick() | 廣告點擊 | O |
onPaidEvent(_ revenueData: AdRevenueData) | 在廣告曝光後的付費事件點收到,傳達廣告收入信息 | O |
onClose() | 廣告結束
| X |
onRewarded(_ rewardItem: RewardItem) | 用戶在基於獎勵的廣告(rewarded ,rewarded interstitial )曝光後獲得獎勵的時刻 | X |
import HiveAdiz
class TestAdizListener: AdizListener {
func onLoad() {
// 当广告加载时调用。
// 如果广告加载成功,您需要在所需的时刻调用广告实例的 .show() 来显示广告。
print("[\(delegateTypeName)] onLoad")
}
func onFail(_ error: AdizError) {
// 如果广告加载失败或由于其他原因广告显示失败时调用。
print("[\(delegateTypeName)] onFail: ")
print("(\(error.getCode())) \(error.getMessage() ?? "")")
}
func onShow() {
// 当广告显示时调用。
print("[\(delegateTypeName)] onShow")
}
func onClick() {
// 当广告被点击时调用。
print("[\(delegateTypeName)] onClick")
}
func onPaidEvent(_ revenueData: AdRevenueData) {
// 当广告产生收入时调用。
print("[\(delegateTypeName)] onPaidEvent: \(revenueData.getCurrency()) \(revenueData.getRevenue().description)")
var revenue = revenueData.getRevenue() // 广告曝光时的收入
var currency = revenueData.getCurrency() // 广告曝光时的收入货币代码
}
func onClose() {
// 当广告关闭时调用。
// 横幅、原生广告没有 onClose 回调。
print("[\(delegateTypeName)] onClose")
}
func onRewarded(_ rewardItem: RewardItem) {
// 在观看奖励广告、奖励插播广告时发生奖励时调用。
print("[\(delegateTypeName)] onRewarded")
print("amount: \(rewardItem.getItemAmount()) type: \(rewardItem.getItemType())")
var itemType = rewardItem.getItemType() // 獎勵項目類型
var itemAmount = rewardItem.getItemAmount() // 獎勵項目數量 }}
#import <HiveAdiz/HiveAdiz-Swift.h>
@interface TestAdizListener : NSObject<AdizListener>
@end
@implementation TestAdizListener
- (void) onLoad {
// 當廣告加載時被調用。
// 如果廣告加載成功,您需要在所需的時候調用廣告實例的.show()來顯示廣告。
NSLog(@"[TestAdizListener] onLoad");
}
- (void) onFail:(AdizError *)error {
// 如果广告加载失败或由于其他原因广告显示失败时调用。
NSLog(@"[TestAdizListener] onFail: ");
NSLog(@"errorCode: %ld, errorMessage: %@", (long)[error getCode], [error getMessage]);
}
- (void) onShow {
// Called when the ad is displayed.
NSLog(@"[TestAdizListener] onShow");
}
- (void) onClick {
// 被点击广告时调用。
NSLog(@"[TestAdizListener] onClick");
}
- (void) onPaidEvent:(AdRevenueData *)revenueData {
// 當廣告產生收入時呼叫。
NSLog(@"[TestAdizListener] onPaidEvent: %@ %f", [revenueData getCurrency], [revenueData getRevenue]);
double revenue = [revenueData getRevenue]; // 廣告曝光時的收入
NSString* currency = [revenueData getCurrency]; // 廣告曝光時的收入貨幣代碼
}
- (void) onClose {
// 當廣告關閉時調用。
// 橫幅、原生廣告沒有 onClose 回調。
NSLog(@"[TestAdizListener] onClose");
}
- (void) onRewarded:(RewardItem *)rewardItem {
// 當觀看廣告時獲得獎勵時調用。
NSLog(@"[TestAdizListener] onRewarded");
NSLog(@"金額: %ld 類型: %@", (long)[rewardItem getItemAmount], [rewardItem getItemType]);
NSString* itemType = [rewardItem getItemType]; // 獎勵項目類型
NSInteger itemAmount = [rewardItem getItemAmount]; // 獎勵項目數量
}
@end
錯誤代碼¶
當收到 onFail()
從 Adiz.Initialize
和 AdizListener
時,AdizError
錯誤代碼和錯誤信息如下。
常見代碼¶
編號 | 案例 | 解釋 |
---|---|---|
0 | 成功 | 成功 |
Adiz 錯誤代碼¶
編號 | 案例 | 解釋 |
---|---|---|
-1 | InvalidParam | 無效的參數 |
-2 | NotSupported | 不支持 |
-3 | InProgress | 處理中 |
-4 | Network | 網絡錯誤 |
-5 | NeedInitialize | 需要初始化 |
-6 | ResponseFail | 響應失敗 |
-7 | Timeout | 網絡超時 |
-99 | Unknown | 未知錯誤 |
廣告平台錯誤代碼¶
編號 | 案例 | 解釋 |
---|---|---|
-101 | NeedLoad | 廣告未加載 |
-102 | NeedReload | 因廣告曝光時間到期需要重新加載 |
-103 | NotEnoughInventory | 調解響應成功,但由於庫存不足而未填充廣告 |
-104 | MissingAppId | 調解請求的 AppID 錯誤 |
-105 | InternalNetworkError | 調解中的網絡相關錯誤 |
-106 | InvalidUnitId | 無效的單位 ID |
-107 | MediationNoFill | 調解適配器未能處理廣告請求 |
-108 | AlreadyLoaded | 已經處於加載狀態 |
-109 | CannotRequestAds | 無法請求廣告 |
-201 | GdprConsentError | GDPR 同意錯誤 |
-202 | IsNotPrivacyOptionsRequired | 無法顯示 GDPR 同意彈出窗口,或處於不需要顯示的狀態 |
廣告曝光與廣告終止¶
要曝光和終止廣告,請按照以下步驟操作。
- 為您想要顯示的每種類型的廣告在廣告類別中創建一個廣告實例。如果您想顯示的廣告不是預設廣告,則必須輸入從初始化獲得的廣告金鑰或放置 ID。如果您不輸入廣告金鑰(
hiveAdKey
)或放置 ID(placementId
),將創建一個預設廣告實例。放置 ID 可以在 Hive 控制台中設置,更多詳細信息請參閱控制台指南中的Admob 設定頁面。 - 加載您想要顯示的廣告(
load()
)。 - 顯示已加載的廣告(
show()
)。要再次顯示廣告,您必須再次調用load()
,然後調用show()
。 - 要關閉廣告,請調用
destroy()
。
插播廣告¶
這是一個全螢幕的插播廣告。
import UIKit
import HiveAdiz
class InitViewController: UIViewController {
// 創建一個插頁式廣告實例。
var interstitialAd: AdizInterstitial?
func requestInitAd(hiveAdKey: String?) {
if let adKey = hiveAdKey,
adKey.count > 0 {
// 初始化 AdizInterstitial 实例 (ViewController, hiveAdKey, AdizListener)
self.interstitialAd = AdizInterstitial.initialize(self, hiveAdKey: adKey, adizListener: self)
}
else {
// 初始化默认的 AdizInterstitial 实例 (ViewController, AdizListener)
self.interstitialAd = AdizInterstitial.initialize(self, adizListener: self)
}
}
func requestInitAdWithPlacementId(placementId: String?) {
if let placementId = placementId,
placementId.count > 0 {
// 初始化 AdizInterstitial 實例 (ViewController, placementId, AdizListener)
self.interstitialAd = AdizInterstitial.initializeWithPlacementId(self, placementId: placementId, adizListener: self)
}
else {
// 初始化默認的 AdizInterstitial 實例 (ViewController, AdizListener)
self.interstitialAd = AdizInterstitial.initialize(self, adizListener: self)
}
}
func requestLoadAd() {
// Load AdizInterstitial
if let ad = self.interstitialAd,
ad.isInitialized() {
ad.load()
}
}
func requestShowAd() {
// Show AdizInterstitial
if let ad = self.interstitialAd,
ad.isLoaded() {
ad.show()
}
}
func requestDestroyAd() {
// 銷毀 AdizInterstitial
self.interstitialAd?.destroy()
self.interstitialAd = nil
}
}
extension InitViewController: AdizListener {
func onLoad() {
// requestShowAd()
}
func onFail(_ error: AdizError) {
}
func onShow() {
}
func onClick() {
}
func onPaidEvent(_ revenueData: AdRevenueData) {
}
func onClose() {
// requestDestroyAd()
}
}
#import <UIKit/UIKit.h>
#import <HiveAdiz/HiveAdiz-Swift.h>
@interface InitViewController : UIViewController<AdizListener>
@property (nonatomic, strong) AdizInterstitial* interstitialAd;
@end
@implementation InitViewController
- (void) requestInitAd: (NSString*)hiveAdKey {
if (hiveAdKey != nil && ![hiveAdKey isEqualToString:@""]) {
// 初始化 AdizInterstitial 实例 (ViewController, hiveAdKey, AdizListener)
// 创建一个插页广告实例。
self.interstitialAd = [AdizInterstitial initialize:self hiveAdKey:hiveAdKey adizListener:self];
}
else {
// 初始化默认 AdizInterstitial 实例 (ViewController, AdizListener)
self.interstitialAd = [AdizInterstitial initialize:self adizListener:self];
}
}
- (void) requestInitAdWithPlacementId: (NSString*)placementId {
if (placementId != nil && ![placementId isEqualToString:@""]) {
// 初始化 AdizInterstitial 实例 (ViewController, placementId, AdizListener)
// 创建一个插页广告实例。
self.interstitialAd = [AdizInterstitial initializeWithPlacementId:self placementId:placementId adizListener:self];
}
else {
// 初始化默认的 AdizInterstitial 实例 (ViewController, AdizListener)
self.interstitialAd = [AdizInterstitial initialize:self adizListener:self];
}
}
- (void) requestLoadAd {
// 加載 AdizInterstitial
if (self.interstitialAd != nil && [self.interstitialAd isInitialized]) {
[self.interstitialAd load];
}
}
- (void) requestShowAd {
// 顯示 AdizInterstitial
if (self.interstitialAd != nil && [self.interstitialAd isLoaded]) {
[self.interstitialAd show];
}
}
- (void) requestDestroyAd {
// 銷毀 AdizInterstitial
if (self.interstitialAd != nil) {
[self.interstitialAd destroy];
self.interstitialAd = nil;
}
}
#pragma mark - AdizListener
- (void) onLoad {
// [self requestShowAd];
}
- (void) onFail:(AdizError *)error {
}
- (void) onShow {
}
- (void) onClick {
}
- (void) onPaidEvent:(AdRevenueData *)revenueData {
}
- (void) onClose {
// [self requestDestroyAd];
}
@end
橫幅廣告¶
這是一個顯示特定大小橫幅的橫幅廣告。橫幅廣告不會接收 onClose()
回調。因此,您需要從其他位置調用 destroy()
來終止廣告。
BannerSize
遵循標準橫幅大小。
尺寸點(寬 x 高) | 描述 | 支持的設備 | BannerSize 常量 |
---|---|---|---|
320x50 | 橫幅 | 手機和平板電腦 | BannerSize.normal |
320x100 | 大橫幅 | 手機和平板電腦 | BannerSize.medium |
300x250 | IAB 中型矩形 | 手機和平板電腦 | BannerSize.large |
468 x 60 | IAB 全尺寸橫幅 | 平板電腦 | BannerSize.full |
PositionType
是最上面或最下面的。默認值是最下面的。
對齊方式 | 描述 | PositionType 常數 |
---|---|---|
頂部對齊 | 根據 SafeArea 指定在螢幕頂部的對齊方式 | PositionType.top |
底部對齊(預設) | 根據 SafeArea 指定在螢幕底部的對齊方式 | PositionType.bottom |
import UIKit
import HiveAdiz
class BannerViewController: UIViewController {
// 創建 AdizBanner 實例
// 創建一個橫幅廣告實例。
var bannerAd: AdizBanner?
func requestInitAd(hiveAdKey: String?) { // 設定橫幅大小
var bannerSize: BannerSize = .normal
if let adKey = hiveAdKey,
adKey.count > 0 {
// 初始化 AdizBanner 实例 (ViewController, hiveAdKey, BannerSize, AdizListener)
self.bannerAd = AdizBanner.initialize(self, hiveAdKey: adKey, size: bannerSize, adizListener: self)
}
else {
// 初始化默认的 AdizBanner 实例 (ViewController, BannerSize, AdizListener)
self.bannerAd = AdizBanner.initialize(self, size: bannerSize, adizListener: self)
}
}
func requestInitAdWithPlacementId(placementId: String?) { // 設定橫幅大小
var bannerSize: BannerSize = .normal
if let placementId = placementId,
placementId.count > 0 {
// 初始化 AdizBanner 实例 (ViewController, placementId, BannerSize, AdizListener)
self.bannerAd = AdizBanner.initializeWithPlacementId(self, placementId: placementId, size: bannerSize, adizListener: self)
}
else {
// 初始化默认 AdizBanner 实例 (ViewController, BannerSize, AdizListener)
self.bannerAd = AdizBanner.initialize(self, size: bannerSize, adizListener: self)
}
}
func requestLoadAd() {
// Load AdizBanner
if let ad = self.bannerAd,
ad.isInitialized() {
ad.load()
}
}
func requestShowAd() {
// 設定位置類型
var position: PositionType = .top
// 顯示 AdizBanner
if let ad = self.bannerAd,
ad.isLoaded() {
ad.show(position)
}
}
func requestDestroyAd() {
// Destroy AdizBanner
self.bannerAd?.destroy()
self.bannerAd = nil
}
}
extension BannerViewController: AdizListener {
func onLoad() {
// requestShowAd()
}
func onFail(_ error: AdizError) {
}
func onShow() {
}
func onClick() {
}
func onPaidEvent(_ revenueData: AdRevenueData) {
}
}
#import <UIKit/UIKit.h>
#import <HiveAdiz/HiveAdiz-Swift.h>
@interface BannerViewController : UIViewController<AdizListener>
@property (nonatomic, strong) AdizBanner* bannerAd;
@end
@implementation BannerViewController
- (void) requestInitAd: (NSString*)hiveAdKey {
// 設定橫幅大小
BannerSize bannerSize = BannerSizeNormal;
if (hiveAdKey != nil && ![hiveAdKey isEqualToString:@""]) {
// 初始化 AdizBanner 实例 (ViewController, hiveAdKey, BannerSize, AdizListener)
self.bannerAd = [AdizBanner initialize:self hiveAdKey:hiveAdKey size: bannerSize adizListener:self];
} else {
// 初始化默认 AdizBanner 实例 (ViewController, BannerSize, AdizListener)
self.bannerAd = [AdizBanner initialize:self size:bannerSize adizListener:self];
}
}
- (void) requestInitAdWithPlacementId: (NSString*)placementId {
// 設定橫幅大小
BannerSize bannerSize = BannerSizeNormal;
if (placementId != nil && ![placementId isEqualToString:@""]) {
// 初始化 AdizBanner 实例 (ViewController, placementId, BannerSize, AdizListener)
self.bannerAd = [AdizBanner initializeWithPlacementId:self placementId:placementId size: bannerSize adizListener:self];
} else {
// 初始化默认 AdizBanner 实例 (ViewController, BannerSize, AdizListener)
self.bannerAd = [AdizBanner initialize:self size:bannerSize adizListener:self];
}
}
- (void) requestLoadAd {
// 加載 AdizBanner
if (self.bannerAd != nil && [self.bannerAd isInitialized]) {
[self.bannerAd load];
}
}
- (void) requestShowAd {
// 設置位置類型
PositionType position = PositionTypeTop;
// 顯示 AdizBanner
if (self.bannerAd != nil && [self.bannerAd isLoaded]) {
[self.bannerAd show: position];
}
}
- (void) requestDestroyAd {
// 銷毀 AdizBanner
if (self.bannerAd != nil) {
[self.bannerAd destroy];
self.bannerAd = nil;
}
}
#pragma mark - AdizListener
- (void) onLoad {
// [self requestShowAd];
}
- (void) onFail:(AdizError *)error {
}
- (void) onShow {
}
- (void) onClick {
}
- (void) onPaidEvent:(AdRevenueData *)revenueData {
}
@end
原生廣告¶
這是一個原生廣告,顯示特定大小的原生模板。原生廣告已針對垂直螢幕進行優化,因此建議在垂直遊戲(豎屏遊戲)中使用。原生廣告不會接收 onClose()
回調。因此,您需要從其他位置調用 destroy()
來關閉廣告。
當前模板支持 small
或 medium
尺寸。
尺寸點(寬 x 高) | 模板 | 對齊方式 | BannerSize 常數 |
---|---|---|---|
355x91(比例調整) | 小尺寸 | 上 / 下 | BannerSize.normal |
355x370(比例調整) | 中尺寸 | 居中(固定) | BannerSize.medium, BannerSize.large, BannerSize.full |
在 small
模板中,PositionType
可以是顶部或底部,默认为底部。
對齊方式 | 描述 | 位置類型常數 |
---|---|---|
頂部對齊 | 指定在螢幕頂部的對齊方式 | PositionType.top |
底部對齊(預設) | 指定在螢幕底部的對齊方式 | PositionType.bottom |
medium
模板不允許選擇對齊方式,並默認使用居中對齊。
import UIKit
import HiveAdiz
class NativeViewController: UIViewController {
// 創建 AdizNative 實例
var nativeAd: AdizNative?
func requestInitAd(hiveAdKey: String?) {
// 設定橫幅大小
var bannerSize: BannerSize = .normal
if let adKey = hiveAdKey,
adKey.count > 0 {
// 初始化 AdizNative 实例 (ViewController, hiveAdKey, BannerSize, AdizListener)
self.nativeAd = AdizNative.initialize(self, hiveAdKey: adKey, size: bannerSize, adizListener: self)
}
else {
// 初始化默认的 AdizNative 实例 (ViewController, BannerSize, AdizListener)
self.nativeAd = AdizNative.initialize(self, size: bannerSize, adizListener: self)
}
}
func requestInitAdWithPlacementId(placementId: String?) {
// 設定橫幅大小
var bannerSize: BannerSize = .normal
if let placementId = placementId,
placementId.count > 0 {
// 初始化 AdizNative 实例 (ViewController, placementId, BannerSize, AdizListener)
self.nativeAd = AdizNative.initializeWithPlacementId(self, placementId: placementId, size: bannerSize, adizListener: self)
}
else {
// 初始化默认的 AdizNative 实例 (ViewController, BannerSize, AdizListener)
self.nativeAd = AdizNative.initialize(self, size: bannerSize, adizListener: self)
}
}
func requestLoadAd() {
// Load AdizNative
if let ad = self.nativeAd,
ad.isInitialized() {
ad.load()
}
}
func requestShowAd() {
// 設定位置類型
var position: PositionType = .top
// 顯示 AdizNative
if let ad = self.nativeAd,
ad.isLoaded() {
ad.show(position)
}
}
func requestDestroyAd() {
// 銷毀 AdizNative
self.nativeAd?.destroy()
self.nativeAd = nil
}
}
extension NativeViewController: AdizListener {
func onLoad() {
// requestShowAd()
}
func onFail(_ error: AdizError) {
}
func onShow() {
}
func onClick() {
}
func onPaidEvent(_ revenueData: AdRevenueData) {
}
}
#import <UIKit/UIKit.h>
#import <HiveAdiz/HiveAdiz-Swift.h>
@interface NativeViewController : UIViewController<AdizListener>
@property (nonatomic, strong) AdizNative* nativeAd;
@end
@implementation NativeViewController
- (void) requestInitAd: (NSString*)hiveAdKey {
// 設定橫幅大小
BannerSize bannerSize = BannerSizeNormal;
if (hiveAdKey != nil && ![hiveAdKey isEqualToString:@""]) {
// 初始化 AdizNative 实例 (ViewController, hiveAdKey, BannerSize, AdizListener)
self.nativeAd = [AdizNative initialize:self hiveAdKey:hiveAdKey size: bannerSize adizListener:self];
}
else {
// 初始化默认 AdizNative 实例 (ViewController, BannerSize, AdizListener)
self.nativeAd = [AdizNative initialize:self size:bannerSize adizListener:self];
}
}
- (void) requestInitAdWithPlacementId: (NSString*)placementId {
// 設定橫幅大小
BannerSize bannerSize = BannerSizeNormal;
if (placementId != nil && ![placementId isEqualToString:@""]) {
// 初始化 AdizNative 实例 (ViewController, placementId, BannerSize, AdizListener)
self.nativeAd = [AdizNative initializeWithPlacementId:self placementId:placementId size: bannerSize adizListener:self];
}
else {
// 初始化默认的 AdizNative 实例 (ViewController, BannerSize, AdizListener)
self.nativeAd = [AdizNative initialize:self size:bannerSize adizListener:self];
}
}
- (void) requestLoadAd {
// 加載 AdizNative
if (self.nativeAd != nil && [self.nativeAd isInitialized]) {
[self.nativeAd load];
}
}
- (void) requestShowAd {
// 設定位置類型
PositionType position = PositionTypeTop;
// 顯示 AdizNative
if (self.nativeAd != nil && [self.nativeAd isLoaded]) {
[self.nativeAd show: position];
}
}
- (void) requestDestroyAd {
// 銷毀 AdizNative
if (self.nativeAd != nil) {
[self.nativeAd destroy];
self.nativeAd = nil;
}
}
#pragma mark - AdizListener
- (void) onLoad {
// [self requestShowAd];
}
- (void) onFail:(AdizError *)error {
}
- (void) onShow {
}
- (void) onClick {
}
- (void) onPaidEvent:(AdRevenueData *)revenueData {
}
@end
獎勵廣告¶
這是一個獎勵廣告,用戶在觀看廣告一段時間後會獲得獎勵。獎勵一旦發放,獎勵項目的信息將通過onRewarded()
回調接收。
import UIKit
import HiveAdiz
class RewardViewController: UIViewController {
// 創建 AdizRewarded 實例
var rewardAd: AdizRewarded?
func requestInitAd(hiveAdKey: String?) {
if let adKey = hiveAdKey,
adKey.count > 0 {
// 初始化 AdizRewarded 实例 (ViewController, hiveAdKey, AdizListener)
self.rewardAd = AdizRewarded.initialize(self, hiveAdKey: adKey, adizListener: self)
}
else {
// 初始化默认 AdizRewarded 实例 (ViewController, AdizListener)
self.rewardAd = AdizRewarded.initialize(self, adizListener: self)
}
}
func requestInitAdWithPlacementId(placementId: String?) {
if let placementId = placementId,
placementId.count > 0 {
// 初始化 AdizRewarded 实例 (ViewController, placementId, AdizListener)
self.rewardAd = AdizRewarded.initializeWithPlacementId(self, placementId: placementId, adizListener: self)
}
else {
// 初始化默认的 AdizRewarded 实例 (ViewController, AdizListener)
self.rewardAd = AdizRewarded.initialize(self, adizListener: self)
}
}
func requestLoadAd() {
// Load AdizRewarded
if let ad = self.rewardAd,
ad.isInitialized() {
ad.load()
}
}
func requestShowAd() {
// Show AdizRewarded
if let ad = self.rewardAd,
ad.isLoaded() {
ad.show()
}
}
func requestDestroyAd() {
// Destroy AdizRewarded
self.rewardAd?.destroy()
self.rewardAd = nil
}
}
extension RewardViewController: AdizListener {
func onLoad() {
// requestShowAd()
}
func onFail(_ error: AdizError) {
}
func onShow() {
}
func onClick() {
}
func onPaidEvent(_ revenueData: AdRevenueData) {
}
func onClose() {
// requestDestroyAd()
}
func onRewarded(_ rewardItem: RewardItem) {
}
}
#import <UIKit/UIKit.h>
#import <HiveAdiz/HiveAdiz-Swift.h>
@interface RewardedViewController : UIViewController<AdizListener>
@property (nonatomic, strong) AdizRewarded* rewardedAd;
@end
@implementation RewardedViewController
- (void) requestInitAd: (NSString*)hiveAdKey {
if (hiveAdKey != nil && ![hiveAdKey isEqualToString:@""]) {
// 初始化 AdizRewarded 实例 (ViewController, hiveAdKey, AdizListener)
self.rewardedAd = [AdizRewarded initialize:self hiveAdKey:hiveAdKey adizListener:self];
}
else {
// 初始化默认 AdizRewarded 实例 (ViewController, AdizListener)
self.rewardedAd = [AdizRewarded initialize:self adizListener:self];
}
}
- (void) requestInitAdWithPlacementId: (NSString*)placementId {
if (placementId != nil && ![placementId isEqualToString:@""]) {
// 初始化 AdizRewarded 实例 (ViewController, placementId, AdizListener)
self.rewardedAd = [AdizRewarded initializeWithPlacementId:self placementId:placementId adizListener:self];
}
else {
// 初始化默认 AdizRewarded 实例 (ViewController, AdizListener)
self.rewardedAd = [AdizRewarded initialize:self adizListener:self];
}
}
- (void) requestLoadAd {
// 加載 AdizRewarded
if (self.rewardedAd != nil && [self.rewardedAd isInitialized]) {
[self.rewardedAd load];
}
}
- (void) requestShowAd {
// 顯示 AdizRewarded
if (self.rewardedAd != nil && [self.rewardedAd isLoaded]) {
[self.rewardedAd show];
}
}
- (void) requestDestroyAd {
// 銷毀 AdizRewarded
if (self.rewardedAd != nil) {
[self.rewardedAd destroy];
self.rewardedAd = nil;
}
}
#pragma mark - AdizListener
- (void) onLoad {
// [self requestShowAd];
}
- (void) onFail:(AdizError *)error {
}
- (void) onShow {
}
- (void) onClick {
}
- (void) onPaidEvent:(AdRevenueData *)revenueData {
}
- (void) onClose {
// [self requestDestroyAd];
}
- (void) onRewarded:(RewardItem *)rewardItem {
}
@end
獎勵插頁廣告¶
這是一個獎勵插頁廣告,使用者在觀看廣告一段時間後會獲得獎勵。一旦獎勵被授予,獎勵項目的信息將通過 onRewarded()
回調接收。
import UIKit
import HiveAdiz
class RewardInterstitialViewController: UIViewController {
// 創建 AdizRewardedInterstitial 實例
var rewardInterstitialAd: AdizRewardedInterstitial?
func requestInitAd(hiveAdKey: String?) {
if let adKey = hiveAdKey,
adKey.count > 0 {
// 初始化 AdizRewardedInterstitial 实例 (ViewController, hiveAdKey, AdizListener)
self.rewardInterstitialAd = AdizRewardedInterstitial.initialize(self, hiveAdKey: adKey, adizListener: self)
}
else {
// 初始化默认的 AdizRewardedInterstitial 实例 (ViewController, AdizListener)
self.rewardInterstitialAd = AdizRewardedInterstitial.initialize(self, adizListener: self)
}
}
func requestInitAdWithPlacementId(placementId: String?) {
if let placementId = placementId,
placementId.count > 0 {
// 初始化 AdizRewardedInterstitial 實例 (ViewController, placementId, AdizListener)
self.rewardInterstitialAd = AdizRewardedInterstitial.initializeWithPlacementId(self, placementId: placementId, adizListener: self)
}
else {
// 初始化默認的 AdizRewardedInterstitial 實例 (ViewController, AdizListener)
self.rewardInterstitialAd = AdizRewardedInterstitial.initialize(self, adizListener: self)
}
}
func requestLoadAd() {
// Load AdizRewardedInterstitial
if let ad = self.rewardInterstitialAd,
ad.isInitialized() {
ad.load()
}
}
func requestShowAd() {
// 顯示 AdizRewardedInterstitial
if let ad = self.rewardInterstitialAd,
ad.isLoaded() {
ad.show()
}
}
func requestDestroyAd() {
// 銷毀 AdizRewardedInterstitial
self.rewardInterstitialAd?.destroy()
self.rewardInterstitialAd = nil
}
}
extension RewardInterstitialViewController: AdizListener {
func onLoad() {
// requestShowAd()
}
func onFail(_ error: AdizError) {
}
func onShow() {
}
func onClick() {
}
func onPaidEvent(_ revenueData: AdRevenueData) {
}
func onClose() {
// requestDestroyAd()
}
func onRewarded(_ rewardItem: RewardItem) {
}
}
#import <UIKit/UIKit.h>
#import <HiveAdiz/HiveAdiz-Swift.h>
@interface RewardedInterstitialViewController : UIViewController<AdizListener>
@property (nonatomic, strong) AdizRewardedInterstitial* rewardedInterstitialAd;
@end
@implementation RewardedInterstitialViewController
- (void) requestInitAd: (NSString*)hiveAdKey {
if (hiveAdKey != nil && ![hiveAdKey isEqualToString:@""]) {
// 初始化 AdizRewardedInterstitial 实例 (ViewController, hiveAdKey, AdizListener)
self.rewardedInterstitialAd = [AdizRewardedInterstitial initialize:self hiveAdKey:hiveAdKey adizListener:self];
}
else {
// 初始化默认 AdizRewardedInterstitial 实例 (ViewController, AdizListener)
self.rewardedInterstitialAd = [AdizRewardedInterstitial initialize:self adizListener:self];
}
}
- (void) requestInitAdWithPlacementId: (NSString*)placementId {
if (placementId != nil && ![placementId isEqualToString:@""]) {
// 初始化 AdizRewardedInterstitial 实例 (ViewController, placementId, AdizListener)
self.rewardedInterstitialAd = [AdizRewardedInterstitial initializeWithPlacementId:self placementId:placementId adizListener:self];
}
else {
// 初始化默认的 AdizRewardedInterstitial 实例 (ViewController, AdizListener)
self.rewardedInterstitialAd = [AdizRewardedInterstitial initialize:self adizListener:self];
}
}
- (void) requestLoadAd {
// 加載 AdizRewardedInterstitial
if (self.rewardedInterstitialAd != nil && [self.rewardedInterstitialAd isInitialized]) {
[self.rewardedInterstitialAd load];
}
}
- (void) requestShowAd {
// 顯示 AdizRewardedInterstitial
if (self.rewardedInterstitialAd != nil && [self.rewardedInterstitialAd isLoaded]) {
[self.rewardedInterstitialAd show];
}
}
- (void) requestDestroyAd {
// 銷毀 AdizRewardedInterstitial
if (self.rewardedInterstitialAd != nil) {
[self.rewardedInterstitialAd destroy];
self.rewardedInterstitialAd = nil;
}
}
#pragma mark - AdizListener
- (void) onLoad {
// [self requestShowAd];
}
- (void) onFail:(AdizError *)error {
}
- (void) onShow {
}
- (void) onClick {
}
- (void) onPaidEvent:(AdRevenueData *)revenueData {
}
- (void) onClose {
// [self requestDestroyAd];
}
- (void) onRewarded:(RewardItem *)rewardItem {
}
@end
應用程式開啟廣告 (AppOpen)¶
這是一個應用程式開啟廣告,當應用程式狀態從背景變為前景時,顯示一個預加載的 (load()
) 廣告。如果在廣告加載後經過 3 小時後調用 show()
,廣告將自動重新加載並顯示。一旦廣告至少顯示過一次,它將不會自動重新加載。
import UIKit
import HiveAdiz
class AppOpenViewController: UIViewController {
// 創建 AdizAppOpen 實例
var appOpenAd: AdizAppOpen?
func requestInitAd(hiveAdKey: String?) {
if let adKey = hiveAdKey,
adKey.count > 0 {
// 初始化 AdizAppOpen 实例 (ViewController, hiveAdKey, AdizListener)
self.appOpenAd = AdizAppOpen.initialize(self, hiveAdKey: adKey, adizListener: self)
}
else {
// 初始化默认的 AdizAppOpen 实例 (ViewController, AdizListener)
self.appOpenAd = AdizAppOpen.initialize(self, adizListener: self)
}
}
func requestInitAdWithPlacementId(placementId: String?) {
if let placementId = placementId,
placementId.count > 0 {
// 初始化 AdizAppOpen 实例 (ViewController, placementId, AdizListener)
self.appOpenAd = AdizAppOpen.initializeWithPlacementId(self, placementId: placementId, adizListener: self)
}
else {
// 初始化默认的 AdizAppOpen 实例 (ViewController, AdizListener)
self.appOpenAd = AdizAppOpen.initialize(self, adizListener: self)
}
}
func requestLoadAd() {
// Load AdizAppOpen
if let ad = self.appOpenAd,
ad.isInitialized() {
ad.load()
}
}
func requestShowAd() {
print("[appOpenAd] appOpenAd don't request Show")
}
func requestDestroyAd() {
// 銷毀 AdizAppOpen
self.appOpenAd?.destroy()
self.appOpenAd = nil
}
}
extension AppOpenViewController: AdizListener {
func onLoad() {
}
func onFail(_ error: AdizError) {
}
func onShow() {
}
func onClick() {
}
func onPaidEvent(_ revenueData: AdRevenueData) {
}
func onClose() {
// requestDestroyAd()
}
}
#import <UIKit/UIKit.h>
#import <HiveAdiz/HiveAdiz-Swift.h>
@interface AppOpenViewController : UIViewController<AdizListener>
@property (nonatomic, strong) AdizAppOpen* appOpenAd;
@end
@implementation AppOpenViewController
- (void) requestInitAd: (NSString*)hiveAdKey {
if (hiveAdKey != nil && ![hiveAdKey isEqualToString:@""]) {
// 初始化 AdizAppOpen 实例 (ViewController, hiveAdKey, AdizListener)
self.appOpenAd = [AdizAppOpen initialize:self hiveAdKey:hiveAdKey adizListener:self];
}
else {
// 初始化默认的 AdizAppOpen 实例 (ViewController, AdizListener)
self.appOpenAd = [AdizAppOpen initialize:self adizListener:self];
}
}
- (void) requestInitAdWithPlacementId: (NSString*)placementId {
if (placementId != nil && ![placementId isEqualToString:@""]) {
// 初始化 AdizAppOpen 实例 (ViewController, placementId, AdizListener)
self.appOpenAd = [AdizAppOpen initializeWithPlacementId:self placementId:placementId adizListener:self];
}
else {
// 初始化默认 AdizAppOpen 实例 (ViewController, AdizListener)
self.appOpenAd = [AdizAppOpen initialize:self adizListener:self];
}
}
- (void) requestLoadAd {
// 加載 AdizAppOpen
if (self.appOpenAd != nil && [self.appOpenAd isInitialized]) {
[self.appOpenAd load];
}
}
- (void) requestShowAd {
NSLog(@"[appOpenAd] appOpenAd don't request Show");
}
- (void) requestDestroyAd {
// 销毁 AdizAppOpen
if (self.appOpenAd != nil) {
[self.appOpenAd destroy];
self.appOpenAd = nil;
}
}
#pragma mark - AdizListener
- (void) onLoad {
}
- (void) onFail:(AdizError *)error {
}
- (void) onShow {
}
- (void) onClick {
}
- (void) onPaidEvent:(AdRevenueData *)revenueData {
}
- (void) onClose {
// [self requestDestroyAd];
}
@end