2012-08-04 24 views
5

estoy tratando de cambiar fragmentos usando ViewPager + FragmentPagerAdapter. Actualmente estoy utilizando el soporte más reciente de Android paquete v4"java.lang.IllegalStateException: No se puede cambiar la etiqueta del fragmento" error al utilizar ViewPager # setCurrentItem()

Tengo 5 pestañas en mi aplicación. Cuando selecciono la cuarta pestaña, la aplicación se cierra de repente y dice "no puedo cambiar la etiqueta del fragmento ~~".

No intenté reemplazar el Fragmento que está incluido en el archivo xml de diseño, así que no pude encontrar la causa.

Aquí está el código donde se produce el error:

@Override 
public void onTabSelected(ActionBar.Tab tab, 
     FragmentTransaction fragmentTransaction) { 
    // When the given tab is selected, switch to the corresponding page in 
    // the ViewPager. 
    mViewPager.setCurrentItem(tab.getPosition()); 
} 

A continuación se muestra un fragmento de FragmentPagerAdapter estoy usando

@Override 
    public Fragment getItem(int i) { 
     if (fragment_list.get(i) == null) { 
      fragment_list.add(i, getFragment(i)); 
     } 

     return fragment_list.get(i); 
    } 

    private Fragment getFragment(int index) { 
     switch (index) { 
     case TOP: 
      return UseCaseListWithOptionFragment.newInstance(
        URLHelper.USE_CASES_TOP_URL, R.array.comment); 
     case FEED: 
      int user_id = UserHelper.getCurrentUser(MainActivity.this).id; 
      return UseCaseListFragment.newInstance(
        URLHelper.getMyFeedsURL(user_id), true); 
     case RECENT: 
      return UseCaseListFragment.newInstance(
        URLHelper.USE_CASES_RECENT_URL, true); 
     case CATEOGORY: 
      return UseCaseGroupListFragment.newInstance(
        URLHelper.USE_CASE_GROUPS_URL, R.array.use_case); 
     case MY: 
      return UserProfileFragment.newInstance(UserHelper 
        .getCurrentUser(MainActivity.this)); 
     default: 
      throw new IllegalStateException("Tab index out of bound."); 
     } 
    } 

    @Override 
    public int getCount() { 
     return TAB_COUNT; 
    } 

A continuación se muestra el registro de errores que encuentro:

08-04 17:51:55.983: E/AndroidRuntime(1112): FATAL EXCEPTION: main 
08-04 17:51:55.983: E/AndroidRuntime(1112): java.lang.IllegalStateException: Can't change tag of fragment UseCaseGroupListFragment{4055f558 id=0x7f050034 android:switcher:2131034164:3}: was android:switcher:2131034164:3 now android:switcher:2131034164:4 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.support.v4.app.BackStackRecord.doAddOp(BackStackRecord.java:356) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.support.v4.app.BackStackRecord.add(BackStackRecord.java:347) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.support.v4.app.FragmentPagerAdapter.instantiateItem(FragmentPagerAdapter.java:99) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.support.v4.view.ViewPager.addNewItem(ViewPager.java:692) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.support.v4.view.ViewPager.populate(ViewPager.java:875) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.support.v4.view.ViewPager.setCurrentItemInternal(ViewPager.java:469) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.support.v4.view.ViewPager.setCurrentItemInternal(ViewPager.java:441) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.support.v4.view.ViewPager.setCurrentItem(ViewPager.java:422) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at org.everyuse.android.activity.MainActivity.onTabSelected(MainActivity.java:176) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at com.actionbarsherlock.internal.app.ActionBarImpl.selectTab(ActionBarImpl.java:526) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at com.actionbarsherlock.internal.app.ActionBarImpl$TabImpl.select(ActionBarImpl.java:907) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at com.actionbarsherlock.internal.widget.ScrollingTabContainerView$TabClickListener.onClick(ScrollingTabContainerView.java:503) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.view.View.performClick(View.java:2485) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.view.View$PerformClick.run(View.java:9080) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.os.Handler.handleCallback(Handler.java:587) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.os.Handler.dispatchMessage(Handler.java:92) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.os.Looper.loop(Looper.java:123) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at android.app.ActivityThread.main(ActivityThread.java:3683) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at java.lang.reflect.Method.invokeNative(Native Method) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at java.lang.reflect.Method.invoke(Method.java:507) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
08-04 17:51:55.983: E/AndroidRuntime(1112):  at dalvik.system.NativeStart.main(Native Method) 

Gracias de antemano ...

+0

hacer u haber una respuesta ahora? – singhsumit

+1

Su implementación de 'public Fragment getItem (int)' parece un poco extraña. ¿Qué pasaría si se llamara a 'getItem (4)' antes de 'getItem (3)'? Me imagino que obtendrías una excepción IndexOutOfBoundsException en la lista. Eso no está sucediendo aquí, pero podrías considerar un enfoque ligeramente diferente y terminar solucionando el problema. – mkasberg

Respuesta

4

Experimenté la misma excepción al implementar incorrectamente el método getCount. ¿Has verificado si se devuelve el tamaño correcto?

@Override 
public int getCount() { 
    return 5; 
} 
+0

También tuve problemas con esto, que resultó ser un 'público int getCount()' no coincidente, como sugirió bogdan. – mkasberg

1

veo que ha pasado un tiempo que esta pregunta, pero para el futuro usuario que pudiera hacer frente a este problema también ...

que estaba teniendo exactamente el mismo error en algunos dispositivos, y no pude encuentre cualquier razón hasta que vea el comentario de @ mkasberg ... De alguna manera el método getItem puede llamarse no en orden, tal vez porque algunos dispositivos procesan más rápido o no sé, pero el uso de sparseArray en lugar de arrayList ha resuelto mi problema. Gracias!

Y aquí la forma en que podría hacerlo:

public Fragment getItem(int i) { 
    if (sparseArray.get(i) == null) { 
     sparseArray.put(i, getFragment(i)); 
    } 

    return sparseArray.get(i); 
} 
Cuestiones relacionadas