1.2 充值部分
1.2.1 是否开启年龄限制
说明
检测游戏是否开启年龄限制,在游戏对接阶段就已经确定是否开启年龄限制,对游戏来说是个固定值。
接口
public Boolean isInAppBillingAgeLimitOn()
参数说明
无
示例
mCydoniaSDK.isInAppBillingAgeLimitOn()
1.2.3 玩家是否设定生日
说明
在开启年龄限制的前提下,检测玩家是否设定了生日。如果没有设定需要弹出设定UI.
接口
public Boolean isBirthdaySet()
参数说明
无
示例
if (mCydoniaSDK.isBirthdaySet()) {
Log.d(SDKDEMOTAG, "birthday set");
System.out.println("Demo isBirthdaySet: yes");
} else {
System.out.println("Demo isBirthdaySet: no");
Log.d(SDKDEMOTAG, "birthday not set");
}
1.2.4 玩家设定生日
说明
在开启年龄限制的前提下,需要此API设定玩家生日,配合前面的UI需求。
接口
public void setBirthday(String birthday, final CydoniaJPSDKCallbackListener sdkCallback)
参数说明
birthday:玩家选择的生日,格式是"yyyyMM"。例如:"200012"
示例
mCydoniaSDK.setBirthday("201010", new CydoniaJPSDKCallbackListener() {
@Override
public void onResult(String params) {
try {
JSONObject resultObject = new JSONObject(params);
Log.d(SDKDEMOTAG, "status:" + resultObject.get("status") + ", message:" + resultObject.get("msg"));
System.out.println("Demo setBirthday result:" + "status:" + resultObject.get("status")
+ ", message:" + resultObject.get("msg"));
}catch (JSONException e) {
e.printStackTrace();
}
}
});
1.2.5 玩家是否在充值限制内
说明
在开启年龄限制的前提下,每次充值都要检测本次充值是否在充值范围内。
接口
public void isInChargeLimit(Long itemPrice, final CydoniaJPSDKCallbackListener sdkCallback)
参数说明
itemPrice:需要购买的item的价格
示例
//购买的前提是在充值限定范围内
mCydoniaSDK.isInChargeLimit(120L, new CydoniaJPSDKCallbackListener() {
@Override
public void onResult(String params) {
try {
JSONObject resultObject = new JSONObject(params);
if (resultObject.getInt("status") == 200) {
/////////////////
//允许购买
//billingPara一般传入本单所在服务器等信息,主要用于掉单后的补单处理,根据实际需求设定,例如服务器id_服务器商品id
//billingPara不能用特殊符号,仅能使用a-zA-Z0-9_
////////////////
} else {
////超出了本月年龄限制,本月无法充值, 需要给玩家弹窗提示
Log.d(SDKDEMOTAG, "status:" + resultObject.get("status") + ", message:" + resultObject.get("msg"));
System.out.println("Demo isInChargeLimit result:" + "status:" + resultObject.get("status")
+ ", message:" + resultObject.get("msg"));
}
}catch (JSONException e) {
e.printStackTrace();
}
}
});
1.2.6 充值
说明
实现充值功能
接口
public void purchaseItem(String itemSku, String billingPara, final UserPurchaseCallbackListener sdkCallback)
参数说明
productId:商品ID
billingPara:便于未消除订单的重新充值,需要自定义标识来识别此订单属于哪个服等
示例
//billingPara一般传入本单所在服务器等信息,主要用于掉单后的补单处理,根据实际需求设定,例如服务器id_服务器商品id
//billingPara不能用特殊符号,仅能使用a-zA-Z0-9_
mCydoniaSDK.purchaseItem("com.cydoniajp.sdkdevelop.item1","J1_I_10001", new UserPurchaseCallbackListener() {
@Override
public void onUserPurchaseResult(String params) {
try {
JSONObject iapResultObject = new JSONObject(params);
//安卓客户端SDK返回200:购买成功,300:购买失败 301:购买取消
if (iapResultObject.get("status").equals("200")) {
Log.d(SDKDEMOTAG,
"status:" + iapResultObject.get("status") + ", receipt:" + iapResultObject.get("receipt") + ", signature:" + iapResultObject.get("signature") + ", googleOrderId:"+ iapResultObject.get("googleOrderId")+ ", productId:"+ iapResultObject.get("productId"));
System.out.println("Demo purchaseItem result:" + "status:" + iapResultObject.get("status") + ", receipt:" + iapResultObject.get("receipt") + ", signature:" + iapResultObject.get("signature") + ", googleOrderId:"+ iapResultObject.get("googleOrderId") + ", productId:"+ iapResultObject.get("productId")+ ",para:" + iapResultObject.get("para"));
} else {
Log.d(SDKDEMOTAG, "status:" + iapResultObject.get("status") + ", message:" + iapResultObject.get("msg"));
System.out.println("Demo purchaseItem result:" + "status:" + iapResultObject.get("status")
+ ", message:" + iapResultObject.get("msg"));
}
} catch (JSONException e) {
e.printStackTrace();
}
}
});
1.2.7 检测是否有未消除订单
说明
充值有时会有掉单发生,这时候订单会缓存在客户端,在玩家重启游戏或者重新打开充值界面时可以调用此API检测是否有掉单发生,如果有未清除订单需要继续跟服务端通讯完成充值,完成充值后进行下面的消单操作。
接口
public String checkIsPayInfoLeft()
参数说明
无
示例
String leftPayInfo = mCydoniaSDK.checkIsPayInfoLeft();
Log.d(SDKDEMOTAG,"leftPayInfo:" + leftPayInfo );
System.out.println("Demo 如果游戏服务器完成了订单校验并通知了客户端发货,应该清除leftPayInfo,返回空,否则返回字符串.leftPayInfo:" + leftPayInfo);
if (leftPayInfo.length() > 0){
for(String oneReceipt : leftPayInfo.split(";")){
try {
JSONObject payInfoObject = new JSONObject(oneReceipt);
System.out.println("Demo leftPayInfo:" + "status:" + payInfoObject.get("status")+ ", receipt:" + payInfoObject.get("receipt") + ", googleOrderId:"
+ payInfoObject.get("googleOrderId") + ", signature:" + payInfoObject.get("signature") + ",purchaseToken:" + payInfoObject.get("purchaseToken") + ",productId:" + payInfoObject.get("productId")+ ",para:" + payInfoObject.get("para"));
}catch (JSONException e){
System.out.println("Demo 订单格式错误");
}
}
}
1.2.8 消单
说明
充值完成之后调用消单
接口
public void clearPayInfo()
参数说明
无
示例
mCydoniaSDK.clearPayInfo();
Last updated