Cocos Service:HUAWEI HMS Core 插件开发指南
推荐:将NSDT场景编辑器加入你的3D工具链
3D工具集:NSDT简石数字孪生
开发指南
开发时请先参考 Cocos SDKHub - 开发指南,本章节作为 HMS Core SDK 插件特性的补充说明部分。
华为 HMS Core SDK 提供的方法较多,部分接口需要使用扩展方法调用,并返回扩展回调。需要配合参考 Cocos SDKHub Sample 工程中的代码与华为官方对应的文档进行调用。
Cocos SDKHub 的 Log 关键字为 HUB_LOG
,仅在 构建发布 面板中的 调试模式 选项 打开 的情况下才会输出。可参考 Cocos SDKHub - 调试信息输出。
接入 HMS Core SDK 后,在统一回调中需要判断返回的 msg 格式是否为 JSON 对象,JSON 对象中是否有 retCode 信息。该值为华为返回的错误码,可以通过该值到华为文档中查询错误信息。
账号与游戏插件
开发时请先参考 Cocos SDKHub - 账号与游戏插件,本章节作为 HMS Core SDK 插件特性的补充说明部分。
当前用户是否登录等情况,需要游戏端进行判断,避免在用户未登录下,调用账号和游戏服务其他接口导致崩溃。
登录
华为的登录回调中,可读取 userID 参数作为用户唯一 ID。此时也可以根据获取的登录签名信息,调用 校验登录签名接口 对玩家信息进行服务端验签。
浮标
SDKHub 提供的 HMS Core SDK 插件,已在生命周期内调用 SDK 的浮标接口,无需 开发者手动调用 showToolBar
和 hideToolBar
浮标方法。
成就
成就功能,可参考 游戏服务 - 成就 文档。
展示成就
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
type | "getShowAchievementListIntent" "getAchievementList" | 直接跳转或执行展示成就列表 |
forceReload | "1" | "getAchievementList" 情况可选参数: "0":不联网,表示从本地缓存获取 "1":联网,表示直接从游戏服务器获取。 默认为 "1" |
示例:
var params = {
"type": "getAchievementList",
"forceReload": "0"
};
sdkhub.getUserPlugin().showAchievements(params);
解锁成就
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
type | "visualizeWithResult" "growWithResult" "makeStepsWithResult" "reachWithResult" | 对应文档各子方法 |
achievementId | "5D9580837D32CB59Cxxx" | 后台配置后生成的成就 ID |
stepsNum | "50" | 当前成就的步长,growWithResult 和 makeStepsWithResult 情况需要该参数 |
示例:
var params = {
"type": "growWithResult",
"achievementId": "5D9580837D32CB59CFEC89DAD39470CDF9B672033A2D6F14689BC01335818444",
"stepsNum": "50"
};
sdkhub.getUserPlugin().unlockAchievement(params);
排行榜
排行榜功能,可参考 游戏服务 - 排行榜 文档。
显示排行榜
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
type | "getRankingsIntent" "getRankingSummary" "getCurrentPlayerRankingScore" "getPlayerCenteredRankingScores" "getMoreRankingScores" "getRankingTopScores" | 对应文档各子方法:直接展示应用助手的排行榜和自行展示排行榜列表等。 |
rankingId | "5D9580837D32CB59Cxxx" | 可选,如果需要获取所有排行榜就不要传该参数。 |
timeDimension | "1" | 可选,"getRankingsIntent" "getCurrentPlayerRankingScore" "getRankingTopScores" 情况下的指定时间维度。 "0":日,表示获取当天的排行榜数据。 "1":周,表示获取本周的排行榜数据。 "2":全部时间。需要与 rankingId 同时传入。 |
isRealTime | "1" | 可选,"getRankingSummary"、"getRankingTopScores"、getPlayerCenteredRankingScores 情况下指定获取方式。 "0":不联网,表示从本地缓存获取。 "1":联网,表示直接从游戏服务器获取。默认为 "1"。 |
maxResults | "15" | "getMoreRankingScores"、"getPlayerCenteredRankingScores"、"getRankingTopScores" 必传参数每页的最大数量,支持取值为 1 ~ 21 的整数。 |
offsetPlayerRank | "1" | "getMoreRankingScores" 必传,"getPlayerCenteredRankingScores" 与 "getRankingTopScores" 可选,从 offsetPlayerRank 指定的位置,根据 pageDirection 指定的数据获取方向获取一页数据,offsetPlayerRank 取值必须为大于等于 0 的整数。 例如 offsetPlayerRank 取值为 5,pageDirection 取值为 0,表示从排行榜的第 5 位分数向下获取一页数据。 |
pageDirection | "0" | "getRankingTopScores"、"getPlayerCenteredRankingScores" 可选,数据获取方向。 "0":下一页 "1":上一页,默认为 "0" |
示例:
var params = {
"type": "getRankingTopScores",
"rankingId": "2008EE56BB773FA325FFB1349D0D206A8B0EC3E9E2F0D32E786E574ADD10E7A1",
"offsetPlayerRank": "1",
"maxResults": "15",
"pageDirection": "0",
"timeDimension": "2"
};
sdkhub.getUserPlugin().showLeaderBoard(params);
提交分数
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
type | "getRankingSwitchStatus" "setRankingSwitchStatus" "submitRankingScore" | 对应文档各子方法。 |
stateValue | "1" | setRankingSwitchStatus 需要传入,排行榜开关状态,默认为 0,需设置为 1 才可提交分数。 |
rankingId | "5D9580837D32CB59Cxxx" | submitRankingScore 情况需要传入,后台配置后生成的排行榜 ID |
score | "10000" | submitRankingScore 情况需要传入,要提交到排行榜的分数,Java 侧为 long 型。 |
scoreTips | "金币" | submitRankingScore 情况可选,有自定义单位情况下需要传入。 |
以下方法需要通过 扩展方法调用。
初始化
可参考 游戏启动 - 开发步骤 的 JosAppsClient.init
方法,需要用户在游戏登录前调用,用于展示公告业务。
方法名:init
参数说明:无需参数。
示例:
sdkhub.getUserPlugin().callFuncWithParam("init");
应用升级
可参考 应用升级 文档,中国大陆的联运游戏需要在应用启动完成后接入。
方法名:checkAppUpdate
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
showUpdateDialog | "0" | 可选,是否调用 HMS 提供的 应用升级提示框,默认为 "1" |
forceUpdate | "1" | 可选,默认为 "0"。若 showUpdateDialog 为 "1",则强制更新按钮选择。 |
示例:
sdkhub.getUserPlugin().callFuncWithParam("checkAppUpdate");
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 132 | JSON | 获取升级信息成功,返回信息可对应 intent 说明。 |
+ 133 | String | 获取升级信息失败,或者无需处理升级信息情况 |
账号服务登录
注意:游戏请调用 Login 方法,无需接入该方法。
该方法用于第三方应用获取华为帐号用户身份认证信息(ID Token)或用户的临时授权票据(Authorization Code),以便用户可以使用华为帐号安全登录第三方应用。详情可参考 登录华为帐号 和 静默登录 文档。
通过 sdkhub.UserResultCode.kLoginSucceed
登录回调获取 ID Token 或 Authorization Code 后,请参考 登录华为帐号 文档中对应登录方式的服务端验证部分,完成服务端接入。
方法名:accountLogin
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
type | "AuthorizationCode" "IDToken" "Slient" | 对应各账号服务登录方式。 |
示例:
var params = "AuthorizationCode";
sdkhub.getUserPlugin().callFuncWithParam("accountLogin", params);
登录后获取用户信息
可参考 getCurrentPlayer 文档,由于登录流程中也会调用该方法,并且走登录方法回调,该方法可选。
方法名:getCurrentPlayer
参数说明:无需参数。
示例:
sdkhub.getUserPlugin().callFuncWithParam("getCurrentPlayer");
帐号取消授权
可参考 帐号取消授权 文档,为了提升应用隐私安全,应用可以提供入口,供用户取消对应用的授权。
方法名:cancelAuthorization
参数说明:无需参数。
示例:
sdkhub.getUserPlugin().callFuncWithParam("cancelAuthorization");
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 122 | String | 取消登录授权成功描述 |
+ 123 | String | 取消登录授权失败描述 |
实名认证与游戏试玩模式
可参考 游戏服务 - 实名认证。
本插件接入了相关方法,开发者仅需要处理相关回调。
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 130 | String | 试玩时间结束回调 |
+ 131 | Boolean | 实名认证结果。若为 true ,可以继续后续的游戏登录处理。若为 false ,建议提示玩家后退出游戏或引导玩家重新登录并实名认证 |
防沉迷监控
防沉迷监控功能,可参考 游戏服务 - 防沉迷 文档,中国大陆发布的游戏需要开发者按照上述通知结合游戏自身完成游戏防沉迷功能的开发。
- 当玩家登录游戏或从后台切到游戏前台时,调用
submitPlayerEventStart
。游戏定期调用getPlayerExtraInfo
方法查询玩家附加信息。服务器允许的最高频率为 10 分钟查询一次,一般建议 15 分钟查询一次。当玩家退出游戏、从前台切到后台或游戏异常退出(进程终止、手机重启等)时,会调用submitPlayerEventEnd
上报玩家退出游戏事件。 - 在接入防沉迷方案前,您需要联系华为运营开通强制实名认证功能。
注意:submitPlayerEventStart
和 getPlayerExtraInfo
如果回调中 retCode
返回 7002 或 7006 错误码,需进行如下处理:
- 7002:需判断是否为网络问题,如果不是网络问题则表示该帐号未在中国大陆注册,请直接放通,无需进行强制处理。
- 7006:表示该帐号未在中国大陆注册,请直接放通,无需进行强制处理。
方法名:
- `submitPlayerEventStart` 上报玩家进入游戏事件
- `submitPlayerEventEnd`上报玩家退出游戏事件
- `getPlayerExtraInfo` 查询玩家附加信息
参数说明:无需参数。
示例:
sdkhub.getUserPlugin().callFuncWithParam("submitPlayerEventStart");
sdkhub.getUserPlugin().callFuncWithParam("submitPlayerEventEnd");
sdkhub.getUserPlugin().callFuncWithParam("getPlayerExtraInfo");
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 106 | JSON | submitPlayerEventStart 上报玩家进入游戏事件成功,可获取参数 transactionId |
+ 107 | JSON / String | 上报玩家进入游戏事件失败 |
+ 108 | JSON | 上报玩家退出游戏事件成功,可获取参数 traceId |
+ 109 | JSON / String | 上报玩家退出游戏事件失败 |
+ 110 | JSON | 查询玩家附加信息成功,可获取参数 isRealName、isAdult、playerId、playerDuration |
+ 111 | JSON / String | 查询玩家附加信息失败 |
事件上报
事件上报功能,可参考 游戏服务 - 事件上报 文档。事件上报为开发者提供了收集玩家在游戏过程中产生的特定数据,上报并存储至华为游戏服务器,随后在 AppGallery Connect 上进行归纳分析的能力。
上报事件方法
方法名:submitEvent
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
eventId | "5D9580837D32CB59Cxxx" | 当前事件的 ID,在配置事件时生成,后台获取。 |
growAmount | "20" | 在已有事件数值的基础上要增量增加的数值。 |
示例:
var params = {
"eventId": "A29DB82609936BE9DBB44CF7AFBBAECD5D2B7F14A05FB2B37EF543E7622F7B7F",
"growAmount": "20"
};
sdkhub.getUserPlugin().callFuncWithParam("submitEvent", params);
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 112 | String | 调用事件上报回调,无成功或失败情况返回 |
获取玩家事件的数据
方法名:getEvent
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
forceReload | "1" | 可选,默认为 "1"。 "0":不联网,表示从本地缓存获取。 "1":联网,表示直接从游戏服务器获取。 |
eventIds | "eventId1, eventId2" | 可选,传入事件 ID,获取特定事件数据,通过逗号分隔。不传则返回所有事件数据。 |
示例:
var params = {
"eventId": "A29DB82609936BE9DBB44CF7AFBBAECD5D2B7F14A05FB2B37EF543E7622F7B7F,2008EE56BB773FA325FFB1349D0D206A8B0EC3E9E2F0D32E786E574ADD10E7A1",
"foreReload": "0"
};
sdkhub.getUserPlugin().callFuncWithParam("getEvent", params);
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 114 | JSON | 获取事件数据成功,可获取参数 eventId。 |
+ 115 | JSON / String | 获取事件数据失败描述 |
玩家信息统计
玩家信息统计方法,可参考 游戏服务 - 玩家信息统计 文档。玩家信息统计是指开发者可以从华为游戏服务器获取当前玩家在游戏中的多种统计信息,帮助开发者更深度了解玩家的游戏习惯,以便根据玩家的游戏进度、支付能力等构建更适合该玩家的游戏体验。
方法名:getGamePlayerStats
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
isRealTime | 0 | Number 型 1:是,表示从游戏服务器获取数据。 0:否,表示从本地缓存获取数据。本地缓存时间为 5 分钟,如果本地无缓存或缓存超时,则从游戏服务器获取。 |
示例:
var params = 0;
sdkhub.getUserPlugin().callFuncWithParam("getGamePlayerStats", params);
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 116 | JSON | 获取事件数据成功,可获取参数 averageOnLineMinutes、daysFromLastGame、paymentTimes、onlineTimes、totalPurchasesAmountRange |
+ 117 | JSON / String | 获取事件数据失败描述 |
游戏基本信息
获取游戏基本信息方法,可参考 游戏服务 - 游戏基本信息 文档。游戏基本信息是指游戏应用的相关信息,例如游戏的应用ID、游戏名称、游戏描述、游戏分类等。当开发者需要在游戏中使用游戏应用的信息时,可以从华为游戏服务器获取游戏基本信息。
方法名:getGameSummary
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
isLocal | 0 | Number 型 1:是,表示从游戏服务器获取数据。 0:否,表示从本地缓存获取数据。 |
示例:
var params = 0;
sdkhub.getUserPlugin().callFuncWithParam("getGameSummary", params);
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 118 | JSON | 获取事件数据成功,可获取参数 achievementCount, appId, descInfo, gameName, gameHdImgUri, gameIconUri, rankingCount, firstKind, secondKind |
+ 119 | JSON / String | 获取事件数据失败描述 |
取消游戏服务授权
可参考 cancelGameService,用户在华为应用市场开启游戏服务授权后,应用可以调用本方法向用户提供取消游戏服务授权的功能。
方法名:cancelGameService
参数说明:无需参数。
示例:
sdkhub.getUserPlugin().callFuncWithParam("cancelGameService");
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 124 | String | 取消游戏服务授权成功描述 |
+ 125 | String | 取消游戏服务授权失败描述 |
设置欢迎提示语和完成成就提示框展示位置
可参考 setPopupsPosition,设置欢迎提示语和完成成就提示框展示的位置。如果不调用本接口,将默认在页面顶部展示。
方法名:setPopupsPosition
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
position | 0 | 当前只支持在页面顶部展示欢迎提示语和完成成就提示框。 此参数传入任意整型值即可。 |
示例:
var params = 1;
sdkhub.getUserPlugin().callFuncWithParam("setPopupsPosition", params);
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 126 | String | 设置提示框位置成功描述 |
+ 127 | String | 设置提示框位置失败描述 |
获取 APPID
可参考 获取游戏的应用 ID 文档。
方法名:getAppId
参数说明:无需参数。
示例:
sdkhub.getUserPlugin().callFuncWithParam("getAppId");
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 128 | String | 获取 APPID 成功,可获取参数 APPID |
+ 129 | String | 获取 APPID 失败描述 |
存档
开发者可以将玩家的游戏进度存储到华为云空间,或从华为云空间中获得之前的游戏进度以便继续游戏。因此,只要用户使用相同的华为帐号登录,则可以在任意设备上按照之前的游戏进度继续游戏,即使用户之前的设备丢失、损毁或换了新设备也能继续之前的游戏进度。可参考 游戏服务 - 业务介绍 和 API 参考 - ArchivesClient。
方法名:archive
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 120 | String | 成功回调,需通过 type 判断调用类型,并获取其他参数。 |
+ 121 | String | 失败回调,需通过 type 判断调用类型。 |
此外还有两种特殊 type
回调类型可能需要处理:
archiveAdd
:当用户点击存档选择页面的 添加存档 按钮时会收到该回调。请调用addArchive
方法,保存当前游戏记录。archiveConflict
:发生 存档冲突 时请分析返回信息中的recentArchive
和serverArchive
对象,解决冲突后调用updateArchive
方法。
setScopeList:
如果要使用存档功能,需要在玩家登录之前调用该方法,申请 DRIVE_APP_DATA 的 SCOPE,无需处理回调。
示例:
var params = {
"type": "setScopeList",
}
sdkhub.getUserPlugin().callFuncWithParam("archive", params);
addArchive:
以 异步 方式提交存档记录,只增加存档。即使应用客户端调用本方法时如果设备无网络,HMS Core SDK 也会先将数据缓存在本地,待网络恢复后用户再次登录时提交到华为服务器,开发者无需关注此方法的执行结果。
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
activeTime | "10000" | 存档的时长。由开发者在提交存档时自行定义,Java 侧为 long 型。 |
currentProgress | "50" | 存档的进度值。由开发者在提交存档时自行定义,Java 侧为 long 型。 |
descInfo | "Savedata20" | 存档描述信息 |
archiveDetails | "Savedata20, details..." | 需要写入存档文件的二进制字节数据 |
thumbnail | "archiveIcon.png" | 存档封面图片,可选,需要放在可读写目录下 |
thumbnailMimeType | "png" "jpg" | 存档封面图片类型,可选 |
isSupportCache | "0" | 是否支持网络异常时先缓存到本地,待网络恢复后再提交,默认为 "1",支持。 |
示例:
var params = {
"type": "addArchive",
"activeTime": "5000",
"currentProgress": "50",
"archiveDetails": "time = 5000, progress = 50",
"descInfo": "Savedata20",
"thumbnail": "archiveIcon.png",
"thumbnailMimeType": "png",
"isSupportCache" : "1",
};
sdkhub.getUserPlugin().callFuncWithParam("archive", params);
removeArchive:
删除存档记录,包括华为游戏服务器和本地缓存中的存档记录。
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
archiveId | "AA14I0V4G_gChJWeU_H2RRQalZZT5hvwA" | 要删除的存档的 ID。 |
示例:
var params = {
"type": "removeArchive",
"archiveId": "AA14I0V4G_gChJWeU_H2RRQalZZT5hvwA",
};
sdkhub.getUserPlugin().callFuncWithParam("archive", params);
getLimitThumbnailSize:
获取服务器允许的封面图片文件的最大大小。
示例:
var params = {
"type": "getLimitThumbnailSize",
};
sdkhub.getUserPlugin().callFuncWithParam("archive", params);
getLimitDetailsSize:
获取服务器允许的存档文件的最大大小。
示例:
var params = {
"type": "getLimitDetailsSize",
};
sdkhub.getUserPlugin().callFuncWithParam("archive", params);
getShowArchiveListIntent:
打开存档选择页面。
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
title | "Saved games" | 界面上展示的存档的名称 |
allowAddBtn | "1" | 可选,是否允许新增存档按钮。默认为 “0”,不允许。 |
allowDeleteBtn | "1" | 可选,是否允许新增删除存档按钮。默认为 “0”,不允许。 |
maxArchive | "1" | 可选,展示存档的最大数量,默认为 "-1",表示展示全部。 |
示例:
var params = {
"type": "getShowArchiveListIntent",
"title": "Savedata",
"allowAddBtn": "1",
"allowDeleteBtn": "1",
"maxArchive": "5",
};
sdkhub.getUserPlugin().callFuncWithParam("archive", params);
getArchiveSummaryList:
获取当前玩家的所有存档元数据,支持从本地缓存获取。
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
isRealTime | "0" | 可选,是否联网获取数据,默认为 "1"。 "1":表示从游戏服务器获取数据。 "0":表示从本地缓存获取数据。本地缓存时间为 5 分钟,如果本地无缓存或缓存超时,则从游戏服务器获取。 |
示例:
var params = {
"type": "getArchiveSummaryList",
"isRealTime": "0",
};
sdkhub.getUserPlugin().callFuncWithParam("archive", params);
loadArchiveDetails:
使用存档 ID 打开存档元数据,支持指定 冲突策略。
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
archiveId | "AA14I0V4G_gChJWeU_H2RRQalZZT5hvwA" | 存档 ID |
diffStrategy | "STRATEGY_SELF" "STRATEGY_ACTIVE_TIME" "STRATEGY_TOTAL_PROGRESS" "STRATEGY_LAST_UPDATE" | 选择解决冲突的策略。默认为 "STRATEGY_SELF",不处理冲突。 "STRATEGY_ACTIVE_TIME":游戏时长,在冲突的两个存档中使用游戏时长较长的存档处理冲突。 "STRATEGY_TOTAL_PROGRESS":游戏进度,在冲突的两个存档中使用进度较快的存档来处理冲突。 "STRATEGY_LAST_UPDATE":最近修改版本,在冲突的两个存档中使用最近修改的存档处理冲突。 |
示例:
var params = {
"type": "loadArchiveDetails",
"archiveId": "AA14I0V4G_gChJWeU_H2RRQalZZT5hvwA",
"diffStrategy": "STRATEGY_TOTAL_PROGRESS",
};
sdkhub.getUserPlugin().callFuncWithParam("archive", params);
updateArchive:
更新存档或解决数据冲突。
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
selectArchive | "recentArchive" "serverArchive" | 选择使用哪个存档来处理 type = archiveConflict 的冲突回调。若传入该参数,则其他参数都不生效。详情请参考文档 解决冲突。"recentArchive":选择本地缓存的存档作为最终存档。 "serverArchive":选择从服务器获取的存档作为最终存档。 |
archiveId | "AA14I0V4G_gChJWeU_H2RRQalZZT5hvwA" | 存档 ID |
activeTime | "10000" | 存档的时长。由开发者在提交存档时自行定义,Java 侧为 long 型。 |
currentProgress | "50" | 存档的进度值。由开发者在提交存档时自行定义,Java 侧为 long 型。 |
descInfo | "Savedata20" | 存档描述信息 |
archiveDetails | "Savedata20, details..." | 需要写入存档文件的二进制字节数据 |
thumbnail | "archiveIcon.png" | 可选,存档封面图片,需要放在可读写目录下 |
thumbnailMimeType | "png" "jpg" | 可选,存档封面图片类型 |
示例:
var params = {
"type": "updateArchive",
// "selectArchive": "recentArchive",
"archiveId": "AA14I0V4G_gChJWeU_H2RRQalZZT5hvwA",
"activeTime": "8000",
"currentProgress": "60",
"archiveDetails": "time=8000,progress=60",
"descInfo": "savedata20",
"thumbnail": "archiveIcon.png",
"thumbnailMimeType": "png",
};
sdkhub.getUserPlugin().callFuncWithParam("archive", params);
自动读取短信验证码
可选,可参考 账号服务 - 自动读取短信验证码 文档。本插件在 User 系统初始化时调用了请求开启短信读取服务,用户无需调用代码,仅需处理回调。
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 102 | String | 读取短信验证码初始化回调 |
+ 103 | String | 读取短信验证码失败或超时回调 |
+ 104 | String | 返回读取的短信验证码信息 |
授权读取短信验证码
可选,可参考 账号服务 - 授权读取短信验证码 文档。
方法名:smsStartConsent
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
phoneNumber | 136xxxxxxxx | 可选参数,发送短信的号码,长度小于等于 128 位。 如果传该参数,HMS Core SDK 会根据该号码精确匹配符合短信规则的第一条短信。 如果不传该参数,HMS Core SDK 会读取调用该接口后用户手机中的未读消息,并展示第一条匹配短信规则的短信。 |
示例:
sdkhub.getUserPlugin().callFuncWithParam("smsStartConsent");
var phoneNumber = "136xxxxxxxx";
sdkhub.getUserPlugin().callFuncWithParam("smsStartConsent", phoneNumber);
回调说明:
扩展回调值 sdkhub.UserResultCode.kUserExtension | msg 类型 | msg 说明 |
---|---|---|
+ 102 | String | 读取短信验证码初始化回调 |
+ 103 | String | 读取短信验证码失败或超时回调 |
+ 104 | String | 返回读取的短信验证码信息 |
支付插件
开发时请先参考 Cocos SDKHub - 支付插件,本章节作为 HMS Core SDK 插件特性的补充说明部分。
HMS Core SDK 在 V3.0 后便不再支持支付服务端通知模式。目前支付流程是将支付回执先发给客户端,与苹果的 AppStore 的 In-App Purchase 较为接近。若用户从旧版本升级上来,请注意流程上的改动。
支付商品
feeForProduct
支付方法,可参考 应用内支付服务 - 发起购买 文档。
用户支付商品成功后,若为 消耗型商品,需要通过 消耗型商品的补单机制 进行核销。否则该商品不能再次调用支付商品方法并返回错误。
支付服务支持 沙盒测试。
HMS Core SDK 目前支付流程中,支付后的回执直接返回客户端。Cocos SDKHub 插件也封装了客户端层的 对返回结果验签。若用户还需要再做服务端验证,请参考 Order 服务购买 Token 校验。
由于 HMS Core SDK 现在要求商品都在后台配置,通过商品 ID 调用支付方法,仅需要传以下参数。
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
Product_ID | "CProduct1" | 后台配置商品的商品 ID。 |
EXT | "50extra" | 可选,对应 文档 setDeveloperPayload ,支付透传参数。 |
priceType | "0" | 可选,0/1/2 分别对应消耗型商品,非消耗型商品和订阅型商品,不传则默认为 "0"。 |
以下方法需要通过 扩展方法调用。
判断是否支持应用内支付
判断是否支持应用内支付方法,在使用应用内支付之前,开发者的应用需要向华为 IAP 发送 isEnvReady 请求,以此判断用户当前登录的华为帐号所在的服务地,是否在华为 IAP 支持结算的国家或地区中。可参考 应用内支付服务 - 判断是否支持应用内支付 文档。
方法名:isEnvReady
参数说明:无需参数。
示例:
sdkhub.getFeePlugin().callFuncWithParam("isEnvReady");
回调说明:
扩展回调值 sdkhub.FeeResultCode.kFeeExtension | msg 类型 | msg 说明 |
---|---|---|
+ 100 | JSON | 支持应用内支付情况描述 |
+ 101 | JSON / String | 不支持应用内支付情况描述 |
展示商品信息
展示商品信息方法,若开发者使用在华为 AppGallery Connect 网站上配置的商品,则需要在开发者的应用中使用 obtainProductInfo
接口来获取此类商品的详细信息。可参考 应用内支付服务 - 展示商品信息方法 文档。
方法名:obtainProductInfo
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
productIdList | "item1,item2" | 后台配置商品的商品 ID,若需传入多个以逗号分隔。 |
priceType | "0" | 可选,0/1/2 分别对应消耗型商品,非消耗型商品和订阅型商品,不传则默认为 0。 |
示例:
var params = {
"productIdList": conf.obtainProductIdList,
"priceType": 0
};
sdkhub.getFeePlugin().callFuncWithParam("obtainProductInfo", params);
回调说明:
扩展回调值 sdkhub.FeeResultCode.kFeeExtension | msg 类型 | msg 说明 |
---|---|---|
+ 102 | JSONArray | 返回商品信息成功,可解析 msg 展示商品 |
+ 103 | JSON / String | 返回商品信息失败 |
消耗型商品的补单机制 & 提供非消耗型商品对应的服务
可参考 应用内支付服务 - 消耗型商品的补单机制 文档。
- 若用户购买的是 消耗型商品,则需要在获得支付商品回调信息,或者
obtainOwnedPurchases
返回的未发货回调信息后,调用consumeOwnedPurchase
,对已发货商品进行消耗。 - 若用户购买的是 非消耗型商品,则需要在获得支付商品回调信息后发货,但无需进行消耗。其他时段需要调用
obtainOwnedPurchases
同步下已购买的非消耗品商品是否已在发货状态。
若用户购买的是 订阅型商品,则返回该用户在此应用下已有的订阅关系,包括以下几种订阅关系:
- 续期(正常使用,下周期会续费)。
- 到期(下一周期不再续费,这个周期过后就变成已过期)。
- 已过期(订阅服务不能再使用,但是仍能从订阅关系历史中查到)。
建议在游戏开始时调用 obtainOwnedPurchases
方法,获取用户还有哪些已购 消耗型商品 尚未发货并做处理,已购 非消耗型商品 是否发货状态与购买信息同步。
obtainOwnedPurchases
获取的回调 Array 里的信息,与支付商品成功回调信息格式一致,包含用商品购买信息及其签名数据。可使用公钥进行签名验证并做补发。
consumeOwnedPurchase
消耗商品接口也可以通过服务端调用,可参考 Order 服务确认购买 文档。
Sample 工程 中提供了一个简单的消耗型商品消耗流程,可供参考。
查询用户所有已订购商品信息
方法名:obtainOwnedPurchases
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
type | 0 | Number 型,0/1/2 分别对应消耗型商品、非消耗型商品、订阅商品。 |
示例:
var params = 0;
sdkhub.getFeePlugin().callFuncWithParam("obtainOwnedPurchases", params);
回调说明:
扩展回调值 sdkhub.FeeResultCode.kFeeExtension | msg 类型 | msg 说明 |
---|---|---|
+ 106 | JSONArray | 可解析 Array 中的,调用 consumeOwnedPurchase 方法 |
+ 107 | JSON / String | 操作失败描述 |
对已发货商品进行消耗
方法名:consumeOwnedPurchase
参数说明:
支付成功回调的 msg 转为 JSON 对象后,获取其中的 inAppPurchaseData
。可参考 Sample 工程写法。
示例:
params = conf.paymentReceipt[0]["inAppPurchaseData"];
sdkhub.getFeePlugin().callFuncWithParam("consumeOwnedPurchase", params);
回调说明:
扩展回调值 sdkhub.FeeResultCode.kFeeExtension | msg 类型 | msg 说明 |
---|---|---|
+ 104 | String | 消耗品确认交易成功描述 |
+ 105 | JSON / String | 消耗品确认交易失败描述 |
查看用户购买历史
查看用户购买历史方法,可参考 应用内支付服务 - 查看用户购买历史 文档。对于消耗型商品,可使用该接口获取用户所有已消耗即已发货的商品信息。
方法名:obtainOwnedPurchaseRecord
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
type | 0 | Number 型,0/1/2 分别对应消耗型商品、非消耗型商品和订阅型商品。 |
示例:
var params = 0;
sdkhub.getFeePlugin().callFuncWithParam("obtainOwnedPurchaseRecord", params);
回调说明:
扩展回调值 sdkhub.FeeResultCode.kFeeExtension | msg 类型 | msg 说明 |
---|---|---|
+ 118 | JSONArray | 返回购买历史信息 |
+ 109 | JSON / String | 返回购买历史信息失败 |
提供订阅管理的页面跳转
提供订阅管理的页面跳转方法,可参考 订阅专用功能说明 - 提供订阅管理的页面跳转 文档。开发者的应用可以通过该接口跳转到华为 IAP 的管理订阅页面和编辑订阅页面。
方法名:startIapActivity
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
reqType | "TYPE_SUBSCRIBE_EDIT_ACTIVITY" | 若传入"TYPE_SUBSCRIBE_EDIT_ACTIVITY" 显示编辑订阅页面 若传入 "TYPE_SUBSCRIBE_MANAGER_ACTIVITY" 显示管理订阅页面。 |
示例:
var params = {"reqType": "TYPE_SUBSCRIBE_MANAGER_ACTIVITY"};
sdkhub.getFeePlugin().callFuncWithParam("startIapActivity", params);
回调说明:
扩展回调值 sdkhub.FeeResultCode.kFeeExtension | msg 类型 | msg 说明 |
---|---|---|
+ 110 | JSON | 打开页面成功描述 |
+ 111 | JSON / String | 打开页面失败描述 |
广告插件
开发时请先参考 Cocos SDKHub - 广告插件,本章节作为 HMS Core SDK 插件特性的补充说明部分。
目前广告系统接入的是 流量变现服务 部分。接入广告形式为 Banner,原生广告,激励广告 和 插屏广告。开屏和极速开屏广告若有需要用户可自己直接在工程中接入。
Reward 激励广告和 Interstitial 插屏广告均需要先调用 preloadAds
预加载方法,收到成功回调后,再调用 showAds
显示广告。Banner 条幅广告和 Native 原生广告,可直接调用 showAds
显示广告。
预加载广告
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
adType | "Interstitial" "Reward" | 广告类型 |
adId | "testb4znbuh3n2" | 广告 ID |
示例:
var params = { "adType": "Reward", "adId": "testx9dtjwj8hp" };
sdkhub.getAdsPlugin().preloadAds(params);
显示广告
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
adType | "Interstitial" "Native" "Reward" "Banner" | 广告类型 |
adId | "testx9dtjwj8hp" | 广告 ID,Native 原生广告中,广告 ID 对应不同展示形式的原生广告 |
pos | "0" | 广告位置,Banner 情况下可选,默认为 "0"。 "0":正下方 "1":正中 "2":正上方 |
adSize | "BANNER_SIZE_360_144" | 广告尺寸,Banner 情况下可选,默认为 "BANNER_SIZE_360_57",传入值可参考 广告尺寸 文档。 |
nativeLayout | "native_small" "native_full" | Native 情况下可选,对应插件自带的两种 原生广告模板文件,用户也可直接在对应 .xml 文件中修改布局,默认为 "native_full" |
requestCustomDislikeThisAd | "1" | Native 情况下可选,不再显示该广告 开关,用户可以自行隐藏或关闭不感兴趣的广告,默认值为 "0",该功能大陆地区不可用,若需调试需要在 Log 中查看输出信息。 |
choicesPosition | "TOP_LEFT" "TOP_RIGHT" "BOTTOM_RIGHT" "BOTTOM_LEFT" "INVISIBLE" | Native 广告且 requestCustomDislikeThisAd = "1" 情况下可选,设置广告选项的展示位置,默认为 "TOP_RIGHT" |
videoConfiguration | "1" | Native 情况下可选,视频广告参数设置。默认为 "0",设为 "1" 情况下,可设置以下参数 |
audioFocusType | "GAIN_AUDIO_FOCUS_ALL" "NOT_GAIN_AUDIO_FOCUS_WHEN_MUTE" "NOT_GAIN_AUDIO_FOCUS_ALL" | Native 广告且 videoConfiguration = "1" 情况下可选,设置视频的音频焦点类型,默认为 "GAIN_AUDIO_FOCUS_ALL" |
startMuted | "0" | Native 广告且 videoConfiguration = "1" 情况下可选,设置视频的初始静音状态,默认为 "1" |
注意:使用 Native 原生广告,再次调用显示广告方法前,请确保先前的请求已经完成。
示例:
var params = { "adType": "Banner", "adId": "testw6vs28auh3", "pos": "0", "adSize": "BANNER_SIZE_360_144" };
sdkhub.getAdsPlugin().showAds(params);
隐藏广告
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
adType | "Native" "Banner" | 广告类型 |
示例:
var params = { "adType": "Native" };
sdkhub.getAdsPlugin().hideAds(params);
推送插件
开发时请先参考 Cocos SDKHub - 推送插件,本章节作为 HMS Core SDK 插件特性的补充说明部分。
调试推送功能时,需要调用 开始推送 startPush
方法,成功回调 msg 信息即为 Push Token
,再到后台进行推送操作。
HMS Core SDK 不支持 设置别名 和 删除别名 功能。
HMS Core SDK 的 设置标签 和 删除标签 接口每次只能设置一条,若开发者按文档传入多个标签,则会有多次回调,该回调一般无需处理。
以下方法需要通过 扩展方法调用。
设置是否显示通知栏消息
可参考 推送服务 - 设置是否显示通知栏消息。通知消息是由系统直接在通知中心下拉列表呈现的即时消息。开发者如果想控制应用是否允许显示通知栏消息,可以调用以下接口。如果开发者不调用此接口,系统默认是允许显示通知栏消息。
该功能无法获取当前状态,用户需要在需要的情况下主动调用。
打开显示通知栏消息
方法名:turnOnPush
参数说明:无需参数。
示例:
sdkhub.getPushPlugin().callFuncWithParam("turnOnPush");
回调说明:
扩展回调值 sdkhub.PushResultCode.kPushExtension | msg 类型 | msg 说明 |
---|---|---|
+ 100 | String | 打开显示通知栏消息方法调用成功描述 |
+ 101 | JSON / String | 打开显示通知栏消息方法调用失败描述 |
关闭显示通知栏消息
方法名:turnOffPush
参数说明:无需参数。
示例:
sdkhub.getPushPlugin().callFuncWithParam("turnOffPush");
回调说明:
扩展回调值 sdkhub.PushResultCode.kPushExtension | msg 类型 | msg 说明 |
---|---|---|
+ 102 | String | 关闭显示通知栏消息方法调用成功描述 |
+ 103 | JSON / String | 关闭显示通知栏消息方法调用失败描述 |
发送上行消息
发送上行消息功能,可参考 推送服务 - 发送上行消息 文档。该方法仅提供客户端接口,若用户需要接入,需要参考文档完成服务端部分。
方法名:sendMessage
参数说明:
仅有 messageId
为必传,部分参数可对应文档 RemoteMessage.Builder,传入指定参数便会调用相关方法。传入其他 Key 和 Value 值,便可用来上行给服务端。
参数名 | 填写格式 | 说明 |
---|---|---|
messageId | "mid123456" | 需要保证该参数的唯一性 |
messageType | "mType1" | 发送上行消息时设置的消息类型,SDK 不感知,直接透传 |
collapseKey | "0" | 可选,设置消息分类标识,用于控制离线消息的覆盖功能. "-1":是,对于本应用的离线消息待用户上线后全部发送给用户。 "0":对于本应用的离线消息待用户上线后按照华为推送系统默认策略发送给用户(一般是最新的一条)。 "1~100":是对消息进行分组,例如如果开发者发送了10条消息,其中前5条的collapse_key为1,后5条的collapse_key为2,那么待用户上线后collapse_key为1和2的分别下发最新的一条消息给最终用户。 |
sendMode | "1" | 可选,设置是否使用终端设备上Push的消息缓存重发能力。如果不设置则不支持消息缓存,比如当网络不可用时消息会直接丢弃。取值只有 "0" 与 "1","1" 表示使用消息缓存重发能力。 |
receiptMode | "0" | 可选,设置上行消息发送到App服务器后的消息回执能力。取值只有 "0" 与 "1","1" 表示使用消息回执能力。 |
ttl | "10000" | 可选,设置消息的最大缓存时间,单位秒,支持设置最大15天 [0, 1296000]。 |
其他 key 值 | 其他 Value 值 | 可传任意多组,上行给服务端的信息。 |
示例:
var params = {
"messageId": "messageId" + Math.ceil(Math.random() * 100000),
"messageType": "mType1",
"collapseKey": "0",
"sendMode": "1",
"receiptMode": "1",
"ttl": "10000",
"key1": "value1",
"key2": "value2",
"key3": "value3"
}
sdkhub.getPushPlugin().callFuncWithParam("sendMessage", params);
回调说明:
扩展回调值 sdkhub.PushResultCode.kPushExtension | msg 类型 | msg 说明 |
---|---|---|
+ 104 | String | 消息发送成功,返回 msgId |
+ 105 | String | 消息发送时发生错误,返回失败描述 |
+ 106 | String | 消息已经送达,返回 msgId |
获取 ODID
异步任务获取 ODID,可参考 推送服务 - getOdid。
方法名:getOdid
示例:
sdkhub.getPushPlugin().callFuncWithParam("getOdid");
回调说明:
扩展回调值 sdkhub.PushResultCode.kPushExtension | msg 类型 | msg 说明 |
---|---|---|
+ 108 | String | 返回获取的 ODID |
+ 109 | String | 发生错误,返回失败描述 |
获取 AAID
异步任务获取 AAID,可参考 推送服务 - getAAID。
方法名:getAAID
示例:
sdkhub.getPushPlugin().callFuncWithParam("getAAID");
回调说明:
扩展回调值 sdkhub.PushResultCode.kPushExtension | msg 类型 | msg 说明 |
---|---|---|
+ 110 | String | 返回获取的 AAID |
+ 111 | String | 发生错误,返回失败描述 |
删除 AAID
删除本地已经生成的 AAID,可参考 推送服务 - deleteAAID。
方法名:deleteAAID
示例:
sdkhub.getPushPlugin().callFuncWithParam("deleteAAID");
回调说明:
扩展回调值 sdkhub.PushResultCode.kPushExtension | msg 类型 | msg 说明 |
---|---|---|
+ 112 | String | 删除成功,返回成功描述 |
+ 113 | String | 删除失败,返回失败描述 |
获取自动初始化
获取是否启用了自动初始化功能,可参考 isAutoInitEnabled。
方法名:isAutoInitEnabled
示例:
var isAuto = sdkhub.getPushPlugin().callBoolFuncWithParam("isAutoInitEnabled");
console.log("isAutoInitEnabled", isAuto);
设置自动初始化
设置是否自动初始化。如果设置为 true,SDK 会自动生成 AAID,自动申请令牌 Token,申请的令牌通过 sdkhub.PushResultCode.kPushExtension + 100
回调方法返回。可参考 setAutoInitEnabled。
方法名:setAutoInitEnabled
示例:
var params = 1 - sdkhub.getPushPlugin().callBoolFuncWithParam("isAutoInitEnabled");
sdkhub.getPushPlugin().callFuncWithParam("setAutoInitEnabled", params);
在多发送者场景下,目标应用给发送者申请 token
在多发送者场景下,目标应用给发送者注销 token 方法,subjectId
需要传入 AGC 后台的项目ID。
使用方式和回调与 startPush
方法相同。
方法名:getToken
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
subjectId | "7364300792444xxxxx" | 发送者的项目 ID,登录 AGC 后台,选择 我的项目,左侧导航栏选择 项目设置,在该页面获取发送者的项目 ID。 |
示例:
var subjectId = "7364300792444xxxxx";
sdkhub.getPushPlugin().callFuncWithParam("getToken", subjectId);
在多发送者场景下,目标应用给发送者注销 token
在多发送者场景下,目标应用给发送者注销 token 方法,subjectId
需要传入 AGC 后台的项目ID。
使用方式和回调与 closePush
方法相同。
方法名:deleteToken
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
subjectId | "7364300792444xxxxx" | 发送者的项目 ID,登录 AGC 后台,选择 我的项目,左侧导航栏选择 项目设置,在该页面获取发送者的项目 ID。 |
示例:
var subjectId = "7364300792444xxxxx";
sdkhub.getPushPlugin().callFuncWithParam("deleteToken", subjectId);
判断当前设备是否支持帐号校验能力
对应 帐号校验功能。从 Push SDK 5.0.4 版本开始,华为推送服务提供了帐号校验功能,该功能支持您根据终端设备上不同账户属性来推送消息。举例来说:某华为手机上,有用户 A 和用户 B,用户 A 和 B 名下都有华为钱包应用,华为钱包给用户 A 推送消息时,只有用户 A 登录时才展示,其他用户登录消息不展示,这就使用了帐号校验功能。
方法名:isSupportProfile
示例:
console.log("isSupportProfile, ret = ", sdkhub.getPushPlugin().callBoolFuncWithParam("isSupportProfile"));
添加当前设备上的用户与应用的关系
方法名:addProfile
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
subjectId | "7364300792444xxxxx" | 可选,发送者的项目 ID,登录 AGC 后台,选择 我的项目,左侧导航栏选择 项目设置,在该页面获取发送者的项目 ID。 |
type | "HUAWEI_PROFILE" | 帐号校验功能的类型,"HUAWEI_PROFILE" 表示关联华为帐号,"CUSTOM_PROFILE" 表示不关联华为帐号。 |
profileId | "A123456" | 若当前设备支持帐号校验能力,应用发送的消息需要校验帐号,profileId 是您给帐号自定义生成的帐号的唯一标识。 |
示例:
var params1 = {
"type": "CUSTOM_PROFILE",
"profileId": "PROFILE_ID_001"
};
sdkhub.getPushPlugin().callFuncWithParam("addProfile", params1);
var params2 = {
"subjectId": "7364300792444xxxxx",
"type": "CUSTOM_PROFILE",
"profileId": "PROFILE_ID_001"
}
sdkhub.getPushPlugin().callFuncWithParam("addProfile", params2);
删除当前设备上的用户与应用的关系
方法名:deleteProfile
参数说明:
参数名 | 填写格式 | 说明 |
---|---|---|
subjectId | "7364300792444xxxxx" | 可选,发送者的项目 ID,登录 AGC 后台,选择 我的项目,左侧导航栏选择 项目设置,在该页面获取发送者的项目 ID。 |
profileId | "A123456" | 若当前设备支持帐号校验能力,应用发送的消息需要校验帐号,profileId 是您给帐号自定义生成的帐号的唯一标识。 |
示例:
var params1 = {
"profileId": "PROFILE_ID_001"
};
sdkhub.getPushPlugin().callFuncWithParam("deleteProfile", params1);
var params2 = {
"subjectId": "7364300792444xxxxx",
"profileId": "PROFILE_ID_001"
}
sdkhub.getPushPlugin().callFuncWithParam("deleteProfile", params2);
由3D建模学习工作室 翻译整理,转载请注明出处!