From c4448ac17d48f4dc79bbb3d047a3e2e0724aa86e Mon Sep 17 00:00:00 2001 From: Zebartin <16185081+Zebartin@users.noreply.github.com> Date: Sat, 1 Jun 2024 15:28:16 +0800 Subject: [PATCH] =?UTF-8?q?fix:=20=E6=88=AA=E5=9B=BE=E6=9D=83=E9=99=90?= =?UTF-8?q?=E7=94=B3=E8=AF=B7?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- NIKKE/CHANGELOG.md | 1 + utils.js | 33 +++++++++++++++++++++++++++------ 2 files changed, 28 insertions(+), 6 deletions(-) diff --git a/NIKKE/CHANGELOG.md b/NIKKE/CHANGELOG.md index 6f4d5eb..0155f27 100644 --- a/NIKKE/CHANGELOG.md +++ b/NIKKE/CHANGELOG.md @@ -3,6 +3,7 @@ - 结束应用失败; - 爬塔战斗结束后卡住; - 特拦队伍识别; +- 截图权限申请问题; 新增功能: diff --git a/utils.js b/utils.js index f384934..a33ed9b 100644 --- a/utils.js +++ b/utils.js @@ -51,7 +51,9 @@ function getDisplaySize(doNotForcePortrait) { const img = captureScreen(); return [img.width, img.height]; } catch (e) { - if (!e.message.includes('No screen capture permission')) { + const errorStr = e.toString(); + if (!errorStr.includes('No screen capture permission') && + !errorStr.includes('ScreenCapturer is not available')) { throw e; } } @@ -551,7 +553,25 @@ function enterPwd(pwd) { } function requestScreenCaptureAuto(ensureImg) { + let testImg; + try { + testImg = captureScreen(); + if (!ensureImg || ensureImg(testImg)) + return; + log(`截图异常,截图大小:${testImg.width}x${testImg.height}`); + if (!images.stopScreenCapturer) { + exit(); + } + images.stopScreenCapturer(); + } catch (e) { + const errorStr = e.toString(); + if (!errorStr.includes('No screen capture permission') && + !errorStr.includes('ScreenCapturer is not available')) { + throw e; + } + } let hasPermission = false; + const [w, h] = getDisplaySize(); let confirmRequest = () => { //安卓版本高于Android 9 if (hasPermission || device.sdkInt <= 28) { @@ -574,13 +594,15 @@ function requestScreenCaptureAuto(ensureImg) { log('找到取消按钮'); const cancelBounds = cancel.get(0).bounds(); t = new android.graphics.Rect( - device.width - cancelBounds.right, + w - cancelBounds.right, cancelBounds.top, - device.width - cancelBounds.left, + w - cancelBounds.left, cancelBounds.bottom ); } - if (t.top < t.bottom && (device.height == 0 || t.bottom <= device.height)) { + if (t) + log(t); + if (t && t.top < t.bottom && (h == 0 || t.top <= h + 200)) { target = { bounds: t }; break; } @@ -589,7 +611,6 @@ function requestScreenCaptureAuto(ensureImg) { console.error('处理截图权限弹窗失败'); return; } - log(`点击区域:${target.bounds}`); for (let i = 0; i < 10; ++i) { if (hasPermission) return; @@ -612,7 +633,7 @@ function requestScreenCaptureAuto(ensureImg) { hasPermission = true; return; } - const testImg = captureScreen(); + testImg = captureScreen(); if (ensureImg(testImg)) { hasPermission = true; return;