17

Moja aplikacja zamyka się po wyłączeniu ekranu i ponownym włączeniu.ViewPager PagerObserver nie został zarejestrowany

Logcat informuje mnie, że przyczyną tego błędu jest wskazanie linii Java 60 w pliku CourseFragment.class, który rozszerza fragment.

mViewPager.setAdapter(infoTechPageAdapter); 

Wdrażam ViewPager w moim CourseFragment.class, który rozszerza Fragment.

Oto mój kod:

public class CourseFragment extends Fragment { 

public static final String ARG_POSITION_NUMBER = "course_number"; 

private int position; 

public CourseFragment() { 
    // Empty constructor required for fragment subclasses 
} 

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
     Bundle savedInstanceState) { 

    View rootView; 
    position = getArguments().getInt("position"); 

    String course = getResources().getStringArray(
      R.array.array_navigation_drawer)[position]; 

    getActivity().setTitle(course); 

    rootView = inflater.inflate(R.layout.activity_drawer_fragment, 
      container, false); 

    return rootView; 
}// end onCreateView 

@Override 
public void onStart() { 
    super.onStart(); 

    ViewPager mViewPager = (ViewPager) getActivity().findViewById(
      R.id.pagerYear); 

    Log.i("posit", String.valueOf(position)); 
    switch (position) { 

    case 0: 
     InfoTechPageAdapter infoTechPageAdapter = new InfoTechPageAdapter(
       getActivity().getSupportFragmentManager()); 
     mViewPager.setAdapter(infoTechPageAdapter); 
     break; 

    case 1: 
     ComSciPageAdapter comSciPageAdapter = new ComSciPageAdapter(
       getActivity().getSupportFragmentManager()); 
     mViewPager.setAdapter(comSciPageAdapter); 
     break; 

    case 2: 
     ProfilePageAdapter profilePageAdapter = new ProfilePageAdapter(
       getActivity().getSupportFragmentManager()); 
     mViewPager.setAdapter(profilePageAdapter); 
     break; 
    } 

}// end onStart 
} 

Logcat

09-22 10:54:03.830: E/AndroidRuntime(2917): FATAL EXCEPTION: main 
09-22 10:54:03.830: E/AndroidRuntime(2917): java.lang.IllegalStateException: Observer [email protected] was not registered. 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.database.Observable.unregisterObserver(Observable.java:69) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.view.PagerAdapter.unregisterDataSetObserver(PagerAdapter.java:294) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at com.usjr.sss.adapter.InfoTechPageAdapter.unregisterDataSetObserver(InfoTechPageAdapter.java:21) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.view.ViewPager.setAdapter(ViewPager.java:409) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at com.usjr.sss.fragment.CourseFragment.onStart(CourseFragment.java:60) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.Fragment.performStart(Fragment.java:1502) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:957) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1460) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.FragmentManagerImpl.executePendingTransactions(FragmentManager.java:472) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.FragmentStatePagerAdapter.finishUpdate(FragmentStatePagerAdapter.java:163) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.view.ViewPager.setAdapter(ViewPager.java:415) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at com.usjr.sss.fragment.CourseFragment.onStart(CourseFragment.java:60) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.Fragment.performStart(Fragment.java:1502) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:957) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1086) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.FragmentManagerImpl.dispatchStart(FragmentManager.java:1882) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:573) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1164) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.app.Activity.performStart(Activity.java:5114) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.app.Activity.performRestart(Activity.java:5169) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.app.ActivityThread.handleSleeping(ActivityThread.java:3408) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.app.ActivityThread.access$2700(ActivityThread.java:153) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1426) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.os.Handler.dispatchMessage(Handler.java:99) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.os.Looper.loop(Looper.java:137) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at android.app.ActivityThread.main(ActivityThread.java:5227) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at java.lang.reflect.Method.invokeNative(Native Method) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at java.lang.reflect.Method.invoke(Method.java:511) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562) 
09-22 10:54:03.830: E/AndroidRuntime(2917):  at dalvik.system.NativeStart.main(Native Method) 
+7

