PDFRenderer无法显示文件

时间:2016-06-05 15:49:35

标签: android pdfrenderer

我正在使用API​​ Level 21,而我正在尝试显示从互联网下载的PDF并存储在缓存目录中。

   private void openRenderer(Context context) throws IOException {
    Log.d("NoiPA", "Opening PDF File: " + pdfPath);
    // In this sample, we read a PDF from the assets directory.
    mFileDescriptor = ParcelFileDescriptor.open(new File(pdfPath),ParcelFileDescriptor.MODE_READ_ONLY);
    //mFileDescriptor = context.getAssets().openFd(pdfPath).getParcelFileDescriptor();
    // This is the PdfRenderer we use to render the PDF.
    mPdfRenderer = new PdfRenderer(mFileDescriptor);
}

上面的代码使应用程序崩溃,并显示以下堆栈跟踪:

Download: Completed -> Showing PDF
onAttach -> pdfPath: /data/data/com.vitobellini.noipa/cache/MAG 2016.pdf
Opening PDF File: /data/data/com.vitobellini.noipa/cache/MAG 2016.pdf
java.io.IOException: not create document. Error:
     at android.graphics.pdf.PdfRenderer.nativeCreate(Native Method)
     at android.graphics.pdf.PdfRenderer.<init>(PdfRenderer.java:149)
     at com.vitobellini.noipa.PdfRendererFragment.openRenderer(PdfRendererFragment.java:151)
     at com.vitobellini.noipa.PdfRendererFragment.onAttach(PdfRendererFragment.java:115)
     at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1019)
     at android.support.v4.app.BackStackRecord.setLastIn(BackStackRecord.java:779)
     at android.support.v4.app.BackStackRecord.calculateFragments(BackStackRecord.java:819)
     at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:660)
     at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1617)
     at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:517)
     at android.os.Handler.handleCallback(Handler.java:739)
     at android.os.Handler.dispatchMessage(Handler.java:95)
     at android.os.Looper.loop(Looper.java:135)
     at android.app.ActivityThread.main(ActivityThread.java:5221)
     at java.lang.reflect.Method.invoke(Native Method)
     at java.lang.reflect.Method.invoke(Method.java:372)
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)

我无法向自己解释为什么代码不起作用,有人知道如何修复它吗?

1 个答案:

答案 0 :(得分:2)

根据我的经验,它与您传递给PdfRenderer的文件有关。 如果您能够从保存的完全相同的目录中打开与其他应用程序/库相同的文件,则意味着您应该能够使用PdfRenderer打开它。

此处的官方问题https://github.com/googlesamples/android-PdfRendererBasic/issues/1已关闭,原始记者尚未重新开启。

您可以使用自己的PDF文件尝试完全相同的样本吗?如果它不起作用,那么库存在错误,我建议你用不起作用的文件重新打开该问题。也可以随意使用您的解决方案尝试其他文件(非常简单的文件)。