每當我的應用程序嘗試顯示一個對話框片段時,出現以下錯誤或類似的錯誤,或特定佈局: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();
}
這僅僅是一個例子。有多個對話框以這種方式打開。直到最近他們工作得很好。如果你喜歡,我也可以發佈菜單資源,但它們沒有改變。
你打開任何alertailouge只是在這裏發佈java代碼.. – pavanmvn
這只是一個菜單對話框。我已經添加了與之相對應的代碼,但我不確定它會有幫助。 –
只是檢查你的日誌貓顯示arrayindexoutofbound異常.. – pavanmvn