2014-09-17 5 views
0

GLSurfaceView를 XML 레이아웃에 넣으려고합니다.하지만 그렇게하려고하면 애플리케이션이 자동으로 닫히게됩니다. glsurgaceview에 대한 태그 이름을 모르므로 문제는 layout/activity_main.xml에 있다고 생각합니다. 이것은 내 코드입니다. 제 코드에 어떤 문제가 있는지 말해주십시오. 당신의 도움을 주셔서 감사합니다.어떻게 안드로이드의 레이아웃 xml에서 glsurfaceview를 부 풀릴 수 있습니까

<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" 
    android:paddingBottom="@dimen/activity_vertical_margin" 
    android:paddingLeft="@dimen/activity_horizontal_margin" 
    android:paddingRight="@dimen/activity_horizontal_margin" 
    android:paddingTop="@dimen/activity_vertical_margin" 
    tools:context=".AnimationActivity"> 

    <TextView 
     android:id="@+id/angolo" 
     android:layout_width="wrap_content" 
android:layout_height="wrap_content" 
     android:layout_alignParentTop="true" 
     android:layout_centerHorizontal="true" 
     android:layout_marginTop="135dp" 
     android:text="Angolo:" 
     android:textAppearance="?android:attr/textAppearanceMedium" /> 

    <view 
     class="rugani.tesi.animazione3d.AnimationActivity$MyGLSurfaceView" 
     android:id="@+id/myglsurfaceView" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     /> 

</RelativeLayout> 

이 myglsurfaceview입니다 :

protected void onCreate(Bundle savedInstanceState) { 

    Logger.log("onCreate"); 

    super.onCreate(savedInstanceState); 
    getActionBar().setDisplayHomeAsUpEnabled(true); 


    /* 
    mGLView = new GLSurfaceView(getApplication()); 
    mGLView.setEGLContextClientVersion(2); 
    mGLView.setEGLConfigChooser(new AAConfigChooser(mGLView)); 
    mGLView.setRenderer(renderer); 
    setContentView(mGLView); 
    */ 
    //mGLView = new MyGLSurfaceView(getApplication()); 
    //setContentView(mGLView); 

    setContentView(R.layout.activity_main); 
    mGLView = (MyGLSurfaceView) findViewById(R.id.graphics_glsurfaceview); 

    pluto=(MyApplication)this.getApplication(); 
    mBoundService=pluto.getObj(); 
} 

이 내에서 OnCreate()

private MyGLSurfaceView mGLView; 
private MyGLRenderer renderer; 
protected void onCreate(Bundle savedInstanceState) { 

    Logger.log("onCreate"); 

    super.onCreate(savedInstanceState); 
    getActionBar().setDisplayHomeAsUpEnabled(true); 


    /* 
    mGLView = new GLSurfaceView(getApplication()); 
    mGLView.setEGLContextClientVersion(2); 
    mGLView.setEGLConfigChooser(new AAConfigChooser(mGLView)); 
    mGLView.setRenderer(renderer); 
    setContentView(mGLView); 
    */ 
    //mGLView = new MyGLSurfaceView(getApplication()); 
    //setContentView(mGLView); 

    setContentView(R.layout.activity_main); 
    mGLView = (MyGLSurfaceView) findViewById(R.id.graphics_glsurfaceview); 

} 

이는 로그 캣입니다 :

09-18 10시 52분 : 17.665 : E/ActivityThread (30263) : 팽창하지 못했습니다. 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.view.InflateException : 바이너리 XML 파일 줄 # 11 : 클래스를 부 풀릴 때 오류 발생 rugani.tesi.animazione3d.AnimationActivity.MyGLSurfaceView 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.view.LayoutInflater.createViewFromTag (LayoutInflater.java:708) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.view.LayoutInflater.rInflate (LayoutInflater.java:708) .java : 756) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.view.LayoutInflater.inflate (LayoutInflater.java:492) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.view.LayoutInflater.inflate (LayoutInflater.java:397) 09-18 10:52:17.665 : E/Acti vityThread (30263) : android.view.LayoutInflater.inflate (LayoutInflater.java:353) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : com.android.internal.policy.impl. PhoneWindow.setContentView (PhoneWindow.java:344) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.app.Activity.setContentView (Activity.java:2127) 09-18 10:52 : 17.665 : E/ActivityThread (30263) : rugani.tesi.animazione3d.AnimationActivity.onCreate (AnimationActivity.java:73) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.app .Activity.performCreate (Activity.java:6020) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.app.Instrumentation.callActivityOnCreate (Inst rumentation.java:1087) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2181) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:2276) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.app.ActivityThread.access $ 800 ActivityThread.java:144) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.app.ActivityThread $ H.handleMessage (ActivityThread.java:1205) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.os.Handler.dispatchMessage (Handler.java:102) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : 012에android.os.Looper.loop (Looper.java:136) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.app.ActivityThread.main (ActivityThread.java:5151) 09- 18 10 : 52 : 17.665 : E/ActivityThread (30263) : 에서 java.lang.reflect.Method.invokeNative (네이티브 메소드) 09-18 10:52:17.665 : E/ActivityThread (30263) : java.lang.reflect.Method.invoke (Method.java:515) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : com.android. internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java:796) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : com.android.internal.os.ZygoteInit.main (ZygoteInit.java : 612) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : 에 dalvik.system.NativeStart.main (기본 방법) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : 원인 : java.lang.ClassNotFoundException : 경로에 "rugani.tesi.animazione3d.AnimationActivity.MyGLSurfaceView"클래스가 없습니다. DexPathList [[zip 파일 "/ d ata/app/rugani.tesi.animazione3d-1.apk "], nativeLibraryDirectories = [/ data/app-lib/rugani.tesi.animazione3d-1, /vendor/lib,/system/lib]] 09-18 10 : 52 : 17.665 : E/ActivityThread (30,263) dalvik.system.BaseDexClassLoader.findClass (BaseDexClassLoader.java:56)에서 10월 9일부터 18일까지 : 52 : 17.665 : E/ActivityThread (30,263)에 자바 . (ClassLoader.java:457) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : : 52 : 17.665 : E/ActivityThread (30263) : android.view.LayoutInflater.createView (LayoutInflater.java:559) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : android.view .LayoutInflater.c reateViewFromTag (LayoutInflater.java:697) 09-18 10 : 52 : 17.665 : E/ActivityThread (30263) : ... (21) 더

편집 : 나는 새로운 XML 레이아웃 및이 게시물을 업데이트 한 당신이 필요로하는

+0

을 사용하면 실패 메시지를 표시 할 수 있습니다 참조 할 수 있습니다

MyGLSurfaceView(Context context, AttributeSet attrs) 

적절한 생성자를 구현 logcat에서? – fadden

+0

오류 logcat 및 편집 된 xml 레이아웃을 포함하여 첫 번째 게시물을 편집했습니다. –

+0

클래스를 찾지 못했습니다. "클래스를 찾지 못했습니다."rugani.tesi.animazione3d.AnimationActivity.MyGLSurfaceView "'. – fadden

답변