From 5c9dc9a5f802ec52f3cd0cfc0a21ff02bad5aab2 Mon Sep 17 00:00:00 2001
From: hch <305670599@qq.com>
Date: 星期四, 28 九月 2023 12:41:56 +0800
Subject: [PATCH] 0312 测试 每次登录弹权限问题
---
SdkProject/plugins/quick/java/com/secondworld/sdk/QuickSdkMgr.java | 75 +++++++++++++++++--------------------
1 files changed, 34 insertions(+), 41 deletions(-)
diff --git a/SdkProject/plugins/quick/java/com/secondworld/sdk/QuickSdkMgr.java b/SdkProject/plugins/quick/java/com/secondworld/sdk/QuickSdkMgr.java
index 11ffcc3..9cf0355 100644
--- a/SdkProject/plugins/quick/java/com/secondworld/sdk/QuickSdkMgr.java
+++ b/SdkProject/plugins/quick/java/com/secondworld/sdk/QuickSdkMgr.java
@@ -47,22 +47,29 @@
public String channelID;
int REQUEST_RECORD_PERMISSION_SETTING = 110;
- private boolean hasPermissions(Activity activity) {
- return (ContextCompat.checkSelfPermission(activity,
- Manifest.permission.READ_PHONE_STATE) == PackageManager.PERMISSION_GRANTED)
- && (ContextCompat.checkSelfPermission(activity,
- Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED);
+ public boolean hasPermissions(Activity activity) {
+ //鏉冮檺鎻愬彇鍒板悇鑷」鐩腑
+// return (ContextCompat.checkSelfPermission(activity,
+// Manifest.permission.READ_PHONE_STATE) == PackageManager.PERMISSION_GRANTED)
+// && (ContextCompat.checkSelfPermission(activity,
+// Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED);
-// return ContextCompat.checkSelfPermission(activity,
-// Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED;
+ String[] permissionStr = PlatformDiff.I.platformPermission();
+ for (int i = 0; i < permissionStr.length; i++)
+ {
+ if (ContextCompat.checkSelfPermission(activity, permissionStr[i]) != PackageManager.PERMISSION_GRANTED)
+ {
+ return false;
+ }
+ }
+ return true;
}
public void requestPermissions(Activity activity) {
try {
if (!hasPermissions(activity)) {
- ActivityCompat.requestPermissions(activity, new String[]{
- Manifest.permission.READ_PHONE_STATE, Manifest.permission.WRITE_EXTERNAL_STORAGE}, RequestCode.QUICK);
+ ActivityCompat.requestPermissions(activity, PlatformDiff.I.platformPermission(), RequestCode.QUICK);
}
else
{
@@ -76,10 +83,11 @@
}
}
- public void onRequestPermissionsResult(Activity activity, int requestCode, int[] grantResults) {
+ public void onRequestPermissionsResult(Activity activity, int requestCode, int[] grantResults, String[] permissions) {
+ PlatformDiff.I.OnRequestPermissionsResult(requestCode, grantResults, permissions);
if (requestCode != RequestCode.QUICK) return;
- //1768娓犻亾涓�瀹氶渶瑕佹潈闄�
+
if (hasPermissions(activity)) {
LogUtil.i("SdkManager", "onRequestPermissionsResult 鐢宠鎴愬姛");
//鐢宠鎴愬姛
@@ -119,40 +127,14 @@
}
+
public void init(Activity activity) {
sdkInitState = SdkInitState.LOADING;
Sdk.getInstance().init(activity, productCode, productKey);
}
public void login() {
- switch (sdkInitState) {
- case FAILED:
- case UNKNOWN: {
- if (GameActivityProxy.I.activity == null)
- return;
- if (hasPermissions(GameActivityProxy.I.activity)) {
- //init(BtGameMain.I.activity);
- Toast.makeText(GameAppProxy.app, "寮傚父璇烽噸鍚父鎴�", Toast.LENGTH_LONG).show();
- }
- break;
- }
- case SUCCEED: {
- //User.getInstance().login(GameActivityProxy.I.activity);
- GameActivityProxy.I.activity.runOnUiThread(new Runnable()
- {
- @Override
- public void run()
- {
- User.getInstance().login(GameActivityProxy.I.activity);
- }
- });
- break;
- }
- case LOADING: {
- Toast.makeText(GameAppProxy.app, "姝e湪鍒濆鍖栦腑锛岃绋嶇瓑锛�", Toast.LENGTH_LONG).show();
- break;
- }
- }
+ PlatformDiff.I.Login();
}
public void loginOut() {
@@ -247,8 +229,8 @@
sdkInitState = SdkInitState.SUCCEED;
LogUtil.debug("SdkManager", "鍒濆鍖栨垚鍔�");
UnityMsgHandler.sendMessageToUnity(CodeA2U.PlatformInitOk);
+ PlatformDiff.I.RegisterEvent("youxitu");
}
-
@Override
public void onFailed(String message, String trace) {
//鍒濆鍖栧け璐�
@@ -368,7 +350,18 @@
@Override
public void onSuccess() {
//閫�鍑烘垚鍔燂紝娓告垙鍦ㄦ鍋氳嚜韬殑閫�鍑洪�昏緫澶勭悊
- UnityMsgHandler.sendMessageToUnity(CodeA2U.ExitGame);
+ //UnityMsgHandler.sendMessageToUnity(CodeA2U.ExitGame);
+ if (GameActivityProxy.I.activity == null)
+ {
+ UnityMsgHandler.sendMessageToUnity(CodeA2U.ExitGame);
+ return;
+ }
+ LogUtil.i("SdkManager", "activity閫�鍑�");
+ GameActivityProxy.I.activity.finish();
+ android.os.Process.killProcess(android.os.Process.myPid());
+ System.exit(0);
+
+
}
@Override
--
Gitblit v1.8.0