1. Czy "ViewPager" jest zadeklarowany w układzie 'R.layout.activity_drawer_fragment'? Jeśli tak, to nie używaj funkcji getActivity(). FindViewById (R.id.pagerYear) ;, aby ją znaleźć, zamiast tego użyj widoku fragmentu bezpośrednio: 'getView(). FindViewById (R.id.pagerYear); '2. Ponownie, jeśli' ViewPager' jest ustawiony do użycia w 'CourseFragment', to przekaż' getChildFragmentManager() 'do' InfoTechPageAdapter' (i reszta adapterów) zamiast 'getActivity(). GetSupportFragmentManager() '. – Luksprog

+0

Jestem pod wrażeniem. Jesteś bardzo [email protected] _ @ Mam inny problem, ale prawdopodobnie opublikuję go później, jeśli nie znajdę rozwiązania, mam nadzieję, że możesz mi w tym pomóc. Dziękuję bardzo. – Marss

+0

Naprawdę ... Nie wiem, jak to powiedzieć, dziękuję .... jesteś naprawdę dobry, wciąż nie wiedziałem, jak znajdę twój komentarz ... Proszę umieścić komentarz jako odpowiedź :) tak, aby każdy mógł zobaczyć oni szybko ... myślę, że nikt inny nie umieścił tego rozwiązania .. –

Odpowiedz

43

Jak podkreślił @Luksprog w komentarzu, trzeba zmienić

getActivity().getSupportFragmentManager() 

dla

getChildFragmentManager() 

Dlaczego: getSupportFragmentManager() (i getFragmentManager()) używa się do interakcji z fragmentami powiązanymi z działaniem tego fragmentu, co nie jest tym, czego potrzebujesz.

Należy umieścić i zarządzać Fragmentami wewnątrz tego Fragmentu (przy użyciu adapterów), co jest opisem metody getChildFragmentManager().

Wielkie dzięki @Luksprog za wskaźnik; Miałem ten sam problem co ty, i on miał odpowiedź! Po prostu publikuj swoją odpowiedź w prawdziwej odpowiedzi, dla innych, którzy mogą nie myśleć, aby zajrzeć do komentarzy w odpowiedzi na ten problem.

+0

Co powinienem zrobić, jeśli nie mam getChildFragmentManager() na Androidzie 4.0 i 4.1? –

+1

@ RomulusUrakagiTs'ai: Ta metoda jest również dostępna z [biblioteki pomocy] (http://developer.android.com/reference/android/support/v4/app/Fragment.html#getChildFragmentManager()), którą powinieneś zawsze używaj, jeśli zamierzasz obsługiwać starsze wersje Androida. –

+0

Wiele osób prawdopodobnie nadepnęło na to jako przykład ['ViewPager'] (http://developer.android.com/reference/android/support/v4/view/ViewPager.html) po prostu robi' super (activity.getFragmentManager ()); 'at ctor ... :( – Diederik

3

Miałem ten problem, mimo że byłam 100% pewna, że ​​używałam poprawnego FragmentManager. Rozwiązałem go, wykonując zerową kontrolę podczas inicjowania ViewPager's adapter.

if(pager.getAdapter() == null) 
    pager.setAdapter(pagerAdapter); 

Po przestudiowaniu StackTrace myślę problemem jest to, że ViewPager próbuje zniszczyć stare fragmenty pamięci podręcznej po zwolnieniu starego adaptera i coś jest nie tak, ponieważ fragmenty nigdy nie były faktycznie widoczne. To tylko zgadnij.

0

Miałem ten problem przy użyciu wygenerowanego kodu Android Studio i użyłem powyższej pracy z testem page.getAdapter() == null przed utworzeniem go za każdym razem, onStart().

kod końcowa:

@Override 
public void onStart() { 
    super.onStart(); 

    // Set up the ViewPager with the sections adapter. 
    mViewPager = (ViewPager) findViewById(R.id.pager); 
    if(mViewPager.getAdapter() == null) { 
     // Create the adapter that will return a fragment for each of the three 
     // primary sections of the activity. 
     mSectionsPagerAdapter = new SectionsPagerAdapter(getFragmentManager()); 
     mViewPager.setAdapter(mSectionsPagerAdapter); 
    } 
} 

Jedyny problem mam teraz jest, że naciśnięcie przycisku Wstecz należy zrobić dwa razy, aby działać poprawnie. Nie jestem pewien, czy jest to problem z intencją lub fragmentem ...

Powiązane problemy