跳轉至

iOS

Adiz iOS

Adiz iOS 是一個為 iOS 提供的廣告模組,旨在使 Hive 平台上的 AdMob 廣告曝光功能更易於使用。Adiz iOS 提供的廣告類型如下。

  • 插頁廣告
  • 橫幅廣告
  • 原生廣告
  • 獎勵廣告
  • 獎勵插頁廣告
  • 應用開啟廣告

要安裝和使用 Adiz iOS,請按照以下指南進行。

準備

設置Adiz iOS 開發環境

安裝

GADApplicationIdentifier 鍵添加到您的 Xcode 項目的 Info.plist 文件中,並將 AdMobId 值(格式為 ca-app-pub-XXXXX~YYYYY)作為該鍵的值輸入。

    <key>GADApplicationIdentifier</key>
    <string>ca-app-pub-XXXXX~YYYYY</string>

 

此外,對於 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 可以以兩種方式顯示測試廣告。

  1. 啟用測試模式:僅顯示由 AdMob 發佈的測試廣告
  2. 在註冊測試設備後顯示廣告:顯示真實廣告以進行測試,確保不會產生無效流量,並通過註冊將顯示測試廣告的設備來進行

測試模式啟用

在開發階段,啟用測試模式,以便點擊測試廣告不會向廣告主收費。當測試模式啟用時,將僅顯示測試廣告。在測試模式下,即使未在控制台中輸入 AdMob 廣告密鑰,也會顯示測試廣告。商業發行期間將停用測試模式。

有兩種方法可以啟用測試模式。
<

  • 在 Hive 控制台中注册测试设备后,将其设置为演示广告(推荐):
    请参考控制台指南的 测试设备管理 部分。
  • 使用 Adiz 类的 setTestMode() 方法:
    参考 下面的示例代码
Note

當在開發階段未處於測試模式時,對廣告的過度點擊可能會被視為無效流量,並且您的 AdMob 帳戶可能會被報告,從而阻止廣告顯示。

使用 Adiz.setTestMode() 方法

import HiveAdiz

// 啟用測試模式。將以下行註解掉以進行生產部署。
Adiz.setTestMode(true)

// 啟用 Adiz 模組日誌。日誌應僅在測試模式下使用。對於生產部署,請註釋掉下面的行。
Adiz.setLogEnable(true)
#import <HiveAdiz/HiveAdiz-Swift.h> 

// 啟用測試模式。將下面的行註解掉以進行生產部署。
[Adiz setTestMode: true];

// 啟用 Adiz 模組日誌記錄。日誌記錄應僅在測試模式下使用。對於生產部署,請將以下行註釋掉。
[Adiz setLogEnable: true];

測試設備廣告曝光

在以下情況下,您需要註冊一個測試設備以顯示測試廣告。

  • 測試在控制台中註冊的 AdMob 廣告金鑰是否正常運作
  • 撰寫GDPR 訊息並檢查 GDPR 同意彈出窗口是否正常運作
  • 運行廣告檢查器以分析和調試廣告請求



<

在測試設備上有兩種顯示廣告的方法。
<

  • 在 Hive 控制台中注册测试设备后,将其设置为 使用广告单元 ID(推荐):
    请参考控制台指南的 测试设备管理 部分。

  • 使用Adiz類的setTestDevice()方法:
    請參考下面的示例代碼

Note

如果您进行测试而未注册测试设备,实际广告可能会被视为无效流量,这将导致您的 AdMob 帐户被封锁,并可能阻止进一步的广告曝光。通过注册测试设备,在广告曝光期间将显示“测试模式”或“测试广告”(原生广告)。在商业分发期间,您必须停用测试设备。

 

橫幅、全螢幕廣告或獎勵廣告

 

原生廣告

 

使用 Adiz.setTestDevice() 方法

要注册测试设备,您首先需要检查测试设备 ID。测试设备 ID(示例:B74F6468-1516-467C-99AD-CC5973C5DB52)可以通过以下两种方式进行验证。

  1. 在调用 Adiz.Initialize() 后检查 Logcat 日志:
    要為此設備啟用調試模式,請設置: UMPDebugSettings.testDeviceIdentifiers = @[B74F6468-1516-467C-99AD-CC5973C5DB52]
    
  2. 在調用 Adiz.Initialize() 之後,無論廣告類型如何,都要調用 initialize()load() 並檢查 Logcat 日誌:
    GADMobileAds.sharedInstance().requestConfiguration.testDeviceIdentifiers = [ "B74F6468-1516-467C-99AD-CC5973C5DB52" ]
    

 

在检查测试设备 ID 后,在现有的 Hive Adiz 初始化代码中执行 Adiz.initialize 之前,添加行 Adiz.SetTestDevice(DEVICE_ID)。将复制的测试设备 ID 输入到 DEVICE_ID 中。

 

func setTestDevice(testId: String) {
        Adiz.setTestDevice(testId)
}
- (void)setTestDevice: (NSString *)testId {
        [Adiz setTestDevice: testId];
}


廣告檢查器使用

廣告檢查器是一個應用內的覆蓋工具,實時分析在測試設備上請求和顯示實際廣告的過程。它告訴您加載廣告所需的時間,並提供任何顯示廣告失敗的原因。您還可以指定特定的廣告網絡,以檢查廣告是否正確顯示,如果有問題,您可以在代碼層面進行調試。所有這些都是在廣告檢查器用戶界面旁邊進行的。它包含在 Google Mobile Ads SDK 版本 7.68.0 及以上版本中,可以通過調用 AdizDeveloperTool.OpenAdInspector 來使用。

 

