2

我從幾個用戶那裏得到這個崩潰報告。他們正在使用三星SPH-M840 Android版本4.1。我正在充氣的佈局是一個簡單的FrameLayout,裏面有一個fragment標籤。我正在使用actionbar-compat。ActionBarView充氣崩潰

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.customprogrammingsolutions.ShabbosAlarm\/com.cpsolutions.alarmbase.alarm.AlarmMainActivity}: android.view.InflateException: Binary XML file line #30: Error inflating class com.android.internal.widget.ActionBarView 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2062) 
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2087) 
    at android.app.ActivityThread.access$600(ActivityThread.java:133) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1198) 
    at android.os.Handler.dispatchMessage(Handler.java:99) 
    at android.os.Looper.loop(Looper.java:137) 
    at android.app.ActivityThread.main(ActivityThread.java:4777) 
    at java.lang.reflect.Method.invokeNative(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:511) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:998) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:765) 
    at dalvik.system.NativeStart.main(Native Method) 
Caused by: android.view.InflateException: Binary XML file line #30: Error inflating class com.android.internal.widget.ActionBarView 
    at android.view.LayoutInflater.createView(LayoutInflater.java:619) 
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:693) 
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:752) 
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:760) 
    at android.view.LayoutInflater.inflate(LayoutInflater.java:495) 
    at android.view.LayoutInflater.inflate(LayoutInflater.java:397) 
    at android.view.LayoutInflater.inflate(LayoutInflater.java:353) 
    at com.android.internal.policy.impl.PhoneWindow.generateLayout(PhoneWindow.java:3298) 
    at com.android.internal.policy.impl.PhoneWindow.installDecor(PhoneWindow.java:3358) 
    at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:314) 
    at android.app.Activity.setContentView(Activity.java:1901) 
    at android.support.v7.app.ActionBarActivity.superSetContentView(ActionBarActivity.java:208) 
    at android.support.v7.app.ActionBarActivityDelegateICS.setContentView(ActionBarActivityDelegateICS.java:111) 
    at android.support.v7.app.ActionBarActivity.setContentView(ActionBarActivity.java:76) 
    at com.cpsolutions.alarmbase.alarm.AlarmMainActivity.onCreate(AlarmMainActivity.java:57) 
    at android.app.Activity.performCreate(Activity.java:5042) 
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094) 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2026) 
    ... 11 more 
Caused by: java.lang.reflect.InvocationTargetException 
    at java.lang.reflect.Constructor.constructNative(Native Method) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:417) 
    at android.view.LayoutInflater.createView(LayoutInflater.java:593) 
    ... 28 more 
Caused by: android.view.InflateException: Binary XML file line #36: Error inflating class android.widget.TextView 
    at android.view.LayoutInflater.createView(LayoutInflater.java:619) 
    at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56) 
    at android.view.LayoutInflater.onCreateView(LayoutInflater.java:666) 
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:691) 
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:752) 
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:760) 
    at android.view.LayoutInflater.inflate(LayoutInflater.java:495) 
    at android.view.LayoutInflater.inflate(LayoutInflater.java:397) 
    at com.android.internal.widget.ActionBarView.initTitle(ActionBarView.java:834) 
    at com.android.internal.widget.ActionBarView.setDisplayOptions(ActionBarView.java:631) 
    at com.android.internal.widget.ActionBarView.<init>(ActionBarView.java:265) 
    ... 31 more 
Caused by: java.lang.reflect.InvocationTargetException 
    at java.lang.reflect.Constructor.constructNative(Native Method) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:417) 
    at android.view.LayoutInflater.createView(LayoutInflater.java:593) 
    ... 41 more 
Caused by: java.lang.NullPointerException 
    at android.server.BluetoothPanProfileHandler.createNewTetheringAddressLocked(BluetoothPanProfileHandler.java:332) 
    at android.text.method.SingleLineTransformationMethod.<init>(SingleLineTransformationMethod.java:33) 
    at android.text.method.SingleLineTransformationMethod.getInstance(SingleLineTransformationMethod.java:57) 
    at android.widget.TextView.applySingleLine(TextView.java:7147) 
    at android.widget.TextView.<init>(TextView.java:1208) 
    at android.widget.TextView.<init>(TextView.java:606) 
    ... 44 more 

編輯:這裏的XML和onCreateAlarmMainActivity的:

<?xml version="1.0" encoding="utf-8"?> 
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent"> 
    <fragment class="com.cpsolutions.alarmbase.alarm.AlarmListFragment" 
      android:id="@+id/alarm_list_frag" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent"/> 
</FrameLayout> 

@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 

    alarmFrag = (AlarmListFragment) getSupportFragmentManager().findFragmentById(R.id.alarm_list_frag); 
    preferenceFrag = (AlarmPreferenceFragment) getSupportFragmentManager().findFragmentById(R.id.preference_list_frag); 
    if(preferenceFrag != null) { 
     isTwoPane = true; 
    } 
} 
+0

這是否得到解決? – Alexis

回答

0

你有NullPointerException

android.server.BluetoothPanProfileHandler.createNewTetheringAddressLocked(BluetoothPanProfileHandler.java: 332)

+0

這就是Android代碼。我什麼都不接觸任何藍牙。 – Eliezer

0

沒有與佈局文件中使用的一個問題:

com.cpsolutions.alarmbase.alarm.AlarmMainActivity.java 

在第57行會有一個setContentView的說法R.layout. {插入此名}

轉到res/layout/ {插入這裏命名}.xml並解決該問題。

如果您需要幫助,請在此處發佈XML文件。


編輯:

的錯誤是因爲它不能膨脹ActionBarView。請發佈類聲明。 (它繼承或extends

+0

如果您仔細閱讀跟蹤,可以看到它與我的XML無關。當一個內部的ActionBarView被實例化時拋出異常,特定的異常是從'BluetoothPanProfileHandler.createNewTetheringAddressLocked'方法拋出的NPE。 – Eliezer

+0

這個異常是由'singleLine =「true」造成的' – 2014-02-10 06:55:26

+0

這只是一個不幸的副作用 – 2014-02-10 06:56:25