在Android中膨胀WebView时出现NullPointerException

时间:2012-11-15 16:01:57

标签: android layout webview nullpointerexception inflate

我试图在我的某个布局中夸大网页浏览时出现这个奇怪的错误

11-15 10:49:30.790: E/AndroidRuntime(18749): FATAL EXCEPTION: main
11-15 10:49:30.790: E/AndroidRuntime(18749): android.view.InflateException: Binary XML file line #9: Error inflating class android.webkit.WebView
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.LayoutInflater.createView(LayoutInflater.java:613)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.LayoutInflater.onCreateView(LayoutInflater.java:660)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.LayoutInflater.rInflate(LayoutInflater.java:746)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.LayoutInflater.inflate(LayoutInflater.java:489)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.LayoutInflater.inflate(LayoutInflater.java:396)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.LayoutInflater.inflate(LayoutInflater.java:352)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at com.philly.prosportsframework.fragments.HomeLauncherFragment.buildView(HomeLauncherFragment.java:317)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at com.philly.prosportsframework.fragments.HomeLauncherFragment$LauncherListAdapter.getView(HomeLauncherFragment.java:299)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.AbsListView.obtainView(AbsListView.java:2267)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.ListView.measureHeightOfChildren(ListView.java:1244)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.ListView.onMeasure(ListView.java:1156)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.View.measure(View.java:15172)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:617)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:399)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.View.measure(View.java:15172)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.View.measure(View.java:15172)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.View.measure(View.java:15172)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.View.measure(View.java:15172)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.View.measure(View.java:15172)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:617)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:399)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.View.measure(View.java:15172)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.View.measure(View.java:15172)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1390)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.LinearLayout.measureVertical(LinearLayout.java:681)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.LinearLayout.onMeasure(LinearLayout.java:574)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.View.measure(View.java:15172)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at com.android.internal.policy.impl.PhoneWindow$DecorView.onMeasure(PhoneWindow.java:2148)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.View.measure(View.java:15172)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:1848)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1100)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1273)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:998)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:4212)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.Choreographer$CallbackRecord.run(Choreographer.java:725)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.Choreographer.doCallbacks(Choreographer.java:555)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.Choreographer.doFrame(Choreographer.java:525)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:711)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.os.Handler.handleCallback(Handler.java:615)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.os.Handler.dispatchMessage(Handler.java:92)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.os.Looper.loop(Looper.java:137)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at android.app.ActivityThread.main(ActivityThread.java:4745)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at java.lang.reflect.Method.invokeNative(Native Method)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at java.lang.reflect.Method.invoke(Method.java:511)
11-15 10:49:30.790: E/AndroidRuntime(18749):    at c
11-15 10:49:30.850: D/dalvikvm(18749): GC_CONCURRENT freed 314K, 6% free 7612K/8071K, paused 13ms+4ms, total 51ms
11-15 10:49:30.850: E/System(18749): Uncaught exception thrown by finalizer
11-15 10:49:30.850: E/System(18749): java.lang.NullPointerException
11-15 10:49:30.850: E/System(18749):    at android.webkit.WebViewClassic.destroyJava(WebViewClassic.java:2087)
11-15 10:49:30.850: E/System(18749):    at android.webkit.WebViewClassic.destroy(WebViewClassic.java:2072)
11-15 10:49:30.850: E/System(18749):    at android.webkit.WebViewClassic.finalize(WebViewClassic.java:4126)
11-15 10:49:30.850: E/System(18749):    at java.lang.Daemons$FinalizerDaemon.doFinalize(Daemons.java:186)
11-15 10:49:30.850: E/System(18749):    at java.lang.Daemons$FinalizerDaemon.run(Daemons.java:169)
11-15 10:49:30.850: E/System(18749):    at java.lang.Thread.run(Thread.java:856)

跟踪中引用的代码行是:

v = LayoutInflater.from(parent.getContext()).inflate(R.layout.home_launcher_item, null);

,布局文件如下所示:

<?xml version="1.0" encoding="utf-8"?>
 <RelativeLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical">


           <WebView
        android:id="@+id/photo" 
        android:layout_width="330dip" 
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"        
        android:background="@drawable/thumb"/>

    <TextView   
        android:id="@+id/title" 
        android:layout_width="fill_parent" 
        android:layout_height="wrap_content"                
        android:layout_above="@+id/byline"
        android:layout_alignRight="@+id/photo"
        android:layout_marginTop="20px"
        android:textColor="#ffffffff"
        android:textSize="25px"
        android:lines="2"
        android:background="#dd000000"/>                

    <TextView   
        android:id="@+id/byline"    
        android:layout_width="fill_parent" 
        android:layout_height="wrap_content"
        android:layout_alignBottom="@+id/photo"
        android:layout_alignRight="@+id/photo"
        android:textColor="#ff565656"
        android:textStyle="italic"
        android:background="#dd000000"/>   
</RelativeLayout>

任何想法都会有所帮助。我正在使用运行Android 4.1.1的Xoom进行测试。

1 个答案:

答案 0 :(得分:0)

可能缺少res/drawable/thumb.png。您需要添加它或更改对现有可绘制资源的引用。

XML布局验证器有时会出错。不要相信他;)