2016-06-05 24 views
5

Używam interfejsu API poziomu 21 i próbuję wyświetlić plik PDF pobrany z Internetu i zapisany w katalogu pamięci podręcznej. powyżejPDFRenderer nie może wyświetlić pliku

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); 
} 

Kod aplikacji sprawia, że ​​zderzenie z poniższego śladu stosu:

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) 

Nie mogę wytłumaczyć sobie, dlaczego ten kod nie działa, ktoś wie jak to naprawić?

Odpowiedz

2

Z mojego doświadczenia wynika, że ​​ma to związek z plikiem przekazywanym do obiektu PdfRenderer. Jeśli możesz otworzyć ten sam plik z inną aplikacją/biblioteką z dokładnie tego samego katalogu, który zapisujesz, oznacza to, że powinieneś móc otworzyć go za pomocą PdfRenderer.

Oficjalny numer tutaj https://github.com/googlesamples/android-PdfRendererBasic/issues/1 został zamknięty, a oryginalny reporter nie otworzył go ponownie.

Czy możesz wypróbować dokładnie tę samą próbkę z własnym plikiem PDF? Jeśli to nie zadziała, to jest błąd z biblioteką i proponuję ponowne otwarcie tego problemu z plikiem, który nie działa. Możesz także wypróbować inne pliki za pomocą swojego rozwiązania (bardzo proste pliki).