TransactionTooLargeException в API 28+ при совместном использовании растрового изображения, несмотря на использование Intent.EXTRA_STREAM - PullRequest
0 голосов
/ 02 июня 2019

Я пытаюсь поделиться растровым изображением через намерение для всех приложений, которые могут обрабатывать изображения. Несмотря на то, что следовал инструкциям в нескольких ответах переполнения стека, таких как этот и для разработчиков Android мой код выдает как TransactionTooLargeException на API 28+ и на некоторых устройствах ниже. Несмотря на то, что я всегда использую Intent.EXTRA_STREAM и никогда не отправляю bitmap direclty.

  1. Мой первый простой подход:
         val intent = Intent(Intent.ACTION_SEND).apply {
                type = "image/jpeg"
                putExtra(Intent.EXTRA_STREAM, getImageUri(context!!, bitmap))
            }
            startActivity(Intent.createChooser(intent, "Share image"))



     fun getImageUri(inContext: Context, inImage: Bitmap): Uri {
    val bytes = ByteArrayOutputStream()
    inImage.compress(Bitmap.CompressFormat.JPEG, 100, bytes)
    val path = MediaStore.Images.Media.insertImage(inContext.contentResolver, inImage, "Title", null)
    return Uri.parse(path) }
  1. Я также пытался получить URI через провайдера:

        <meta-data
            android:name="android.support.FILE_PROVIDER_PATHS"
            android:resource="@xml/provider_paths"
            tools:replace="android:resource" />
    </provider>
    

provider_paths.xml:

<paths xmlns:android="http://schemas.android.com/apk/res/android">
<files-path name="external_files" path="."/>
<cache-path name="external_files" path="."/>
<cache-path name="shared_images" path="images/"/>
<external-path name="external_files" path="."/>
<external-files-path name="external_files" path="."/>
<external-cache-path name="external_files" path="."/>

Получить URI, продолжить, как в 1.:

  val uri = FileProvider.getUriForFile(it.activity, "...", file)

Stacktrace, исходящий из моего 1. подхода:

    2019-06-02 17:10:51.255 19592-19592/... E/JavaBinder: !!! FAILED BINDER TRANSACTION !!!  (parcel size = 9344028)
2019-06-02 17:10:51.292 19592-19592/... E/AndroidRuntime: FATAL EXCEPTION: main
    Process: ..., PID: 19592
    java.lang.RuntimeException: android.os.TransactionTooLargeException: data parcel size 9344028 bytes
        at android.app.ActivityThread$StopInfo.run(ActivityThread.java:3998)
        at android.os.Handler.handleCallback(Handler.java:794)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:176)
        at android.app.ActivityThread.main(ActivityThread.java:6635)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:547)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:823)
     Caused by: android.os.TransactionTooLargeException: data parcel size 9344028 bytes
        at android.os.BinderProxy.transactNative(Native Method)
        at android.os.BinderProxy.transact(Binder.java:774)
        at android.app.IActivityManager$Stub$Proxy.activityStopped(IActivityManager.java:4723)
        at android.app.ActivityThread$StopInfo.run(ActivityThread.java:3982)
        at android.os.Handler.handleCallback(Handler.java:794) 
        at android.os.Handler.dispatchMessage(Handler.java:99) 
        at android.os.Looper.loop(Looper.java:176) 
        at android.app.ActivityThread.main(ActivityThread.java:6635) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:547) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:823) 

PS: я добавил <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> к моему манифесту

...