文档更新记录

    2021.1.28
1. 文档
    Facebook 小游戏 SDK https://developers.facebook.com/docs/games/instant-games/sdk 目前的最新版本 6.3 https://developers.facebook.com/docs/games/instant-games/sdk/fbinstant6.3 广告变现指南 https://developers.facebook.com/docs/games/instant-games/guides/ads-monetization
2. 重要提示

重要提示1

Facebook官方开发文档中的代码有坑,仅作为功能参考和测试,不要直接用在实际项目中。

重要提示2

Facebook官方开发文档中的代码有坑,仅作为功能参考和测试,不要直接用在实际项目中。

重要提示3

Facebook官方开发文档中的代码有坑,仅作为功能参考和测试,不要直接用在实际项目中。

3. Facebook 广告实例(AdInstance)

Facebook 广告分为

    插屏广告 InterstitialAd 激励视频广告 RewardedVideo

在使用Facebook的广告之前,需要先获取广告实例(AdInstance)。不同广告类型获取广告实例的接口不同。

    插屏广告 getInterstitialAdAsync 激励视频 getRewardedVideoAsync

加载和播放广告的接口是一样的,都是对AdInstance的操作。

    加载 loadAsync 播放 showAsync

3.1. Facebook 广告的业务流程

Facebook广告的典型业务流程分为以下几个步骤

    1). 初始 2). 获取广告实例 3). 加载广告 4). 播放广告 5). 结束

3.2. 广告实例AdInstance 的生命状态

一个广告实例的生命状态可以分为:

    1). 无效(初始为null或者undefined) 2). 有效未加载 3). 有效加载中 4). 有效已加载 5). 有效播放中

特别提示

    1). 注意处理**“有效加载中”**的状态,广告预加载的过程会比较慢,容易出现这种中间状态,这时候既不要重新获取实例(可能出现实例过多),也不要再次加载(可能会提示加载中,或者频繁请求)。 2). 注意处理**“有效播放中”**,在播放过程中的广告,不要进行其他操作。 3). 已经播放过的广告实例,无论结果如何,都应舍弃,重新获取新的实例。
4. 常见错误

4.0. 网络与VPN问题

如果VPN 太慢,容易出现各种奇怪的问题,例如相同的游戏,有的人可以播放广告,有的人不能播放。 所以,出现这类问题请先尝试使用一个稳定的VPN。 特别是免费VPN,由于使用的人太多,容易出问题。

4.1. 广告类型错误

Facebook 广告分为插屏广告(InterstitialAd) 和 激励视频广告(RewardedVideo),每种广告都有一组相应的API,如果广告ID与广告接口不匹配,会提示相应错误。

接口参考

    FBInstant.getInterstitialAdAsync FBInstant.getRewardedVideoAsync

4.2. 获取广告实例时,错误 CLIENT_UNSUPPORTED_OPERATION

    解释 客户端不支持这个操作 原因 有的电脑浏览器不支持广告功能。 解决方法 1). 提前检查是否支持该操作(FBInstant.getSupportedAPIs())。 2). 忽略该错误。

4.3. 获取广告实例时,错误 ADS_TOO_MANY_INSTANCES

    解释 太多的广告实例。 原因 每种类型的广告(插页institential或者激励视频rewarded video)各只能保存3个广告实例AdInstance。 解决方法 1). 对于已经成功获取的广告实例AdInstance 预加载失败以后,可以继续重新加载,不需要重新获取。 2). 如果加载成功,未进行播放的话,不要直接丢弃。 3). 注意处理“有效未加载”的状态,广告预加载的过程会比较慢,容易出现这种状态,这时候不要立即重新获取新实例。

4.4. 加载插屏广告时,错误 ADS_NO_FILL,详情 Instant Game does not pass Minimum Performance Standards


"code":"ADS_NO_FILL",

"message":"Instant Game does not pass Minimum Performance Standards."

    解释 该游戏未通过Facebook月活考核标准。 原因 只有通过Facebook的月活考核标准的游戏,才能正常使用插屏广告。 解决方法 1). 对于新游戏或者未达标游戏,这个错误是正常的,一般可以忽略。 2). 如果已经达标,需要跟Facebook申诉。 月活考核标准

目前的月活考核标准(MAP)是,游戏在

    1). 过去28天中 2). 至少3000名玩家 3). 游戏时长超过30分钟。

4.5. 加载广告时,错误 ADS_NO_FILL,详情 No fill

    解释 广告未填充,无法从Facebook获取广告。 原因 1). 广告版位没有审核通过,此时需要添加测试设备id才可以进行测试,建议先审核广告。 2). 广告版位审核通过,但是游戏未上线,填充率会比较低,如果没有其他错误,这是正常情况。 3). 广告版位审核通过,而且已经上线,则需要到后台查看填充率的原因,检查因为违反了Facebook的广告政策被限制。 4). 客户端网络问题,可能被限制广告获取。 解决方法 1). 在广告后台检查广告是否已经审核通过,或者添加测试设备id。 2). 检查客户端VPN,尽量不要用免费VPN,或者蓝灯之类服务器经常更换的VPN 3). 广告版位审核通过,而且已经上线,如果后台查看整体的填充率比较低,可查看填充率详情,检查是否因为违反了Facebook的广告政策被限制。 4). 特别的,对于未上线游戏,如果其他设备能正常使用广告功能,可以暂时忽略该错误,等上线后再观察。

4.6. 加载广告时,错误 ADS_FREQUENT_LOAD

    解释 广告加载太频繁 原因 预加载的频率太高 解决方法 不要过于频繁加载广告。

注意 是否正确处理了广告实例**“有效加载中”**的状态。(参考3.2. 广告实例状态)

4.7. 播放广告时,错误 Invalid Ad Instance

5. 其他事项

5.1. 一些开发与调试建议

    1). 尽量使用TypeScript, 如果可以,优先用TypeScript的await/async语法,用try/catch来捕获错误。 其次选择promise的then/catch。 2). 尽量多打日志,监控广告的生命周期 3). 如果开发人员的电脑始终无法加载或者播放广告,可以找运营人员配合调试,请提供带调试控制台的版本(vConsole) 1). cocos游戏可以直接输出带vConsole的测试版本 2). 其他引擎可以参考 https://github.com/Tencent/vConsole/blob/dev/doc/tutorial_CN.md

5.2. 激励视频广告需要二次确认

Facebook广告要求为激励视频广告添加二次确认,请在播放广告之前,设置对话框确认。

5.3. 使用稳定的VPN网络

最后

祝大家都赚钱~

有小游戏要发行到海外,赚美元,欢迎关注公众号,联系我。