Muszę korzystać z aparatu w mojej aplikacji do pracy, widzę, że w API >= 28 wszystko się zmieniło w porównaniu z tym, jak robiłem to wcześniej, kiedy mogłem użyć startActivityForResult.
Jednak spotykam się z problemem, kiedy uruchamiam aplikację aparatu i od razu pojawia się komunikat o błędzie "TransactionTooLargeException" w konsoli debugowania/uruchomienia.
Do połączenia kamery robię
mGetContent = registerForActivityResult(
new ActivityResultContracts.TakePicture(),
result -> {
if (result) {
}
}
);
Gdzie mGetContent zdefiniowana w klasie jak
private ActivityResultLauncher<Uri> mGetContent;
W moim AndroidManifest.xml plik mam następny
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="com.test.fileprovider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/file_paths" />
</provider>
W moim pliku file_paths mam
<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
<files-path
name="files"
path="."/>
<files-path
name="app_images"
path="./files/"/>
</paths>
W mojej działalności jest skonfigurowany przycisk, za pomocą którego uruchamiam kamerę za pomocą
findViewById(R.id.button)).setOnClickListener(v -> {
File directory = new File(context.getFilesDir(), "app_images");
if (!directory.exists()) directory.mkdir();
File file = new File(directory, "image.jpg");
Uri uri = getUriForFile(this, "com.test.fileprovider", file);
mGetContent.launch(uri);
};
Jak tylko klikam na przycisk i otwiera się aplikacja "Aparat", dostaję to, że mogę tylko przypuszczać, - zbyt ogólny komunikat o błędzie.
E/JavaBinder: !!! FAILED BINDER TRANSACTION !!! (parcel size = 1284092)
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.test, PID: 14296
java.lang.RuntimeException: android.os.TransactionTooLargeException: data parcel size 1284092 bytes
at android.app.servertransaction.PendingTransactionActions$StopInfo.run(PendingTransactionActions.java:161)
at android.os.Handler.handleCallback(Handler.java:883)
at android.os.Handler.dispatchMessage(Handler.java:100)
at android.os.Looper.loop(Looper.java:214)
at android.app.ActivityThread.main(ActivityThread.java:7397)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:935)
Caused by: android.os.TransactionTooLargeException: data parcel size 1284092 bytes
at android.os.BinderProxy.transactNative(Native Method)
at android.os.BinderProxy.transact(BinderProxy.java:511)
at android.app.IActivityTaskManager$Stub$Proxy.activityStopped(IActivityTaskManager.java:4524)
at android.app.servertransaction.PendingTransactionActions$StopInfo.run(PendingTransactionActions.java:145)
Próbowałem szukać w Google, aby znaleźć coś, ale mam problemy z określeniem, na czym polega prawdziwy problem.
Niektóre propozycje podałeś mi na stan onSaveInstanceState, więc переопределил go i ustawia punkt przerwania, aby zobaczyć, co się dzieje, ale to poszło bez żadnych problemów (z tego co mogę powiedzieć).
Mętlik w głowie z tym.