17

La mia applicazione si chiude quando spengo lo schermo e lo riaccendo.ViewPager PagerObserver non registrato

Logcat mi dice che la causa di questo errore è puntare a java line 60 nella mia CourseFragment.class che estende Fragment.

mViewPager.setAdapter(infoTechPageAdapter); 

Io sono l'attuazione di un ViewPager nei miei CourseFragment.class che si estende Fragment.

Ecco il mio codice:

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. Il 'ViewPager' è dichiarato nel layout' R.layout.activity_drawer_fragment'? In caso affermativo, non utilizzare 'getActivity(). FindViewById (R.id.pagerYear);' per trovarlo, utilizzare invece la vista del frammento direttamente: 'getView(). FindViewById (R.id.pagerYear); '2. Ancora, se il' ViewPager' è impostato per essere usato nel 'CourseFragment' quindi passare' getChildFragmentManager() 'a' InfoTechPageAdapter' (e al resto degli adattatori) invece di 'getActivity(). GetSupportFragmentManager() '. – Luksprog

+0

Sono impressionato. Sei molto [email protected] _ @ Ho un altro problema ma probabilmente lo postò più tardi se non trovo una soluzione, spero che tu possa aiutarmi anche in questo. Grazie mille. – Marss

+0

Davvero ... Non so come dire grazie .... sei davvero bravo ancora non sapevo come trovo il tuo commento ... Per favore inserisci il commento come risposta :) in modo che tutti possano vedere rapidamente ... penso che nessun altro abbia piazzato questa soluzione .. –

risposta

43

Come sottolineato da @Luksprog in un commento, è necessario modificare

getActivity().getSupportFragmentManager() 

per

getChildFragmentManager() 

Perché: getSupportFragmentManager() (e getFragmentManager()) viene utilizzato per interagire con i frammenti associati all'attività di questo frammento, che non è ciò che si desidera.

Quello che si desidera è posizionare e gestire i frammenti all'interno di questo frammento (utilizzando gli adattatori), che è la descrizione del metodo getChildFragmentManager().

Un grande ringraziamento a @Luksprog per il puntatore; Ho avuto lo stesso problema che hai fatto e lui ha avuto la risposta! Pubblicando semplicemente la sua risposta in una risposta reale, per gli altri che potrebbero non pensare di cercare nei commenti una risposta a questo problema.

+0

Cosa devo fare se non ho getChildFragmentManager() su Android 4.0 e 4.1? –

+1

@ RomulusUrakagiTs'ai: questo metodo è disponibile anche nella [libreria di supporto] (http://developer.android.com/reference/android/support/v4/app/Fragment.html#getChildFragmentManager()), che dovresti usa sempre, se intendi supportare versioni precedenti di Android. –

+0

Un sacco di gente probabilmente ha fatto un passo su questo come l'esempio ['ViewPager'] (http://developer.android.com/reference/android/support/v4/view/ViewPager.html) semplicemente' super (activity.getFragmentManager ()): at ctor ... :( – Diederik

3

Stavo avendo questo problema anche se ero 100% sicuro che stavo usando il corretto FragmentManager. Ho risolto il problema effettuando un controllo nullo durante l'inizializzazione di ViewPager's adapter.

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

Dopo aver studiato lo stacktrace ho che il problema è che ViewPager sta cercando di distruggere i vecchi frammenti nella cache quando si rilascia il vecchio adattatore e qualcosa sta andando storto, perché i frammenti erano in realtà mai visibile. Questa è solo un'ipotesi.

0

Ho riscontrato questo problema utilizzando il codice generato da Android Studio e ho utilizzato il lavoro precedente con il controllo page.getAdapter() == null prima di crearlo ogni volta onStart().

codice finale:

@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); 
    } 
} 

L'unico problema che ho ora è che premendo il pulsante Indietro deve essere fatto due volte per funzionare correttamente. Non sono sicuro se questo è un problema di Intent o Fragment ...