AutoJs6 icon indicating copy to clipboard operation
AutoJs6 copied to clipboard

requestScreenCapture()出现崩溃

Open mhsjzsq opened this issue 2 years ago • 1 comments

执行main.js会出现崩溃的情况。刚启动App执行不会,过一段时间(大概7、8分钟或者更久)再执行有很大的概率会出现

没有使用连接到计算机功能

autox没有发现这个情况

main.js

var tool = require("tool.js");

tool.js

if (!requestScreenCapture()) {
    toast("请求截图失败");
    exit();
}

11月21日 19:04:51 后面又试了一下运行下面,也会出现崩溃: 重启autojs6执行一次main.js,然后过一段时间再执行一次

main.js

requestScreenCapture();

报错: Version: 2180 Android: 31 java.lang.SecurityException: Media projections require a foreground service of type ServiceInfo.FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION java.lang.RuntimeException:Failure delivering result ResultInfo{who=null, request=17777, result=-1, data=Intent { (has extras) }} to activity {org.autojs.autojs6/org.autojs.autojs.core.image.capture.ScreenCaptureRequestActivity}: java.lang.SecurityException: Media projections require a foreground service of type ServiceInfo.FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION android.app.ActivityThread.deliverResults(ActivityThread.java:5481) ...... Caused by: java.lang.SecurityException:Media projections require a foreground service of type ServiceInfo.FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION android.os.Parcel.createExceptionOrNull(Parcel.java:2455) android.os.Parcel.createException(Parcel.java:2439) android.os.Parcel.readException(Parcel.java:2422) android.os.Parcel.readException(Parcel.java:2364) android.media.projection.IMediaProjection$Stub$Proxy.start(IMediaProjection.java:235) android.media.projection.MediaProjection.(MediaProjection.java:59) android.media.projection.MediaProjectionManager.getMediaProjection(MediaProjectionManager.java:119) org.autojs.autojs.core.image.capture.ScreenCapturer.getMediaProjection(ScreenCapturer.java:127) org.autojs.autojs.core.image.capture.ScreenCapturer.setMediaProjectionIfNeeded(ScreenCapturer.java:116) org.autojs.autojs.core.image.capture.ScreenCapturer.(ScreenCapturer.java:79) org.autojs.autojs.core.image.capture.ScreenCapturer.getInstance(ScreenCapturer.java:90) org.autojs.autojs.runtime.api.Images.lambda$requestScreenCapture$0(Images.java:86) org.autojs.autojs.runtime.api.Images.$r8$lambda$GDM6jDGKO9RJDZSzZ32y5gmNoeM(Unknown Source:0) org.autojs.autojs.runtime.api.Images$$ExternalSyntheticLambda2.onRequestResult(Unknown Source:6) org.autojs.autojs.core.image.capture.ScreenCaptureRequesterImpl.lambda$setOnActivityResultCallback$0(ScreenCaptureRequesterImpl.java:22) org.autojs.autojs.core.image.capture.ScreenCaptureRequesterImpl.$r8$lambda$2v16J-R0oc1CStRvnjP_6lnVRMA(Unknown Source:0) org.autojs.autojs.core.image.capture.ScreenCaptureRequesterImpl$$ExternalSyntheticLambda0.onRequestResult(Unknown Source:4) org.autojs.autojs.core.image.capture.ScreenCaptureRequester$AbstractScreenCaptureRequester.onResult(ScreenCaptureRequester.java:68) org.autojs.autojs.core.image.capture.ScreenCaptureRequester$ActivityScreenCaptureRequester.onActivityResult(ScreenCaptureRequester.java:49) org.autojs.autojs.app.OnActivityResultDelegate$Mediator.onActivityResult(OnActivityResultDelegate.java:30) org.autojs.autojs.core.image.capture.ScreenCaptureRequestActivity.onActivityResult(ScreenCaptureRequestActivity.java:67) android.app.Activity.dispatchActivityResult(Activity.java:8542) android.app.ActivityThread.deliverResults(ActivityThread.java:5474) android.app.ActivityThread.handleSendResult(ActivityThread.java:5520) android.app.servertransaction.ActivityResultItem.execute(ActivityResultItem.java:54) android.app.servertransaction.ActivityTransactionItem.execute(ActivityTransactionItem.java:45) android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135) android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95) android.app.ActivityThread$H.handleMessage(ActivityThread.java:2335) android.os.Handler.dispatchMessage(Handler.java:106) android.os.Looper.loopOnce(Looper.java:210) android.os.Looper.loop(Looper.java:299) android.app.ActivityThread.main(ActivityThread.java:8290) java.lang.reflect.Method.invoke(Native Method) com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:577) com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1073)

11月21日 19:10:29

报错2: Version: 2180 Android: 31 android.os.RemoteException: Remote stack trace: at com.android.server.media.projection.MediaProjectionManagerService$MediaProjection.start(MediaProjectionManagerService.java:557) at android.media.projection.IMediaProjection$Stub.onTransact(IMediaProjection.java:137) at android.os.Binder.execTransactInternal(Binder.java:1190) at android.os.Binder.execTransact(Binder.java:1149)

java.lang.RuntimeException:Failure delivering result ResultInfo{who=null, request=17777, result=-1, data=Intent { (has extras) }} to activity {org.autojs.autojs6/org.autojs.autojs.core.image.capture.ScreenCaptureRequestActivity}: java.lang.SecurityException: Media projections require a foreground service of type ServiceInfo.FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION android.app.ActivityThread.deliverResults(ActivityThread.java:5481) ...... Caused by: android.os.RemoteException:Remote stack trace: at com.android.server.media.projection.MediaProjectionManagerService$MediaProjection.start(MediaProjectionManagerService.java:557) at android.media.projection.IMediaProjection$Stub.onTransact(IMediaProjection.java:137) at android.os.Binder.execTransactInternal(Binder.java:1190) at android.os.Binder.execTransact(Binder.java:1149)

mhsjzsq avatar Nov 20 '23 20:11 mhsjzsq

I also noticed after installation as soon as I flipped the switch for foreground service it crashed. My phone is Samsung S22 Sm-S901W on Android 14 if you need to know for more information

CamsShaft avatar Apr 08 '24 16:04 CamsShaft