本指南介绍了如何使用 Google 移动广告 SDK 使用中介加载和展示来自 Chartboost 的广告,其中涵盖了广告瀑布流集成。其中介绍了如何将 Chartboost 添加到广告单元的中介配置,以及如何将 Chartboost SDK 和适配器集成到 iOS 应用中。
支持的集成和广告格式
Chartboost 的中介适配器具有以下功能:
集成 | |
---|---|
出价 | |
瀑布 | |
表现形式 | |
横幅 | |
插页式广告 | |
激励广告 | |
原生 |
要求
- iOS 部署目标为 12.0 或更高版本
最新版 Google 移动广告 SDK
完成中介入门指南
第 1 步:在 Chartboost 界面中设置配置
注册 Chartboost 账号,并在账号通过验证后登录。然后,前往应用管理标签页。
点击添加新应用按钮以创建应用。
填写表单的其余部分,然后点击添加应用按钮以最终确定应用。
创建应用后,您将进入其信息中心。记下应用的应用 ID 和应用签名。
Ad Manager 要求您提供 Chartboost 用户 ID 和 用户签名,才能设置 Ad Manager 广告单元 ID。您可以在 Chartboost 界面中点击 Chartboost 中介,找到这些参数。
前往 Resources > API Explorer 标签页,记下 Authentication 部分下的 User ID 和 User Signature。
开启测试模式
如需为应用启用测试模式,请前往 Chartboost 界面的应用管理标签页,从列表中选择您的应用,然后点击修改应用设置。
您可以在应用的设置中为应用切换测试模式。
启用测试模式后,您可以使用之前创建的广告单元 ID 请求广告,并接收 Chartboost 测试广告。
在您能够接收 Chartboost 测试广告后,您的应用将被列入 Chartboost 的发布商应用审核名单。若要在 Chartboost 上创收,发布商应用审核需要获得 Chartboost 批准。
第 2 步:在 Ad Manager 界面中设置 Chartboost 需求来源
为广告单元配置中介设置
登录您的 Ad Manager 账号。
依次前往投放 > 收益组,然后点击新建收益组按钮。
为收益组输入唯一的名称,将状态设为有效,选择广告格式,并将广告资源类型设为移动应用。在定位 > 广告资源部分下,选择您要添加中介的广告资源和移动应用下的广告单元。
接下来,点击添加收益合作伙伴按钮。
如果您已经有 Chartboost 的收益合作伙伴,可以选择该合作伙伴。否则,请选择创建新的收益合作伙伴。
选择 Chartboost 作为广告联盟,输入唯一的名称,然后启用中介。
开启自动收集数据,然后输入您在上一部分中获取的用户 ID 和用户签名。
选择收益合作伙伴后,选择移动 SDK 中介作为集成类型,选择 iOS 作为平台,并选择有效作为状态。输入您在上一部分中获取的应用 ID、应用签名和广告位置。然后,输入默认每千次展示定价值。
Chartboost 广告展示位置(命名展示位置)是指表示您要在应用中展示广告的位置的简单名称。Ad Manager 会向设置中指定的位置发送请求。发送请求后,Chartboost 会将相应位置添加到其界面中,以便生成报告。
在 Chartboost 界面中,点击高级设置,即可在基本设置页面中显示您的广告展示位置。如需了解详情,请参阅 Chartboost 命名地理位置指南。
完成后,点击页面底部的保存。
将 Chartboost 添加到 GDPR 和美国州级法规广告合作伙伴名单
请按照 GDPR 设置和 美国州级法规设置中的步骤,将 Chartboost 添加到 Ad Manager 界面中的 GDPR 和美国州级法规广告合作伙伴名单中。
第 3 步:导入 Chartboost SDK 和适配器
使用 CocoaPods(推荐)
将以下代码行添加到项目的 Podfile 中:
pod 'GoogleMobileAdsMediationChartboost'
在命令行中运行以下命令:
pod install --repo-update
手动集成
下载最新版本的 Chartboost SDK,并在项目中关联 Chartboost.framework 和 CHAMoatMobileAppKit.framework。
从更新日志中的下载链接下载最新版本的 Chartboost 适配器,并在项目中关联 ChartboostAdapter.framework。
将以下框架添加到您的项目中:
StoreKit
Foundation
CoreGraphics
WebKit
AVFoundation
UIKit
第 4 步:在 Chartboost SDK 中实现隐私设置
欧盟地区用户意见征求和《一般数据保护条例》(GDPR)
根据 Google 《欧盟地区用户意见征求政策》,您必须确保向位于欧洲经济区 (EEA) 的用户披露相关信息并征得他们的同意,以便使用设备标识符和个人数据。此政策反映了欧盟《电子隐私指令》和《一般数据保护条例》(GDPR) 的要求。在征求用户意见时,您必须指明中介链中可能会收集、接收或使用个人数据的每个广告联盟,并提供有关每个广告联盟使用情况的信息。Google 目前无法自动将用户的意见征求选择传递给此类广告联盟。
在 SDK 版本 8.2.0 中,Chartboost 添加了 addDataUseConsent
方法。以下示例代码将数据使用意见征求设置为 CHBGDPRConsentNonBehavioral
。如果您选择调用此方法,建议您先调用此方法,然后再通过 Google 移动广告 SDK 请求广告。
Swift
let dataUseConsent = CHBDataUseConsent.GDPR(CHBDataUseConsent.GDPR.Consent.nonBehavioral)
Chartboost.addDataUseConsent(dataUseConsent)
Objective-C
CHBGDPRDataUseConsent *dataUseConsent = [CHBGDPRDataUseConsent gdprConsent:CHBGDPRConsentNonBehavioral];
[Chartboost addDataUseConsent:dataUseConsent];
如需了解详情以及每种方法中可以提供的值,请参阅 Chartboost 的 GDPR 文章和 iOS 隐私权方法。
美国州级隐私保护法律
根据美国各州隐私权法的规定,用户有权选择拒绝出售其“个人信息”(该法律对这些术语进行了定义)。“出售”方须在首页醒目位置提供“不出售我的个人信息”链接,以供这些用户选择。美国州级隐私保护法律合规指南提供了为 Google 广告投放启用受限的数据处理的功能,但 Google 无法将此设置应用于中介链中的每个广告网络。因此,您必须识别中介链中可能参与销售个人信息的每个广告网络,并遵循每个广告网络的指南,以确保合规。
在 SDK 版本 8.2.0 中,Chartboost 添加了 addDataUseConsent
方法。以下示例代码将数据使用意见征求设置为 CHBCCPAConsentOptInSale
。如果您选择调用此方法,建议您先调用此方法,然后再通过 Google 移动广告 SDK 请求广告。
Swift
let dataUseConsent = CHBDataUseConsent.CCPA(CHBDataUseConsent.CCPA.Consent.optInSale)
Chartboost.addDataUseConsent(dataUseConsent)
Objective-C
CHBCCPADataUseConsent *dataUseConsent = [CHBCCPADataUseConsent ccpaConsent:CHBCCPAConsentOptInSale];
[Chartboost addDataUseConsent:dataUseConsent];
如需了解详情以及每种方法中可以提供的值,请参阅 Chartboost 的 CCPA 文章和 iOS 隐私权方法。
错误代码
如果适配器未能从 Chartboost 收到广告,您可以使用以下类下的 GADResponseInfo.adNetworkInfoArray
检查广告响应中的底层错误:
GADMAdapterChartboost
GADMediationAdapterChartboost
以下是 Chartboost 适配器在广告加载失败时抛出的代码和随附消息:
错误代码 | 原因 |
---|---|
101 | 在 Ad Manager 界面中配置的 Chartboost 服务器参数缺失/无效。 |
102 | Chartboost SDK 返回了初始化错误。 |
103 | Chartboost 广告不会在展示时缓存。 |
104 | 请求的广告尺寸与 Chartboost 支持的横幅广告尺寸不符。 |
105 | 设备的操作系统版本低于 Chartboost SDK 支持的最低操作系统版本。 |
200-299 | Chartboost SDK 缓存错误。如需了解详情,请参阅代码。 |
300-399 | Chartboost SDK 显示错误。如需了解详情,请参阅代码。 |
400-499 | Chartboost SDK 点击错误。如需了解详情,请参阅代码。 |
Chartboost iOS 中介适配器更新日志
版本 9.8.0.0
- 已经验证与 Chartboost SDK 版本 9.8.0 兼容。
构建和测试所需版本:
- Google 移动广告 SDK 11.11.0 版。
- Chartboost SDK 版本 9.8.0。
版本 9.7.0.1
- 更新了
CFBundleShortVersionString
,使其包含三个组件,而不是四个。
构建和测试所需版本:
- Google 移动广告 SDK 版本 11.10.0。
- Chartboost SDK 版本 9.7.0。
版本 9.7.0.0
- 已验证与 Chartboost SDK 版本 9.7.0 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 11.2.0 版。
- Chartboost SDK 版本 9.7.0。
版本 9.6.0.1
- 现在,最低 iOS 版本要求为 12.0。
- 现在需要 Google 移动广告 SDK 11.0 或更高版本。
- 在
ChartboostAdapter.xcframework
中的框架中添加了Info.plist
。
构建和测试所需版本:
- Google 移动广告 SDK 版本 11.0.1。
- Chartboost SDK 版本 9.6.0。
版本 9.6.0.0
- 已经验证与 Chartboost SDK 版本 9.6.0 兼容。
- 将已废弃的
GADMobileAds.sharedInstance.sdkVersion
方法替换为GADMobileAds.sharedInstance.versionNumber
。 - 添加了
GADMediationInterstitialAd
实现。
构建和测试所需版本:
- Google 移动广告 SDK 10.14.0 版。
- Chartboost SDK 版本 9.6.0。
版本 9.5.1.0
- 已经验证与 Chartboost SDK 版本 9.5.1 兼容。
构建和测试所需版本:
- Google 移动广告 SDK 10.12.0 版。
- Chartboost SDK 版本 9.5.1。
版本 9.4.0.0
- 已验证与 Chartboost SDK 版本 9.4.0 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 10.7.0 版。
- Chartboost SDK 版本 9.4.0。
版本 9.3.1.0
- 已经验证与 Chartboost SDK 版本 9.3.1 兼容。
构建和测试所需版本:
- Google 移动广告 SDK 10.7.0 版。
- Chartboost SDK 版本 9.3.1。
版本 9.3.0.0
- 已验证与 Chartboost SDK 版本 9.3.0 的兼容性。
- 现在,最低 iOS 版本要求为 11.0。
- 现在需要 Google 移动广告 SDK 10.4.0 或更高版本。
构建和测试所需版本:
- Google 移动广告 SDK 10.4.0 版。
- Chartboost SDK 版本 9.3.0。
版本 9.2.0.0
- 移除了
ChartboostAdapter
头文件中的GADMChartboostExtras
导入。 - 已经验证与 Chartboost SDK 版本 9.2.0 兼容。
- 现在需要 Google 移动广告 SDK 10.0.0 或更高版本。
- 移除了对
armv7
架构的支持。 - 现在,最低 iOS 版本要求为 11.0。
构建和测试所需版本:
- Google 移动广告 SDK 10.0.0 版。
- Chartboost SDK 版本 9.2.0。
版本 9.1.0.0
- 已验证与 Chartboost SDK 版本 9.1.0 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 9.11.0 版。
- Chartboost SDK 版本 9.1.0。
版本 9.0.0.0
- 已验证与 Chartboost SDK 版本 9.0.0 的兼容性。
- 已经验证与 Google 移动广告 SDK 9.10.0 版兼容。
- 更新了适配器以使用
didRewardUser
API。 - 现在需要 Google 移动广告 SDK 9.8.0 或更高版本。
构建和测试所需版本:
- Google 移动广告 SDK 9.10.0 版。
- Chartboost SDK 版本 9.0.0。
版本 8.5.0.2
- 已经验证与 Google 移动广告 SDK 9.0.0 版本兼容。
- 现在需要 Google 移动广告 SDK 9.0.0 或更高版本。
构建和测试所需版本:
- Google 移动广告 SDK 9.0.0 版。
- Chartboost SDK 版本 8.5.0。
版本 8.5.0.1.0
- 已验证与 Chartboost SDK 8.5.0 的兼容性,该版本在 CocoaPods 中对应于版本 8.5.0.1。
构建和测试所需版本
- Google 移动广告 SDK 8.13.0 版。
- Chartboost SDK 版本 8.5.0。
版本 8.5.0.0
- 已验证与 Chartboost SDK 8.5.0 的兼容性。
构建和测试所需版本
- Google 移动广告 SDK 8.12.0 版。
- Chartboost SDK 版本 8.5.0。
版本 8.4.2.0
- 已验证与 Chartboost SDK 8.4.2 的兼容性。
构建和测试所需版本
- Google 移动广告 SDK 8.6.0 版。
- Chartboost SDK 版本 8.4.2。
版本 8.4.1.1
- 放宽了对 Google 移动广告 SDK 8.0.0 或更高版本的依赖。
构建和测试所需版本
- Google 移动广告 SDK 8.4.0 版。
- Chartboost SDK 版本 8.4.1。
版本 8.4.1.0
- 已验证与 Chartboost SDK 8.4.1 的兼容性。
- 现在需要 Google 移动广告 SDK 8.1.0 或更高版本。
构建和测试所需版本
- Google 移动广告 SDK 8.1.0 版。
- Chartboost SDK 版本 8.4.1。
版本 8.4.0.1
- 添加了标准化的适配器错误代码和消息。
- 更新了适配器以使用
.xcframework
格式。 - 现在需要 Google 移动广告 SDK 8.0.0 或更高版本。
构建和测试所需版本
- Google 移动广告 SDK 8.0.0 版。
- Chartboost SDK 版本 8.4.0。
版本 8.4.0.0
- 已验证与 Chartboost SDK 8.4.0 的兼容性。
- 现在需要 Google 移动广告 SDK 7.68.0 或更高版本。
构建和测试所需版本
- Google 移动广告 SDK 7.68.0 版。
- Chartboost SDK 版本 8.4.0。
版本 8.3.1.0
- 已验证与 Chartboost SDK 8.3.1 的兼容性。
- 现在需要 Google 移动广告 SDK 7.66.0 或更高版本。
- 现在,最低 iOS 版本要求为 10.0。
- 更新了适配器,以支持自适应横幅广告请求。
构建和测试所需版本
- Google 移动广告 SDK 7.66.0 版。
- Chartboost SDK 版本 8.3.1。
版本 8.2.1.0
- 已验证与 Chartboost SDK 8.2.1 的兼容性。
- 现在需要 Google 移动广告 SDK 7.64.0 或更高版本。
- 现在,最低 iOS 版本要求为 9.0。
构建和测试所需版本
- Google 移动广告 SDK 7.64.0 版。
- Chartboost SDK 版本 8.2.1。
版本 8.2.0.0
- 已验证与 Chartboost SDK 8.2.0 的兼容性。
- 现在需要 Google 移动广告 SDK 7.61.0 或更高版本。
构建和测试所需版本
- Google 移动广告 SDK 7.61.0 版。
- Chartboost SDK 版本 8.2.0。
版本 8.1.0.1
- 将最低要求的 Google 移动广告 SDK 版本更新为 7.60.0。
- 更新了适配器以使用 Chartboost 的新 API,并移除了已废弃的 API。
- 适配器现在支持使用相同的 Chartboost 位置加载多种格式的广告。
- 如果未在 AdMob 或 Ad Manager 界面中替换奖励,激励广告的奖励值现在是 Chartboost 界面中指定的值,而不是
0
。
构建和测试所需版本
- Google 移动广告 SDK 7.60.0 版。
- Chartboost SDK 版本 8.1.0。
版本 8.1.0.0
- 已经验证与 Chartboost SDK 8.1.0 兼容。
- 将最低要求的 Google 移动广告 SDK 版本更新为 7.59.0。
- 移除了对 i386 架构的支持。
构建和测试所需版本
- Google 移动广告 SDK 7.59.0 版。
- Chartboost SDK 版本 8.1.0。
版本 8.0.4.0
- 已验证与 Chartboost SDK 8.0.4 的兼容性。
构建和测试所需版本
- Google 移动广告 SDK 7.52.0 版。
- Chartboost SDK 版本 8.0.4。
版本 8.0.1.1
- 修复了请求横幅广告时未返回任何广告资源的问题。
版本 8.0.1.0
- 已验证与 Chartboost SDK 8.0.1 的兼容性。
- 添加了对请求横幅广告的支持。
版本 7.5.0.1
- 添加了代码以正确初始化 Chartboost SDK。
版本 7.5.0.0
- 已验证与 Chartboost SDK 7.5.0 的兼容性。
- 更新了适配器以使用新的激励广告 API。
- 更新了适配器以处理多个插页式广告请求。
- 现在需要 Google 移动广告 SDK 7.42.2 或更高版本。
版本 7.3.0.0
- 已验证与 Chartboost SDK 7.3.0 的兼容性。
版本 7.2.0.1
- 向适配器添加了
adapterDidCompletePlayingRewardBasedVideoAd:
回调。
版本 7.2.0.0
- 已经验证与 Chartboost SDK 7.2.0 兼容。
版本 7.1.2.0
- 已验证与 Chartboost SDK 7.1.2 的兼容性。
版本 7.1.1.0
- 已验证与 Chartboost SDK 7.1.1 的兼容性。
版本 7.1.0.0
- 已验证与 Chartboost SDK 7.1.0 的兼容性。
版本 7.0.4.0
- 已验证与 Chartboost SDK 7.0.4 的兼容性。
版本 7.0.3.0
- 已验证与 Chartboost SDK 7.0.3 的兼容性。
版本 7.0.2.0
- 已验证与 Chartboost SDK 7.0.2 的兼容性。
- 新增了对两个新的 Chartboost 错误代码的支持。
版本 7.0.1.0
- 已验证与 Chartboost SDK 7.0.1 的兼容性。
版本 7.0.0.0
- 已验证与 Chartboost SDK 7.0.0 的兼容性。
版本 6.6.3.0
- 已经验证与 Chartboost SDK 6.6.3 兼容。
- 移除了对“armv7s”架构的支持。
- 修复了以下 bug:发布商在将
ChartboostAdapter.framework
作为导入非模块化 Chartboost SDK 的模块导入时,在 Swift 中遇到编译问题。
版本 6.6.2.0
- 已经验证与 Chartboost SDK 6.6.2 兼容。
版本 6.6.1.0
- 已经验证与 Chartboost SDK 6.6.1 兼容。
版本 6.6.0.0
- 已经验证与 Chartboost SDK 6.6.0 兼容。
版本 6.5.2.1
- 启用了位码支持。
- 现在,Chartboost 适配器以框架的形式分发。
- 如需在项目中导入
ChartboostAdapter.framework
,请务必在目标的“Build Settings”(构建设置)下将Allow Non-modular Includes in Framework Modules
设置为YES
。
版本 6.5.2.0
- 将版本命名系统更改为 [Chartboost SDK 版本].[适配器补丁版本]。
- 将所需的最低 Chartboost SDK 版本更新为 v6.5.1。
- 将最低要求的 Google 移动广告 SDK 版本更新为 v7.10.1。
- 修复了导致 Chartboost 广告无法支持多个展示位置的 bug。
- 现在,当插页式广告即将关闭时,应用会收到
interstitialWillDismissScreen:
回调。 - 现在,当用户打开基于激励的视频广告时,应用会收到
rewardBasedVideoAdDidOpen:
回调。
版本 1.1.0
- 从 Chartboost 附加信息中移除了 Chartboost 广告位置。现在,在 AdMob 控制台中配置 Chartboost 中介时,需要指定广告位置。
版本 1.0.0
- 初始版本。支持激励视频广告和插页式广告。