2013-11-22 58 views
2

每當我的應用程序嘗試顯示一個對話框片段時,出現以下錯誤或類似的錯誤,或特定佈局:android.view.InflateException:二進制XML文件行#51:錯誤充氣類com.android.internal.widget.DialogTitle

11-22 10:20:48.993: E/AndroidRuntime(15514): FATAL EXCEPTION: main 
11-22 10:20:48.993: E/AndroidRuntime(15514): android.view.InflateException: Binary XML file line #51: Error inflating class com.android.internal.widget.DialogTitle 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.view.LayoutInflater.createView(LayoutInflater.java:613) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:687) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.view.LayoutInflater.rInflate(LayoutInflater.java:746) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.view.LayoutInflater.rInflate(LayoutInflater.java:749) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.view.LayoutInflater.rInflate(LayoutInflater.java:749) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.view.LayoutInflater.inflate(LayoutInflater.java:489) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.view.LayoutInflater.inflate(LayoutInflater.java:396) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.view.LayoutInflater.inflate(LayoutInflater.java:352) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:313) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at com.android.internal.app.AlertController.installContent(AlertController.java:241) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.app.AlertDialog.onCreate(AlertDialog.java:336) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.app.Dialog.dispatchOnCreate(Dialog.java:351) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.app.Dialog.show(Dialog.java:256) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.support.v4.app.DialogFragment.onStart(DialogFragment.java:385) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.support.v4.app.Fragment.performStart(Fragment.java:1484) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:941) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1088) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1444) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:429) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.os.Handler.handleCallback(Handler.java:615) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.os.Handler.dispatchMessage(Handler.java:92) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.os.Looper.loop(Looper.java:137) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.app.ActivityThread.main(ActivityThread.java:4921) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at java.lang.reflect.Method.invokeNative(Native Method) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at java.lang.reflect.Method.invoke(Method.java:511) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:794) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at dalvik.system.NativeStart.main(Native Method) 
11-22 10:20:48.993: E/AndroidRuntime(15514): Caused by: java.lang.reflect.InvocationTargetException 
11-22 10:20:48.993: E/AndroidRuntime(15514): at java.lang.reflect.Constructor.constructNative(Native Method) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at java.lang.reflect.Constructor.newInstance(Constructor.java:417) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.view.LayoutInflater.createView(LayoutInflater.java:587) 
11-22 10:20:48.993: E/AndroidRuntime(15514): ... 28 more 
11-22 10:20:48.993: E/AndroidRuntime(15514): Caused by: java.lang.ArrayIndexOutOfBoundsException: length=43; index=82 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.content.res.StringBlock.get(StringBlock.java:64) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.content.res.XmlBlock$Parser.getPooledString(XmlBlock.java:458) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.content.res.TypedArray.loadStringValueAt(TypedArray.java:720) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.content.res.TypedArray.getText(TypedArray.java:96) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.widget.TextView.<init>(TextView.java:848) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at android.widget.TextView.<init>(TextView.java:588) 
11-22 10:20:48.993: E/AndroidRuntime(15514): at com.android.internal.widget.DialogTitle.<init>(DialogTitle.java:38) 
11-22 10:20:48.993: E/AndroidRuntime(15514): ... 31 more 

我想顯示的佈局是:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" > 

    <RelativeLayout 
     android:id="@+id/titlelay" 
     android:layout_width="match_parent" 
     android:layout_height="@dimen/titlebar" 
     android:background="@color/green" 
     android:padding="@dimen/small" > 

     <TextView 
      android:id="@+id/textView8" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_centerInParent="true" 
      android:textSize="@dimen/text_big" 
      android:textStyle="bold" /> 

     <Button 
      android:id="@+id/problem_button" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_alignParentRight="true" 
      android:layout_alignParentTop="true" 
      android:layout_marginRight="@dimen/ten_pad" 
      android:background="#F00" 
      android:textSize="@dimen/text_medium" 
      android:visibility="gone" /> 

     <Button 
      android:id="@+id/logout_button" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_alignParentLeft="true" 
      android:layout_alignParentTop="true" 
      android:layout_marginLeft="16dp" 
      android:textSize="@dimen/text_medium" /> 
    </RelativeLayout> 

    <!-- Login form --> 

    <TextView 
     android:id="@+id/warning_text" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_below="@+id/titlelay" 
     android:layout_gravity="center_horizontal" 
     android:textColor="#FFF" 
     android:visibility="gone" /> 

    <LinearLayout 
     android:layout_width="match_parent" 
     android:layout_height="fill_parent" 
     android:layout_below="@+id/warning_text" 
     android:layout_margin="@dimen/padding_value" 
     android:gravity="center_vertical" 
     android:orientation="vertical" 
     android:padding="@dimen/padding_value" > 

     <Button 
      android:id="@+id/herds_button" 
      android:layout_width="match_parent" 
      android:layout_height="0dp" 
      android:layout_gravity="center_horizontal" 
      android:layout_marginBottom="@dimen/twenty" 
      android:layout_weight="1" 
      android:textSize="@dimen/text_medium" 
      android:textStyle="bold" /> 

     <Button 
      android:id="@+id/livestock" 
      android:layout_width="match_parent" 
      android:layout_height="0dp" 
      android:layout_gravity="center_horizontal" 
      android:layout_marginBottom="@dimen/twenty" 
      android:layout_weight="1" 
      android:textSize="@dimen/text_medium" 
      android:textStyle="bold" /> 

     <Button 
      android:id="@+id/addHoldings" 
      android:layout_width="match_parent" 
      android:layout_height="0dp" 
      android:layout_gravity="center_horizontal" 
      android:layout_marginBottom="@dimen/twenty" 
      android:layout_weight="1" 
      android:textSize="@dimen/text_medium" 
      android:textStyle="bold" /> 

     <Button 
      android:id="@+id/options" 
      android:layout_width="match_parent" 
      android:layout_height="0dp" 
      android:layout_gravity="center_horizontal" 
      android:layout_marginBottom="@dimen/twenty" 
      android:layout_weight="1" 
      android:textSize="@dimen/text_medium" 
      android:textStyle="bold" /> 
    </LinearLayout> 

