2013-07-05 3 views
10

Mam naprawdę dziwny problem. Mam wspólny fragment dodawany w prawie każdej aktywności mojej aplikacji. Ten fragment pokazuje małą wersję paska odtwarzacza. Dlatego słucha niektórych audycji, aby zaktualizować nazwę aktualnej muzyki i ma kilka elementów sterujących, takich jak odtwarzanie/pauza.Uzyskiwanie "Fragment nie utworzył widoku" po adnotacji innego Fragmentu bez interfejsu użytkownika

Tak jak powiedziałem, dodałem ten fragment w niemal każdej aktywności mojej aplikacji i nigdy nie miałem z tym żadnego problemu. Ale teraz, musiałem stworzyć nowy Fragment, który nie ma interfejsu użytkownika i który jest zachowany (setRetainInstance (true)). Po przejściu tego nowego Fragmentu wszystko wydawało się być w porządku. Dopóki nie obróciłem urządzenia i aktywność się zawiesiła.

Więc patrząc w dzienniku, widzę następujący wyjątek:

07-05 14:10:23.818: ERROR/AndroidRuntime(25922): FATAL EXCEPTION: main 
     java.lang.RuntimeException: Unable to start activity ComponentInfo{com.soongz/com.soongz.ui.PlaylistActivity}: android.view.InflateException: Binary XML file line #13: Error inflating class fragment 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2110) 
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2135) 
     at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:3576) 
     at android.app.ActivityThread.access$800(ActivityThread.java:140) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1243) 
     at android.os.Handler.dispatchMessage(Handler.java:99) 
     at android.os.Looper.loop(Looper.java:137) 
     at android.app.ActivityThread.main(ActivityThread.java:4921) 
     at java.lang.reflect.Method.invokeNative(Native Method) 
     at java.lang.reflect.Method.invoke(Method.java:511) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:794) 
     at dalvik.system.NativeStart.main(Native Method) 
     Caused by: android.view.InflateException: Binary XML file line #13: Error inflating class fragment 
     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:704) 
     at android.view.LayoutInflater.rInflate(LayoutInflater.java:746) 
     at android.view.LayoutInflater.inflate(LayoutInflater.java:489) 
     at android.view.LayoutInflater.inflate(LayoutInflater.java:396) 
     at android.view.LayoutInflater.inflate(LayoutInflater.java:352) 
     at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:313) 
     at com.actionbarsherlock.internal.ActionBarSherlockNative.setContentView(ActionBarSherlockNative.java:119) 
     at com.actionbarsherlock.app.SherlockFragmentActivity.setContentView(SherlockFragmentActivity.java:262) 
     at net.simonvt.menudrawer.MenuDrawer.setContentView(MenuDrawer.java:964) 
     at com.soongz.ui.BaseComMenuActivity.setContentViewComMenu(BaseComMenuActivity.java:31) 
     at com.soongz.ui.PlaylistActivity.createView(PlaylistActivity.java:111) 
     at br.com.cybereagle.androidlibrary.ui.EagleActivity.onCreate(EagleActivity.java:57) 
     at android.app.Activity.performCreate(Activity.java:5206) 
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094) 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2074) 
     ... 12 more 
     Caused by: java.lang.IllegalStateException: Fragment com.soongz.ui.fragment.PlayerReduzidoFragment did not create a view. 
     at android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:303) 
     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:676) 
     ... 26 more 

Ten wyjątek dzieje się we fragmencie, który był już w Działaniu, zamiast dzieje w nowym fragmentem. Jeśli usunę fragment z małą wersją paska odtwarzacza i zachowam nowy Fragment bez interfejsu użytkownika, wszystko działa normalnie. Działa również, jeśli zachowam tylko stary fragment i usuwam nowy.

Więcej szczegółów: Stary fragment jest dodawany za pomocą układu XML. Oto XML działania:

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

    <fragment 
     android:name="com.soongz.ui.fragment.ListaDeMusicasFragment" 
     android:id="@+id/lista_de_musicas_fragment" 
     style="?layoutListViewMusicas" /> 

    <fragment 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:name="com.soongz.ui.fragment.PlayerReduzidoFragment"/> 
</LinearLayout> 

Nowy fragment (wih bez UI) dodaje się w następujący sposób:

FragmentManager fragmentManager = getSupportFragmentManager(); 
operacoesEmBackgroundFragment = (OperacoesEmBackgroundFragment) fragmentManager.findFragmentByTag(TAG_OPERACOES_EM_BACKGROUND_FRAGMENT); 

if(operacoesEmBackgroundFragment == null){ 
    operacoesEmBackgroundFragment = new OperacoesEmBackgroundFragment(); 
    fragmentManager.beginTransaction() 
      .add(operacoesEmBackgroundFragment, TAG_OPERACOES_EM_BACKGROUND_FRAGMENT) 
      .commit(); 
} 

Dzięki z góry za każdego, kto może mi pomóc.

UPDATE:

usunąłem setRetainInstance (true) z fragmentu bez interfejsu użytkownika, aby zobaczyć, czy problem jest związany z tym. Ale problem nadal występuje.

Odpowiedz

17

O mój Boże, nie mogę tego uwierzyć. Rozwiązałem swój problem, ustawiając tylko ID fragmentu, który miał problem.

Teraz układ XML w danej czynności jest tak:

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

    <fragment 
     android:name="com.soongz.ui.fragment.ListaDeMusicasFragment" 
     android:id="@+id/lista_de_musicas_fragment" 
     style="?layoutListViewMusicas" /> 

    <fragment 
     android:id="@+id/player_reduzido_fragment" 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:name="com.soongz.ui.fragment.PlayerReduzidoFragment"/> 
</LinearLayout> 

nie wiem dlaczego. To musi być błąd.

+4

Jeśli dodajesz fragment programowo za pomocą FragmentTransaction, pamiętaj o podaniu kontenera fragmentu Wyświetl identyfikator. Również @FernandoCamargo nie mogę opisać, jak wdzięczny jestem za tę szybką naprawę, dziękuję. –

Powiązane problemy