English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
Escena: usar Fragment para realizar el cambio de página.
Estructura de la clase:
Uno: Activity
En la Activity se utiliza getSupportFragmentManager().beginTransaction() para llenar un Fragment (FragmentA utilizado para la gestión)
Código de la Activity:
FragmentA fragment = FragmentA.newInstant(null); getSupportFragmentManager().beginTransaction().add(R.id.f_tab_fragment,fragment).commit();
XML:
<FrameLayout android:id="@"+id/fl_container" android:layout_width="match_parent" android:layout_above="@"+id/f_tab_fragment" android:layout_height="match_parent"/> <FrameLayout android:id="@"+id/f_tab_fragment" android:layout_width="match_parent" android:layout_height="52dp" android:layout_alignParentBottom="true"/>
Dos: FragmentA
Cargar un Fragment principal FragmentA, que actúa como administrador de otros subFragmentX.
Por ejemplo, ahora hay dos subhojas FragmentB y FragmentC.
FragmentA utiliza FragmentManager y FragmentTransaction para manejar el cambio entre FragmentB y FragmentC
FragmentA código:
public class FragmentA extends BaseFragment { private static final String TAB_HOME = com.timediffproject.module.home.MyMainFragment.class.getName(); private static final String TAB_TEST = com.timediffproject.module.home.TestFragment.class.getName(); private BaseFragment mLastShowFragment; private static TabFragment fragment; public static TabFragment newInstant(Bundle bundle){ if (fragment == null){ fragment = new TabFragment(); fragment.setArguments(bundle); } return fragment; } @Override public void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); initTabInfo(); } private void initTabInfo(){ FragmentManager fm = getFragmentManager(); if (fm == null){ return; } FragmentTransaction ft = fm.beginTransaction(); BaseFragment home = (BaseFragment) fm.findFragmentByTag(TAB_HOME); if (home != null){ ft.hide(home); } BaseFragment test = (BaseFragment) fm.findFragmentByTag(TAB_TEST); if (test != null){ ft.hide(test); } ft.commit(); } @Nullable @Override public View onCreateView(LayoutInflater inflater,ViewGroup container,Bundle savedInstanceState) { return inflater.inflate(R.layout.fragment_tab,container,false); } @Override public void onViewCreated(View view, @Nullable Bundle savedInstanceState) { super.onViewCreated(view, savedInstanceState); view.findViewById(R.id.btn_change_home).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { switchTo(TAB_HOME, null); } }); view.findViewById(R.id.btn_change_test).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { switchTo(TAB_TEST, null); } }); switchTo(TAB_HOME, null); } //Método de cambio de Fragment (FragmentB, FragmentC) //tab es el nombre de la clase del Fragment (por ejemplo: FragmentB.class.getName()) //R.id.fl_container está en el diseño de Activity, no en el diseño de FragmentA private void switchTo(String tab, Bundle bundle){ //Inicializar la clase para administrar Fragment FragmentManager fm = getFragmentManager(); if (fm == null){ return; } FragmentTransaction ft = fm.beginTransaction(); //Encontrar Fragment de clase tab en elFragmentManager BaseFragment fragment = (BaseFragment) fm.findFragmentByTag(tab); if (fragment == null){ fragment = (BaseFragment) Fragment.instantiate(getActivity(), tab); fragment.setArguments(bundle); ft.add(R.id.fl_container, fragment, tab); }else{ ft.show(fragment); } //Ocultar el Fragment que se muestra actualmente if (mLastShowFragment != null) { ft.hide(mLastShowFragment); } //Registrar el Fragment último clicado mLastShowFragment = fragment; ft.commitAllowingStateLoss(); } }
XML:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="52dp"> <Button android:id="@"+id/btn_change_home" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="cambiar home" /> <Button android:id="@"+id/btn_change_test" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="cambiar test" /> </LinearLayout>
Tres: FragmentX (FragmentB, FragmentC)
La lógica de la página secundaria debe definirse según el negocio específico, implementando de la misma manera que un Fragment común
por ejemplo:
public class TestFragment extends BaseFragment { @Nullable @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {return inflater.inflate(R.layout.fragment_test,container,false);} } @Override public void onViewCreated(View view, Bundle savedInstanceState) { super.onViewCreated(view, savedInstanceState); } }
Aquí, se puede implementar de manera simple-Implementar la función de cambio de página mediante la transición de pestañas inferior
Imágenes adjuntas:
PS: Errores que pueden ocurrir durante la implementación
java.lang.IllegalStateException: The specified child already has a parent. You must call removeView() on the child's parent first.
Manera correcta: La inicialización del layout del fragmento relevante debe agregar false, para establecer una relación con el layout del padre.
Razón: Sin agregar, el sistema bindirá un padre desconocido al inflater, y cuando vuelva a bindir este fragment como una subpágina a Activity o otro fragment, se producirá el error mencionado anteriormente.
@Nullable @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { //La forma correcta es: //return inflater.inflate(R.layout.fragment_test, container, false); return inflater.inflate(R.layout.fragment_test, container); }
Esto es todo el contenido de este artículo, espero que sea útil para su aprendizaje y que todos nos apoyen en el tutorial de alarido.
Declaración: El contenido de este artículo se ha obtenido de la red, es propiedad del autor original, el contenido se ha contribuido y subido por los usuarios de Internet, este sitio no posee los derechos de propiedad, no se ha realizado un procesamiento editorial manual y no asume ninguna responsabilidad legal relacionada. Si encuentra contenido sospechoso de infracción de derechos de autor, por favor envíe un correo electrónico a: notice#w3Aviso: Al enviar un correo electrónico, por favor reemplace # con @ para denunciar y proporcionar evidencia relevante. Una vez confirmado, este sitio eliminará inmediatamente el contenido sospechoso de infracción.