/*
* 打开游戏盒主页面
*
* @param activity Activity 实例
*/
public void startGameBox(Activity activity);
/*
* 打开游戏盒详情页,若没有下载游戏盒则提示下载
*
* @param activity Activity对象
*/
public void showGameDetail(Activity activity);
/*
* 打开游戏盒活动详情,若没有下载游戏盒则提示下载
*
* @param activity Activity 实例
* @param activityId 活动id
* @param activityUrl 活动Url
*/
public void showActivityDetail(Activity activity, int activityId, String activityUrl);
/*
* 打开游戏盒礼包中心,若没有下载游戏盒则提示下载
*
* @param activity Activity 实例
*/
public void showGift(Activity activity);
/*
* 打开游戏盒优惠券中心,若没有下载游戏盒则提示下载
*
* @param activity Activity 实例
*/
public void showCoupon(Activity activity);
/*
* 打开游戏盒该游戏的游戏圈页面
* 若未安装游戏盒,则出现提示下载游戏盒的弹窗
*/
public void showGameForum(Activity activity);
/*
* 打开游戏盒论坛(游戏圈)指定帖子,若没有游戏圈toast提示用户,若没有下载游戏盒则提示下载
*
* @param activity Activity 实例
* @param id 帖子id
*/
public void showGameForumDetail(Activity activity, int id);
/*
* 打开游戏盒该游戏的评论页面
* 若未安装游戏盒,则出现提示下载游戏盒的弹窗
*/
public void showGameCommentArea(Activity activity);
此接口要求 SDK 版本不低于
2.37.0
,提供游戏内快速举报违规言论功能。
OperateCenter.reportViolation
举报接口,将一些固定信息传给
SDK/**
*
* 游戏内举报接口
*
* 举报游戏内违规内容,举报结果由 SDK 内部提示
*
* @param activity Activity 实例
* @param violation 违规信息,各字段必须且名称固定如下,若确实没有可留空,但不能不传
* <pre><code>
* Map<String, String> violation = new HashMap<String, String>();
* violation.put("g_uid", "被举报人uid");
* violation.put("g_tid", "聊天频道ID");
* violation.put("g_sid", "服务器ID");
* violation.put("g_rid", "角色ID");
* violation.put("g_role", "角色名称");
* violation.put("g_gname", "公会名");
* violation.put("g_cname", "宠物名");
* violation.put("g_content", "聊天内容");
* violation.put("contact", "联系方式 电话、QQ");
* <code/>
* <pre/>
*/
public void reportViolation(Activity activity, Map<String, String> violation);
Map<String, String> violation = new HashMap<>();
.put("g_uid", "被举报人uid");
violation.put("g_tid", "聊天频道ID");
violation.put("g_sid", "服务器ID");
violation.put("g_rid", "角色ID" + r);
violation.put("g_content", "聊天内容");
violation.put("g_role", "角色名称");
violation.put("g_gname", "公会名");
violation.put("g_cname", "宠物名");
violation.put("contact", "联系方式 电话、QQ");
violation.reportViolation(MainActivity.this, violation); mOpeCenter
SDK 3.3.1
新接入银联微信渠道,充值过程中通过微信小程序与第三方对接,但支付完成后不能可靠回到游戏内。
若游戏有微信
appId
,并接入微信回调,支付后通过小程序可以直接回到游戏内,体验更好。
以下说明如何接入微信回调
appId
:
此过程需要在微信开发者后台完成,提供游戏包名、签名md5等信息appId
:向充值中心提交此标识,提交时带上游戏信息,特别是充值
id以上流程可以咨询相关运营
{
dependencies // 如果接入方已有,可忽略
'com.tencent.mm.opensdk:wechat-sdk-android:6.8.0'
implementation }
libs
目录以下假设游戏包名为cn.m4399.operate.samples
区分游戏是否已有WXEntryActivity
两种情况,当有时,称为已有微信回调,反之为
无微信回调
新建cn.m4399.operate.samples.wxapi.WXEntryActivity
类,将以下代码填充进此类,
并以实际的微信的 appId 填充WECHAT_APP_ID
public class WXEntryActivity extends Activity implements IWXAPIEventHandler {
// REPLACE:使用真实微信appId,它与包名、签名md5是对应的
public static final String WECHAT_APP_ID = WECHAT_APP_ID;
private IWXAPI api;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
= WXAPIFactory.createWXAPI(this, WECHAT_APP_ID, false);
api try {
= getIntent();
Intent intent .handleIntent(intent, this);
api} catch (Exception e) {
.e("[OPERATE]", getClass().getName() + " onCreate but error: " + e.getMessage());
Log.printStackTrace();
e}
}
@Override
public void onReq(BaseReq baseReq) {
}
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
setIntent(intent);
.handleIntent(intent, this);
api}
@Override
public void onResp(BaseResp resp) {
// 4399 运营SDK:收到来自于充值的消息,finish 此 Activity
.Resp r = (WXLaunchMiniProgram.Resp) resp;
WXLaunchMiniProgram.e("[OPERATE]",
LogString.format("Receive wx message, extMsg:%s, openId:%s", r.extMsg, r.openId));
if (!TextUtils.isEmpty(r.extMsg) && r.extMsg.contains("from=recharge"))
finish();
}
}
onResp
方法中内容,拷贝到已有回调的onResp
即可在游戏Activity
注册新加的类,并且将android:taskAffinity="cn.m4399.operate.samples"
中的包名
替换为游戏实际包名(已注册过可忽略)
<!-- 注意:替换 android:taskAffinity="cn.m4399.operate.samples"-->
activity
< android:name=".wxapi.WXEntryActivity"
android:theme="@android:style/Theme.Translucent.NoTitleBar"
android:exported="true"
android:taskAffinity="cn.m4399.operate.samples"
android:launchMode="singleTask">
activity> </