English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Android-Código de Implementação da Função de Alternância de Fragmento da Página

Cenário: usar Fragment para implementar a troca de páginas.

Estrutura da classe:

Um: Activity

Na Activity, usar getSupportFragmentManager().beginTransaction() para preencher um Fragment (FragmentA usado para gerenciamento)

Código da 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"/> 

Dois: FragmentA

Carregar um Fragment principal FragmentA, como gerenciador de outros subfragmentos FragmentX.

Agora, por exemplo, há dois subfragmentos FragmentB e FragmentC.

FragmentA usa FragmentManager e FragmentTransaction para gerenciar a troca de FragmentB e 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 troca de Fragment (FragmentB, FragmentC)
  //tab é o nome da classe do Fragment (por exemplo: FragmentB.class.getName())
  //R.id.fl_container está no layout da Activity, não no layout do FragmentA
  private void switchTo(String tab, Bundle bundle){
    //Inicializar a classe que gerencia Fragment
    FragmentManager fm = getFragmentManager();
    if (fm == null){
      return;
    }
    FragmentTransaction ft = fm.beginTransaction();
    //Procurar Fragment de classe tab noFragmentManager
    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);
    }
    //oculta o Fragment atualmente exibido
    if (mLastShowFragment != null) {
      ft.hide(mLastShowFragment);
    }
    //registra o último Fragment 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="alternar home"
    />
  <Button
    android:id="@"+id/btn_change_test"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="alternar test"
    />
</LinearLayout> 

Três: FragmentX (FragmentB, FragmentC)

A lógica da página filha deve ser definida conforme o negócio específico, implementando da mesma forma que um Fragmeng comum

 por exemplo:

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

Aqui, é possível implementar de maneira simples-Implementar a função de troca de páginas usando Tab no fundo para alternar entre fragments

Figura adjunta:

 

PS: Erros que podem ocorrer durante a implementação 

java.lang.IllegalStateException: The specified child already has a parent. You must call removeView() on the child's parent first.

Método correto: O layout de inicialização do fragment relacionado deve incluir false, estabelecendo uma relação com o layout do pai.

Razão: Sem isso, o sistema associará um pai desconhecido ao inflater. Quando você usar esse fragment como uma subpágina ligada a um Activity ou outro fragment, ocorrerá o erro acima.

@Nullable
  @Override
  public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
    //A forma correta é:
    //return inflater.inflate(R.layout.fragment_test, container, false);
    return inflater.inflate(R.layout.fragment_test, container);
   }   

 Isso é tudo o que há no artigo. Espero que ajude no seu aprendizado e que você apoie o tutorial Yell.

Declaração: O conteúdo deste artigo é extraído da Internet, pertence ao respectivo proprietário, fornecido voluntariamente pelos usuários da Internet e carregado automaticamente. Este site não possui direitos de propriedade, não foi editado manualmente e não assume responsabilidade legal. Se encontrar conteúdo suspeito de violação de direitos autorais, por favor, envie um e-mail para: notice#w3Aviso: Quando enviar um e-mail para denunciar, substitua # por @ e forneça provas relevantes. Se confirmado, o conteúdo suspeito de violação de direitos autorais será removido imediatamente.

Você Também Pode Gostar