要使用廣告檢查器,必須設置測試設備上的廣告曝光

func openAdInspector(viewController: UIViewController) {
        AdizDeveloperTool.openAdInspector(viewController)
}
- (void)openAdInspector: (UIViewController *)viewController {
        [AdizDeveloperTool openAdInspector: viewController];
}

Adiz AppID 設定

設定您在 Hive 控制台 AppCenter 中註冊的 Adiz AppID。如果未設定,將使用 Bundle ID。

Adiz.setAppId(appId)
[Adiz setAppId: appId];

Hive 控制台伺服器配置

設置 Hive 控制台伺服器以供使用。默認為 real。即使您使用生產伺服器,啟用測試模式也僅會顯示測試廣告。

  • Hive 測試控制台伺服器: AdizZoneType.test
  • Hive 沙盒控制台伺服器: AdizZoneType.sandbox
  • Hive 生產控制台伺服器: AdizZoneType.real
Adiz.setZone(AdizZoneType.real)
[Adiz setZone: AdizZoneTypeReal];

用戶特定的廣告曝光

隨著在 iOS 14.5+ 中引入的 ATT(應用追蹤透明度),隱私保護得到了加強。因此,只有在用戶同意在 ATT 同意彈出窗口中進行活動追蹤的情況下,才能顯示用戶特定的廣告。為了通過顯示用戶特定的廣告來最大化廣告收入,您需要創建一個 IDFA(廣告商標識符)消息。

AdMob 在儀表板上遵循以下 IDFA 消息撰寫指南來撰寫和發布您的消息。

在撰寫並發佈 IDFA 訊息後,設置用戶追蹤訪問權限。按照以下步驟將鍵添加到 Info.plist

  1. 在 Xcode 项目窗口的项目导航器中选择您的项目。
  2. 在 TARGETS 列表中选择您的应用。
  3. 点击 Info 标签。
  4. 在 Info 标签中点击自定义 iOS 目标属性项。
  5. 在自定义 iOS 目标属性列表中右键单击。
  6. 点击添加行菜单。
  7. 在键字段中输入 NSUserTrackingUsageDescription,并在值字段中添加在 多语言设置文件 > Base.Iproj 文件夹 > InfoPlist.strings 中指定的值。

 

接下來,撰寫一條消息,請求來自多語言配置文件中指定的應用用戶的許可批准(一般設置 > 訪問許可請求設置)。如果您不輸入許可批准請求彈出消息,則將缺少有關正在使用的用戶訪問許可的附加說明指南,並且應用在審核過程中將被拒絕。

 

如果您已完成到此步骤,ATT 同意弹出窗口将在 Adiz 初始化 期间自动显示。当用户在 ATT 同意弹出窗口上点击“允许”时,IDFA 将被激活,并将显示个性化广告。

如果您的遊戲針對歐洲和英國(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同意/撤回功能,請按照以下步驟操作。

  1. 在應用中實現一個按鈕 UI,可以重新打開 GDPR 同意彈出窗口。
  2. 在實現 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 測試設備。

  1. 通过初始化来初始化Adiz。这是一个初始化步骤,用于检查测试设备ID,无需编写GDPR同意消息。
  2. 检查调试日志以确认设备ID的消息。以下消息是一个示例。

    要为此设备启用调试模式,请设置:UMPDebugSettings.testDeviceIdentifiers = @[B74F6468-1516-467C-99AD-CC5973C5DB52]

    在消息中检查设备ID(示例:B74F6468-1516-467C-99AD-CC5973C5DB52)。

  3. 复制设备ID。
  4. 在现有的Adiz初始化代码中,在执行Adiz.initialize之前添加Adiz.setTestDevice(DEVICE_ID)
  5. 编写GDPR同意消息并重新初始化Adiz,以确保GDPR同意弹出窗口正确显示。
func initialize(_ appId: String) {
    // ...
    // 在 Adiz.initialize 之前設置 TestDevice。例子 @"B74F6468-1516-467C-99AD-CC5973C5DB52"
    Adiz.setTestDevice("B74F6468-1516-467C-99AD-CC5973C5DB52")

    // HiveAdiz 初始化
    Adiz.initialize(targetViewController) { error, json in
            // ...
    }
}
- (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() 廣告結束
  • 要在廣告結束後重新顯示相同的廣告實例,您必須再次調用 load(),然後調用 show()
  • 要停止顯示廣告,請調用 destroy() 以移除廣告實例。
X
onRewarded(_ rewardItem: RewardItem) 用戶在基於獎勵的廣告(rewardedrewarded 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.InitializeAdizListener 時,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 同意彈出窗口,或處於不需要顯示的狀態

廣告曝光與廣告終止

要曝光和終止廣告,請按照以下步驟操作。

  1. 為您想要顯示的每種類型的廣告在廣告類別中創建一個廣告實例。如果您想顯示的廣告不是預設廣告,則必須輸入從初始化獲得的廣告金鑰或放置 ID。如果您不輸入廣告金鑰(hiveAdKey)或放置 ID(placementId),將創建一個預設廣告實例。放置 ID 可以在 Hive 控制台中設置,更多詳細信息請參閱控制台指南中的Admob 設定頁面。
  2. 加載您想要顯示的廣告(load())。
  3. 顯示已加載的廣告(show())。要再次顯示廣告,您必須再次調用load(),然後調用show()
  4. 要關閉廣告,請調用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() 來關閉廣告。

 

當前模板支持 smallmedium 尺寸。

尺寸點(寬 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