2011-01-05 68 views
6

我有時會在我的應用程序中獲得上述錯誤報告。我在開發和測試過程中從未看到這個錯誤。應用程序是2.1和更高版本。我測試了2.1,2.2和2.3(仿真器)和真實設備(除了2.3)。有時:<nine-patch>需要有效的src屬性

下面是產生這種錯誤的佈局文件的一部分(該視圖是TableLayout的一部分):

<TextView 
style="@style/ActivityTitleBar" 
android_layout_span="2" 
android:layout_weight="2" 
android:text="@string/txt_appname" /> 

這裏的樣式定義:

<style name="ActivityTitleBar"> 
<item name="android:background">@drawable/titlebar</item> 
<item name="android:gravity">center</item> 
<item name="android:layout_height">wrap_content</item> 
<item name="android:layout_width">fill_parent</item> 
<item name="android:singleLine">true</item> 
<item name="android:textColor">#fff</item> 
<item name="android:textSize">14sp</item> 
<item name="android:textStyle">bold</item> 
</style> 

在res /可繪是一個包含此內容的XML文件:

<nine-patch 
xmlns:android="http://schemas.android.com/apk/res/android" 
android:dither="true" 
android:src="@drawable/titlebar" /> 

titlebar.png位於我的drawable-hdpi,drawable-ld pi和drawable-mdpi文件夾。

我不知道什麼設備或Android版本導致此錯誤。

任何想法?

非常感謝提前。

HJW

這裏的堆棧跟蹤報告:

java.lang.RuntimeException: Unable to start activity ComponentInfo{de.x.y.android/de.x.y.android.Main}: android.view.InflateException: Binary XML file line #18: Error inflating class android.widget.TextView 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2781) 
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2797) 
at android.app.ActivityThread.access$2300(ActivityThread.java:135) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2132) 
at android.os.Handler.dispatchMessage(Handler.java:99) 
at android.os.Looper.loop(Looper.java:143) 
at android.app.ActivityThread.main(ActivityThread.java:4914) 
at java.lang.reflect.Method.invokeNative(Native Method) 
at java.lang.reflect.Method.invoke(Method.java:521) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 
at dalvik.system.NativeStart.main(Native Method) 
Caused by: android.view.InflateException: Binary XML file line #18: Error inflating class android.widget.TextView 
at android.view.LayoutInflater.createView(LayoutInflater.java:513) 
at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56) 
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:563) 
at android.view.LayoutInflater.rInflate(LayoutInflater.java:618) 
at android.view.LayoutInflater.rInflate(LayoutInflater.java:621) 
at android.view.LayoutInflater.rInflate(LayoutInflater.java:621) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:407) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:320) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:276) 
at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:207) 
at android.app.Activity.setContentView(Activity.java:1654) 
at de.x.y.android.MyActivity.onCreate(MyActivity.java:46) 
at de.X.Y.android.Main.onCreate(Main.java:190) 
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1065) 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2745) 
... 11 more 
Caused by: java.lang.reflect.InvocationTargetException 
at android.widget.TextView.<init>(TextView.java:332) 
at java.lang.reflect.Constructor.constructNative(Native Method) 
at java.lang.reflect.Constructor.newInstance(Constructor.java:446) 
at android.view.LayoutInflater.createView(LayoutInflater.java:500) 
... 25 more 
Caused by: android.content.res.Resources$NotFoundException: File res/drawable/titlebar.xml from drawable resource ID #0x7f020003 
at android.content.res.Resources.loadDrawable(Resources.java:1697) 
at android.content.res.TypedArray.getDrawable(TypedArray.java:601) 
at android.view.View.<init>(View.java:1885) 
at android.widget.TextView.<init>(TextView.java:338) 
... 29 more 
Caused by: org.xmlpull.v1.XmlPullParserException: Binary XML file line #3: <nine-patch> requires a valid src attribute 
at android.graphics.drawable.NinePatchDrawable.inflate(NinePatchDrawable.java:262) 
at android.graphics.drawable.Drawable.createFromXmlInner(Drawable.java:788) 
at android.graphics.drawable.Drawable.createFromXml(Drawable.java:729) 
at android.content.res.Resources.loadDrawable(Resources.java:1694) 
... 32 more 
+0

最後是你做了什麼解決方案? – Kalpesh 2012-07-19 04:39:54

+0

[分享此文](http://stackoverflow.com/questions/37700777/android-api-21-9patch-error)和可能的[谷歌Bug報告](https://code.google.com/p/android/issues/detail?id = 210467) – 2016-11-08 08:09:01

回答

2

不能可靠地兼得titlebar.xmltitlebar.png。請重命名一個具有不同的基本名稱。

+0

謝謝 - 會改變這一點。然而,它爲我和我的客戶在很多不同的設備和仿真器上工作。在所有這些月份裏有兩個錯誤的原因是什麼? – 2011-01-05 15:49:17

+0

@hjw:純粹的運氣,AFAIK。 – CommonsWare 2011-01-05 15:51:13

+0

將png重命名爲其他名稱並更改xml文件中的條目後,我現在也收到錯誤。現在我完全迷失了。如果兩個名稱都相同,並且所有客戶都收到此錯誤(如果名稱不同),則很少有客戶會收到此錯誤。精氨酸! – 2011-01-05 16:28:31

-1

我有同樣的問題。我解決了在頂部添加黑色部分並留下1條像素線的問題。我試圖讓它們保持透明以避免圖像縮放,但不起作用。

相關問題