2012-07-26 3 views
0

나는 ActionBar Sherlock 조각과 관련하여 도움이 필요합니다.onCreate에서 ABS 조각이 손상됨

나는 안드로이드 프로그래밍에 아주 새로운 해요하지만 난 기본적으로 http://goo.gl/Nikyg (유래 게시물) 나의 조각을 만들 수를 따라했지만 이

이 사람이 나를 도울 수 응용 프로그램 충돌은 매번 내가 안드로이드 2.2 또는 4.0

에 실행하려고? 다음과 같이 코드는 다음과 같습니다

Mainactivity.java

package br.com.example.fragmented; 

import android.os.Bundle; 
import com.actionbarsherlock.app.SherlockFragmentActivity; 

public class MainActivity extends SherlockFragmentActivity { 

    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 
    } 

} 

레이아웃 파일 activity_main

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:orientation="vertical" > 

    <Spinner 
     android:id="@+id/spinner1" 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" /> 

    <Spinner 
     android:id="@+id/spinner2" 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" /> 

    <fragment class="br.com.example.fragment1" 
     android:id="@+id/fragment1" 
     android:name="com.actionbarsherlock.app.SherlockFragment" 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:layout_weight="0.85" /> 

</LinearLayout> 

fragment1.java

package br.com.example.fragmented; 

import android.os.Bundle; 
import android.util.Log; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import com.actionbarsherlock.app.SherlockFragment; 

public class fragment1 extends SherlockFragment{ 
    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     Log.i("First Fragment", "onCreate()"); 
    } 

    @Override 
    public View onCreateView(LayoutInflater inflater, ViewGroup container, 
      Bundle savedInstanceState) { 
     Log.i("First Fragment", "onCreateView()"); 
     return inflater.inflate(R.layout.fragment1layout, container, false); 
    } 
} 

fragment1layout.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:orientation="vertical" android:layout_width="fill_parent" 
    android:layout_height="fill_parent" android:background="#000000"> 

    <Button android:text="Landscape" 
     android:id="@+id/button1" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content"> 

    </Button> 

</LinearLayout> 

아무도 내가 여기에 오류가 누락 된 지점 수 있습니까? 오, 나는 셜록에게 테마를 설정했다.

추가 로그 :

07-26 20:22:14.297: E/AndroidRuntime(401): FATAL EXCEPTION: main 
07-26 20:22:14.297: E/AndroidRuntime(401): java.lang.RuntimeException: Unable to start activity ComponentInfo{br.com.example.fragmented/br.com.example.fragmented.MainActivity}: android.view.InflateException: Binary XML file line #17: Error inflating class fragment 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.app.ActivityThread.access$2300(ActivityThread.java:125) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.os.Handler.dispatchMessage(Handler.java:99) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.os.Looper.loop(Looper.java:123) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.app.ActivityThread.main(ActivityThread.java:4627) 
07-26 20:22:14.297: E/AndroidRuntime(401): at java.lang.reflect.Method.invokeNative(Native Method) 
07-26 20:22:14.297: E/AndroidRuntime(401): at java.lang.reflect.Method.invoke(Method.java:521) 
07-26 20:22:14.297: E/AndroidRuntime(401): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860) 
07-26 20:22:14.297: E/AndroidRuntime(401): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 
07-26 20:22:14.297: E/AndroidRuntime(401): at dalvik.system.NativeStart.main(Native Method) 
07-26 20:22:14.297: E/AndroidRuntime(401): Caused by: android.view.InflateException: Binary XML file line #17: Error inflating class fragment 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:582) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.view.LayoutInflater.rInflate(LayoutInflater.java:618) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.view.LayoutInflater.inflate(LayoutInflater.java:407) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.view.LayoutInflater.inflate(LayoutInflater.java:320) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.view.LayoutInflater.inflate(LayoutInflater.java:276) 
07-26 20:22:14.297: E/AndroidRuntime(401): at com.actionbarsherlock.internal.ActionBarSherlockCompat.setContentView(ActionBarSherlockCompat.java:857) 
07-26 20:22:14.297: E/AndroidRuntime(401): at com.actionbarsherlock.app.SherlockFragmentActivity.setContentView(SherlockFragmentActivity.java:251) 
07-26 20:22:14.297: E/AndroidRuntime(401): at br.com.example.fragmented.MainActivity.onCreate(MainActivity.java:12) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627) 
07-26 20:22:14.297: E/AndroidRuntime(401): ... 11 more 
07-26 20:22:14.297: E/AndroidRuntime(401): Caused by: android.support.v4.app.Fragment$InstantiationException: Unable to instantiate fragment br.com.example.fragment1: make sure class name exists, is public, and has an empty constructor that is public 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.support.v4.app.Fragment.instantiate(Fragment.java:395) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.support.v4.app.Fragment.instantiate(Fragment.java:363) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:264) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:558) 
07-26 20:22:14.297: E/AndroidRuntime(401): ... 20 more 
07-26 20:22:14.297: E/AndroidRuntime(401): Caused by: java.lang.ClassNotFoundException: br.com.example.fragment1 in loader dalvik.system.PathClassLoader[/data/app/br.com.example.fragmented-1.apk] 
07-26 20:22:14.297: E/AndroidRuntime(401): at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243) 
07-26 20:22:14.297: E/AndroidRuntime(401): at java.lang.ClassLoader.loadClass(ClassLoader.java:573) 
07-26 20:22:14.297: E/AndroidRuntime(401): at java.lang.ClassLoader.loadClass(ClassLoader.java:532) 
07-26 20:22:14.297: E/AndroidRuntime(401): at android.support.v4.app.Fragment.instantiate(Fragment.java:385) 
07-26 20:22:14.297: E/AndroidRuntime(401): ... 23 more 
+1

어떻게 충돌합니까? 오류가 무엇입니까? 디버거에서 실행 했습니까? 오류에 대한 아이디어를 얻기 위해 logcat 출력을 추가 할 수 있습니까? – Kaediil

답변

1

당신의 XML에 class 속성을 제거하고 이름 속성이 아니라 ABS에 대한 당신의 조각의 이름을 사용하기.

+0

확인을 클릭하면 로그 파일이 추가되었습니다. 실행하기 전에 클래스 accribute를 제거했습니다. 미리 감사드립니다. – Herrera

+0

@Herrera 그래서 클래스 이름이 있는지, public인지, public인지 빈 생성자인지를 알려주고 있습니다. – LuxuryMode

+0

빈 생성자를 삽입하려면 어떻게해야합니까? 레이아웃이 'android : name = "br.com.example.fragment1"'에서 호출되는 클래스가 아닙니다. – Herrera