位图转换为webp给出信号11

时间:2018-11-13 15:28:07

标签: android bitmap webp

当我将位图转换为WEBP格式时,我的Android应用程序出现此错误:

  #00  pc 00000000004125c4  /system/lib/libskia.so
  #01  pc 000000000042e350  /system/lib/libskia.so
  #02  pc 000000000042db78  /system/lib/libskia.so
  #03  pc 000000000042dc60  /system/lib/libskia.so (WebPPictureImportRGBA+36)
  #04  pc 00000000003a1fd0  /system/lib/libskia.so (_ZN18SkWEBPImageEncoder8onEncodeEP9SkWStreamRK8SkBitmapi+444)
  #05  pc 00000000000a216f  /system/lib/libandroid_runtime.so
  #06  pc 0000000001aabea3  /system/framework/arm/boot-framework.oat (android.graphics.Bitmap.nativeCompress+158)
  #07  pc 0000000001aad39b  /system/framework/arm/boot-framework.oat (android.graphics.Bitmap.compress+230)
  #08  pc 00000000000a9e41  /system/lib/libart.so (art_quick_invoke_stub_internal+64)
  #09  pc 00000000004087e1  /system/lib/libart.so (art_quick_invoke_stub+232)
  #10  pc 00000000000b1115  /system/lib/libart.so (_ZN3art9ArtMethod6InvokeEPNS_6ThreadEPjjPNS_6JValueEPKc+136)
  #11  pc 00000000001ef3fd  /system/lib/libart.so (_ZN3art11interpreter34ArtInterpreterToCompiledCodeBridgeEPNS_6ThreadEPNS_9ArtMethodEPKNS_7DexFile8CodeItemEPNS_11ShadowFrameEPNS_6JValueE+200)
  #12  pc 00000000001e99ad  /system/lib/libart.so (_ZN3art11interpreter6DoCallILb0ELb0EEEbPNS_9ArtMethodEPNS_6ThreadERNS_11ShadowFrameEPKNS_11InstructionEtPNS_6JValueE+492)
  #13  pc 0000000000402bb3  /system/lib/libart.so (MterpInvokeVirtualQuick+322)
  #14  pc 00000000000a0a14  /system/lib/libart.so (ExecuteMterpImpl+29972)
  #15  pc 00000000001cc463  /system/lib/libart.so (_ZN3art11interpreterL7ExecuteEPNS_6ThreadEPKNS_7DexFile8CodeItemERNS_11ShadowFrameENS_6JValueEb+290)
  #16  pc 00000000001d0fcb  /system/lib/libart.so (_ZN3art11interpreter33ArtInterpreterToInterpreterBridgeEPNS_6ThreadEPKNS_7DexFile8CodeItemEPNS_11ShadowFrameEPNS_6JValueE+114)
  #17  pc 00000000001e9993  /system/lib/libart.so (_ZN3art11interpreter6DoCallILb0ELb0EEEbPNS_9ArtMethodEPNS_6ThreadERNS_11ShadowFrameEPKNS_11InstructionEtPNS_6JValueE+466)
  #18  pc 0000000000402bb3  /system/lib/libart.so (MterpInvokeVirtualQuick+322)
  #19  pc 00000000000a0a14  /system/lib/libart.so (ExecuteMterpImpl+29972)
  #20  pc 00000000001cc463  /system/lib/libart.so (_ZN3art11interpreterL7ExecuteEPNS_6ThreadEPKNS_7DexFile8CodeItemERNS_11ShadowFrameENS_6JValueEb+290)
  #21  pc 00000000001d0fcb  /system/lib/libart.so (_ZN3art11interpreter33ArtInterpreterToInterpreterBridgeEPNS_6ThreadEPKNS_7DexFile8CodeItemEPNS_11ShadowFrameEPNS_6JValueE+114)
  #22  pc 00000000001e9993  /system/lib/libart.so (_ZN3art11interpreter6DoCallILb0ELb0EEEbPNS_9ArtMethodEPNS_6ThreadERNS_11ShadowFrameEPKNS_11InstructionEtPNS_6JValueE+466)
  #23  pc 0000000000402bb3  /system/lib/libart.so (MterpInvokeVirtualQuick+322)
  #24  pc 00000000000a0a14  /system/lib/libart.so (ExecuteMterpImpl+29972)
  #25  pc 00000000001cc463  /system/lib/libart.so (_ZN3art11interpreterL7ExecuteEPNS_6ThreadEPKNS_7DexFile8CodeItemERNS_11ShadowFrameENS_6JValueEb+290)
  #26  pc 00000000001d0f35  /system/lib/libart.so (_ZN3art11interpreter30EnterInterpreterFromEntryPointEPNS_6ThreadEPKNS_7DexFile8CodeItemEPNS_11ShadowFrameE+92)
  #27  pc 00000000003f7bb3  /system/lib/libart.so (artQuickToInterpreterBridge+706)
  #28  pc 00000000000ae893  /system/lib/libart.so (art_quick_to_interpreter_bridge+34)
  #29  pc 000000000208fc09  /system/framework/arm/boot-framework.oat (android.view.View.performClick+276)
  #30  pc 0000000002109f95  /system/framework/arm/boot-framework.oat (android.view.View$PerformClick.run+40)
  #31  pc 000000000182fbe5  /system/framework/arm/boot-framework.oat (android.os.Handler.handleCallback+48)
  #32  pc 000000000182fc43  /system/framework/arm/boot-framework.oat (android.os.Handler.dispatchMessage+54)
  #33  pc 0000000001e24e39  /system/framework/arm/boot-framework.oat (android.os.Looper.loop+1948)
  #34  pc 00000000018445f3  /system/framework/arm/boot-framework.oat (android.app.ActivityThread.main+814)
  #35  pc 00000000000a9e41  /system/lib/libart.so (art_quick_invoke_stub_internal+64)
  #36  pc 00000000004088e9  /system/lib/libart.so (art_quick_invoke_static_stub+228)
  #37  pc 00000000000b113f  /system/lib/libart.so (_ZN3art9ArtMethod6InvokeEPNS_6ThreadEPjjPNS_6JValueEPKc+178)
  #38  pc 0000000000318d21  /system/lib/libart.so (_ZN3artL18InvokeWithArgArrayERKNS_33ScopedObjectAccessAlreadyRunnableEPNS_9ArtMethodEPNS_8ArgArrayEPNS_6JValueEPKc+56)
  #39  pc 000000000031a0b3  /system/lib/libart.so (_ZN3art12InvokeMethodERKNS_33ScopedObjectAccessAlreadyRunnableEP8_jobjectS4_S4_j+766)
  #40  pc 00000000002c12d5  /system/lib/libart.so (_ZN3artL13Method_invokeEP7_JNIEnvP8_jobjectS3_S3_+40)
  #41  pc 00000000005ae931  /system/framework/arm/boot-core-oj.oat (java.lang.reflect.Method.invoke+116)
  #42  pc 000000000236cf89  /system/framework/arm/boot-framework.oat (com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run+100)
  #43  pc 000000000236e3df  /system/framework/arm/boot-framework.oat (com.android.internal.os.ZygoteInit.main+1978)
  #44  pc 00000000000a9e41  /system/lib/libart.so (art_quick_invoke_stub_internal+64)
  #45  pc 00000000004088e9  /system/lib/libart.so (art_quick_invoke_static_stub+228)
  #46  pc 00000000000b113f  /system/lib/libart.so (_ZN3art9ArtMethod6InvokeEPNS_6ThreadEPjjPNS_6JValueEPKc+178)
  #47  pc 0000000000318d21  /system/lib/libart.so (_ZN3artL18InvokeWithArgArrayERKNS_33ScopedObjectAccessAlreadyRunnableEPNS_9ArtMethodEPNS_8ArgArrayEPNS_6JValueEPKc+56)
  #48  pc 0000000000318b33  /system/lib/libart.so (_ZN3art17InvokeWithVarArgsERKNS_33ScopedObjectAccessAlreadyRunnableEP8_jobjectP10_jmethodIDSt9__va_list+266)
  #49  pc 000000000027b61f  /system/lib/libart.so (_ZN3art3JNI21CallStaticVoidMethodVEP7_JNIEnvP7_jclassP10_jmethodIDSt9__va_list+426)
  #50  pc 000000000006837d  /system/lib/libandroid_runtime.so
  #51  pc 0000000000069c63  /system/lib/libandroid_runtime.so (_ZN7android14AndroidRuntime5startEPKcRKNS_6VectorINS_7String8EEEb+498)
  #52  pc 000000000000199f  /system/bin/app_process32
  #53  pc 0000000000016d8d  /system/lib/libc.so (__libc_init+48)
  #54  pc 00000000000015bc  /system/bin/app_process32

