2012-07-06 6 views
0

난 그냥 Eclipse에 새로운 Android 프로젝트를 함께 넣었고, 지금까지는 하나의 액티비티 (Eclipse에서 자동 생성 된 코드)가있는 패키지 하나만 가지고있었습니다. 버튼을 main.xml 레이아웃 파일에 추가하십시오.Eclipse with Android - InflateException on FrameLayout 오류

응용 프로그램을 디버깅하려고하면 에뮬레이터가 충돌하고 "이진 XML 파일 줄 # 31 : 클래스를 inflating하는 중 오류가 발생했습니다. android.widget.FrameLayout"오류가 발생합니다.

FrameLayout을 사용하고 있지 않습니다.

package com.myapp.main; 

import android.app.Activity; 
import android.os.Bundle; 

public class MyApp extends Activity { 
/** Called when the activity is first created. */ 
@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 
} 
} 
: (다시, 이것은 당신이 새 프로젝트를 만들 때 이클립스가 생성 단지 기본 코드)

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent" 
android:orientation="vertical" 
android:background="#99CCFF"> 

<Button 
    android:id="@+id/btn1" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:text="New" /> 

<Button 
    android:id="@+id/btn2" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:text="Save" /> 

</LinearLayout> 

그리고 여기에 주요 활동 파일은 다음과 같습니다 여기

레이아웃 파일입니다

그리고 단지 그것의 지옥을 위해, 여기뿐만 아니라 매니페스트 파일입니다 :

지금까지 내가 볼 수
<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
package="com.myapp.main" 
android:versionCode="1" 
android:versionName="1.0" > 

<uses-sdk android:minSdkVersion="8" /> 

<application 
    android:icon="@drawable/ic_launcher" 
    android:label="@string/app_name" > 
    <activity 
     android:name="com.myapp.main.MyApp" 
     android:label="@string/app_name" > 
     <intent-filter> 
      <action android:name="android.intent.action.MAIN" /> 

      <category android:name="android.intent.category.LAUNCHER" /> 
     </intent-filter> 
    </activity> 
</application> 

</manifest> 

, 이것은 99 % 자동 생성 코드이며, FrameLayout을 사용하지 않을 때 "FrameLayout"에서 InflateException을 얻는 이유가 없습니다. 나뿐만 아니라 코드 뭐가 잘못 보는 데 문제가

FATAL EXCEPTION: main 
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.myapp.main/com.myapp.main.MyApp}: android.view.InflateException: Binary XML file line #31: Error inflating class android.widget.FrameLayout 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1736) 
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1752) 
at android.app.ActivityThread.access$1500(ActivityThread.java:123) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:993) 
at android.os.Handler.dispatchMessage(Handler.java:99) 
at android.os.Looper.loop(Looper.java:126) 
at android.app.ActivityThread.main(ActivityThread.java:3997) 
at java.lang.reflect.Method.invokeNative(Native Method) 
at java.lang.reflect.Method.invoke(Method.java:491) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599) 
at dalvik.system.NativeStart.main(Native Method) 
Caused by: android.view.InflateException: Binary XML file line #31: Error inflating class android.widget.FrameLayout 
at android.view.LayoutInflater.createView(LayoutInflater.java:596) 
at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56) 
at android.view.LayoutInflater.onCreateView(LayoutInflater.java:644) 
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:669) 
at android.view.LayoutInflater.rInflate(LayoutInflater.java:724) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:479) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:391) 
at android.view.LayoutInflater.inflate(LayoutInflater.java:347) 
at com.android.internal.policy.impl.PhoneWindow.generateLayout(PhoneWindow.java:2456) 
at com.android.internal.policy.impl.PhoneWindow.installDecor(PhoneWindow.java:2516) 
at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:220) 
at android.app.Activity.setContentView(Activity.java:1777) 
at com.myapp.main.MyApp.onCreate(MyApp.java:20) 
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1048) 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1700) 

답변

0

: 그래서 매우 혼란

... 여기

내가 로그 캣에서 무엇을 얻을 수 있습니다. 앱 충돌시 전체 스택 추적을 복사하여 붙여 넣을 수 있습니까? 나는 이것이 우리에게 일어나는 일에 대해 더 많은 통찰력을 줄 것이라고 생각합니다.

당신은 이클립스에서 로그 캣에서 스택 추적을 얻을 수 있습니다, 또는 "ADB 로그 캣"

+0

을 터미널을 열고 입력 할 수 있습니다 예,이 질문을 업데이트 할 수 있습니다. 나는 logcat에서 너무 도움이되는 아무것도 보지 못했다. – JMax2012

+0

onCreate에서 setContentView() 메서드 호출의 인수는 무엇입니까? –

+0

인수 ("R.layout.main")는 main.xml 레이아웃 파일이며, 위의 질문에 main.xml 코드가 포함되어 있다고 생각합니다. – JMax2012