</RelativeLayout> 

這開始發生我做了一些工作定義樣式,顏色和尺寸的資源之後。我將一些佈局和資源文件複製到另一個應用程序,在那裏編輯它們以獲得新的外觀,並將它們複製回主項目。自從(據我所知),我已經取消了所有這些更改,但問題仍然存在。

另一個奇怪的行爲是,一個功能活動中的EditText應該是空的,現在已經用res/color/search_url_text_holo.xml填充了。

我認爲這可能是R.java已被破壞。我自從刪除了R,清理了我的項目並重建了項目,但這並沒有解決問題。

我真的很難過。任何幫助都很好。只是問你是否需要更多的細節。

非常感謝。

編輯1: 這裏是對應於該對話框上的開口中的Java代碼:

private void arable() { 
     dialogs.Arable arable = new dialogs.Arable(); 
     arable.show(getSupportFragmentManager(), "tag"); 
} 

package dialogs; 

import rich.farming.fertiliserrecommendations.R; 
import admin.reference.Crop; 
import android.app.Activity; 
import android.app.AlertDialog; 
import android.app.Dialog; 
import android.content.DialogInterface; 
import android.os.Bundle; 
import android.support.v4.app.DialogFragment; 
import appmethods.Starters; 

public class Arable extends DialogFragment { 

    private static Activity act; 
    private boolean cancelled; 

    @Override 
    public Dialog onCreateDialog(Bundle savedInstanceState) { 

     act = getActivity(); 
     int Items = R.array.Menu_arable; 
     cancelled = false; 

     AlertDialog.Builder builder = new AlertDialog.Builder(getActivity()); 
     builder.setTitle("Select").setItems(Items, 
       new DialogInterface.OnClickListener() { 

        @Override 
        public void onClick(DialogInterface dialog, int which) { 
         System.out.println("(Dialogs.Arable.onClick which = " 
           + which); 
         switch (which) { 

         default: 
          cancelled = true; 
          break; 
         } 
         dismiss(); 
         if (!cancelled) 
          act.finish(); 
        } 

       }); 

     return builder.create(); 
    } 

這僅僅是一個例子。有多個對話框以這種方式打開。直到最近他們工作得很好。如果你喜歡,我也可以發佈菜單資源,但它們沒有改變。

+0

你打開任何alertailouge只是在這裏發佈java代碼.. – pavanmvn

+0

這只是一個菜單對話框。我已經添加了與之相對應的代碼,但我不確定它會有幫助。 –

+0

只是檢查你的日誌貓顯示arrayindexoutofbound異常.. – pavanmvn

回答

1

我發現了這個問題。奇怪的是,這是因爲在我styles.xml資源元素包含一個命名空間引用:

<resources xmlns:android="http://schemas.android.com/apk/res/android"> 

刪除,這樣該元素是不是:

<resources> 

固定的問題。

+0

你應該接受這個答案。 – Kedarnath

0

你得到了一個ArrayIndexOutOfBoundsException 你被放入一個太大的字符串到你的元素之一。 希望這可以幫助。

+0

我不知道這可能會發生。我打開的對話框實際上並沒有引用任何字符串資源,並且其中的所有字符串都非常短。 –

+0

它可能在任何地方在你的活動檢查正確.. – pavanmvn

相關問題