2014-08-28 148 views
0

我今天在AppCompatv7的Android項目中替換了ActionBarSherlock,並遷移了所有需要的東西。現在,當一個ListActivity的適配器要infalte的XML,我得到InflateExceptionInflateException在遷移到AppCompat後

08-28 15:47:10.567: E/AndroidRuntime(32352): FATAL EXCEPTION: main 
08-28 15:47:10.567: E/AndroidRuntime(32352): Process: com.sophos.smenc, PID: 32352 
08-28 15:47:10.567: E/AndroidRuntime(32352): android.view.InflateException: Binary XML file line #10: Error inflating class <unknown> 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.LayoutInflater.createView(LayoutInflater.java:620) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.LayoutInflater.onCreateView(LayoutInflater.java:669) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:694) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.LayoutInflater.rInflate(LayoutInflater.java:755) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.LayoutInflater.inflate(LayoutInflater.java:492) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.LayoutInflater.inflate(LayoutInflater.java:397) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at com.sophos.smenc.ui.adapter.SectionFileListAdapter.getView(SectionFileListAdapter.java:221) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.AbsListView.obtainView(AbsListView.java:2255) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.ListView.makeAndAddView(ListView.java:1790) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.ListView.fillDown(ListView.java:691) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.ListView.fillFromTop(ListView.java:752) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.ListView.layoutChildren(ListView.java:1630) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.AbsListView.onLayout(AbsListView.java:2087) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.View.layout(View.java:14817) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.ViewGroup.layout(ViewGroup.java:4631) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1671) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1525) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.LinearLayout.onLayout(LinearLayout.java:1434) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.View.layout(View.java:14817) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.ViewGroup.layout(ViewGroup.java:4631) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.FrameLayout.onLayout(FrameLayout.java:388) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.View.layout(View.java:14817) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.ViewGroup.layout(ViewGroup.java:4631) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1671) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.LinearLayout.layoutHorizontal(LinearLayout.java:1660) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.LinearLayout.onLayout(LinearLayout.java:1436) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.View.layout(View.java:14817) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.ViewGroup.layout(ViewGroup.java:4631) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.FrameLayout.onLayout(FrameLayout.java:388) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.View.layout(View.java:14817) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.ViewGroup.layout(ViewGroup.java:4631) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at com.android.internal.widget.ActionBarOverlayLayout.onLayout(ActionBarOverlayLayout.java:374) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.View.layout(View.java:14817) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.ViewGroup.layout(ViewGroup.java:4631) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.widget.FrameLayout.onLayout(FrameLayout.java:388) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.View.layout(View.java:14817) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.ViewGroup.layout(ViewGroup.java:4631) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.ViewRootImpl.performLayout(ViewRootImpl.java:1983) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1740) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:996) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5600) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:761) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.Choreographer.doCallbacks(Choreographer.java:574) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.Choreographer.doFrame(Choreographer.java:544) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:747) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.os.Handler.handleCallback(Handler.java:733) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.os.Handler.dispatchMessage(Handler.java:95) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.os.Looper.loop(Looper.java:136) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.app.ActivityThread.main(ActivityThread.java:5001) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at java.lang.reflect.Method.invokeNative(Native Method) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at java.lang.reflect.Method.invoke(Method.java:515) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at dalvik.system.NativeStart.main(Native Method) 
08-28 15:47:10.567: E/AndroidRuntime(32352): Caused by: java.lang.reflect.InvocationTargetException 
08-28 15:47:10.567: E/AndroidRuntime(32352): at java.lang.reflect.Constructor.constructNative(Native Method) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at java.lang.reflect.Constructor.newInstance(Constructor.java:423) 
08-28 15:47:10.567: E/AndroidRuntime(32352): at android.view.LayoutInflater.createView(L 

我還沒有在適配器改變任何東西,因爲我可以看到,當我刪除

android:background="?activatableItemBackground" 

它的工作原理。你有什麼想法是什麼問題,我正在研究幾個小時,但我只能想到一個Android錯誤。

這是我attrs.xml

<resources> 

    <attr name="state_red" format="boolean" /> 
    <attr name="state_yellow" format="boolean" /> 
    <!-- 
    The ListItems reference this as background. In the styles.xml is this reference linked to an xml selector that controls 
    the color of the view according to states. 
    --> 
    <declare-styleable name="BaseTheme"> 
     <attr name="activatableItemBackground" format="reference" /> 
    </declare-styleable> 

</resources> 
+0

請您發佈完整的logcat輸出嗎?此外,'?activatableItemBackground'是你的應用程序的自定義屬性? – reVerse 2014-08-28 14:03:52

回答

0

與往常一樣,問你自己得到解決後很短的時間:這個問題真的很奇怪,我在styles.xml我以下:

<!-- Immediate parent theme to specify base values for custom attributes --> 
<style name="Theme.Base" parent="FrameworkRoot.Theme"> 

    <!-- Defines the selector for the row view --> 
    <item name="activatableItemBackground">@drawable/dna_list_selector_holo_light</item> 
</style> 

讀書的地方,名字衝突之後在風格可能我通過Custom_Base_Thme改變Theme.Base和現在的作品,這是我做出的唯一改變。