尝试在AndroidPdfViewer中调用虚拟方法崩溃

时间:2018-01-18 11:16:35

标签: pdf nullpointerexception virtual-method androidpdfviewer

使用AndroidPdfViewer包。 我的build.gradle代码:

dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'com.android.support:appcompat-v7:26.1.0'
implementation 'com.android.support.constraint:constraint-layout:1.0.2'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.1'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
implementation("com.github.bumptech.glide:glide:4.5.0") {
    exclude group: "com.android.support"
}
implementation "com.android.support:support-fragment:26.1.0"
compile 'com.github.barteksc:android-pdf-viewer:2.8.2'

}

活动XML文件:

    <?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/linearLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <com.github.barteksc.pdfviewer.PDFView
        android:id="@+id/pdfView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_centerInParent="true"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
</android.support.constraint.ConstraintLayout>

活动代码:

package eu.myapp.myapp;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

import com.github.barteksc.pdfviewer.PDFView;

public class activity_fact_sheet extends AppCompatActivity {

    PDFView pdfView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        PDFView pdfView = (PDFView) findViewById(R.id.pdfView);
        pdfView.fromAsset("file2.pdf").load();
    }
}
位于app&gt;中的

file2.pdf src&gt;主要&gt;资产

运行时出错:

01-18 11:59:25.475 29674-29674/eu.myapp.myapp E/AndroidRuntime: FATAL EXCEPTION: main
                                                                        Process: eu.myapp.myapp, PID: 29674
                                                                        java.lang.RuntimeException: Unable to start activity ComponentInfo{eu.myapp.myapp/eu.myapp.myapp.activity_fact_sheet}: java.lang.NullPointerException: Attempt to invoke virtual method 'com.github.barteksc.pdfviewer.PDFView$Configurator com.github.barteksc.pdfviewer.PDFView.fromAsset(java.lang.String)' on a null object reference
                                                                            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2924)
                                                                            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2985)
                                                                            at android.app.ActivityThread.-wrap14(ActivityThread.java)
                                                                            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1635)
                                                                            at android.os.Handler.dispatchMessage(Handler.java:102)
                                                                            at android.os.Looper.loop(Looper.java:154)
                                                                            at android.app.ActivityThread.main(ActivityThread.java:6692)
                                                                            at java.lang.reflect.Method.invoke(Native Method)
                                                                            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1468)
                                                                            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1358)
                                                                         Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'com.github.barteksc.pdfviewer.PDFView$Configurator com.github.barteksc.pdfviewer.PDFView.fromAsset(java.lang.String)' on a null object reference
                                                                            at eu.myapp.myapp.activity_fact_sheet.onCreate(activity_fact_sheet.java:17)
                                                                            at android.app.Activity.performCreate(Activity.java:6912)
                                                                            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1126)
                                                                            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2877)
                                                                            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2985) 
                                                                            at android.app.ActivityThread.-wrap14(ActivityThread.java) 
                                                                            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1635) 
                                                                            at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                                            at android.os.Looper.loop(Looper.java:154) 
                                                                            at android.app.ActivityThread.main(ActivityThread.java:6692) 
                                                                            at java.lang.reflect.Method.invoke(Native Method) 
                                                                            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1468) 
                                                                            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1358) 

解决它的步骤:

PDFView pdfView;添加到@Override以上public class activity_fact_sheet extends AppCompatActivity {下的活动代码 还检查了我的活动开放方法是否存在问题(它不是)。

似乎错误在活动代码中的pdfView.fromAsset("file2.pdf").load();上抛出。这让我觉得它在资产中找不到file2.pdf,但我可能错了。

当您尝试打开活动时,应用程序崩溃。

尝试使用this视频实现它。

2 个答案:

答案 0 :(得分:0)

好的,我在stackexchange上找到了另一个主题(除了nullpointer异常上的无数个 - 这对我没有帮助)。 This有适用的代码。只需导入

compile 'com.github.barteksc:android-pdf-viewer:2.8.2'

compile 'org.apache.commons:commons-collections4:4.1'
你的gradle构建文件中的

然后确保您在AndroidManifest.xml中拥有<uses-permission android:name="android.permission.WRITE_SETTINGS"/>权限。 (无论如何你应该已经有了这个。)

然后确保将您的代码复制到您要显示PDF的活动中。将public static final string SAMPLE_FILE更改为您要显示的实际pdf(在您的资源文件夹中)。

如果TAG中的Log.e(TAG, String.format("%s %s, p %d", sep, b.getTitle(), b.getPageIdx()));收到错误,则必须在private static final String TAG = "youractivitynamehere";

下添加public static final String SAMPLE_FILE = "yourfilehere.pdf";

这就是全部!希望其他任何人都能找到这个问题。

答案 1 :(得分:-1)

将此代码添加到您的 XML 文件中

<com.github.barteksc.pdfviewer.PDFView
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/pdfView"
></com.github.barteksc.pdfviewer.PDFView>