我不知道确切的错误发生位置,但我的猜测是当我尝试在此处尝试将位图压缩为WEBP格式时:

public String saveImage(String id, Bitmap bitmap) {
    if(bitmap != null) {
        File folder = new File(getFilesDir() + "/packs", id);
        if (!folder.exists())
            folder.mkdirs();
        String stickerName = "sticker" + String.valueOf(TimeUnit.MILLISECONDS.toSeconds(System.currentTimeMillis())) + ".webp";
        File filename = new File(folder, stickerName);
        try {
            if (!filename.exists())
                filename.createNewFile();
            FileOutputStream out = new FileOutputStream(filename);
            bitmap.compress(Bitmap.CompressFormat.WEBP, 100, out);
            out.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return stickerName;
    } else {
        return null;
    }
}

位图是在我的自定义视图中创建的,然后保存为WEBP,但是每次尝试都会给我一个错误。正如我说的,我不知道如何调试此错误消息,所以如果我完全错了,请说。

谢谢!

2 个答案:

答案 0 :(得分:1)

所以我最终使用libwebp而不是Bitmap.compress(Bitmap.CompressFormat.WEBP, 100, out);,现在可以正常使用了。这是有关如何使用libwebp http://masashi-k.blogspot.com/2014/02/webp-in-android.html的教程。

答案 1 :(得分:0)

编辑:最终给了我同样的错误。我将尝试您发布的解决方案。

Android Compressor Library添加到您的build.gradle中,然后复制并粘贴此函数(如果您有Bitmap

public static void saveBitmap(String folder, String imageName, Bitmap bitmap, Context context) throws IOException {
        File temp = new File(folder, "temp_" + imageName);

        try (OutputStream stream = new FileOutputStream(temp)) {
            bitmap.compress(Bitmap.CompressFormat.PNG, 100, stream);
        }

        new Compressor(context)
                .setQuality(90)
                .setCompressFormat(Bitmap.CompressFormat.WEBP)
                .setDestinationDirectoryPath(folder) // Saving in the same folder temp file is at
                .compressToFile(temp, imageName); // Takes the temp file and creates a new one with the name passed as second argument

        temp.delete(); // Deleting temp file

    }

如果您想知道为什么在保存所需的PNG之前先保存一个临时WEBP文件,那是因为该库没有使用Bitmap作为参数,所以它只能工作与File

该库记录了一个错误,指出“文件应为JPEG”,但到目前为止,它仍然可以正常工作,PNG alpha通道仍保留在WEBP中,因此我忽略了该错误。