簡體   English   中英

使用 ViewPager2 在 AlertDialog 中自定義 TabLayout

[英]Custom TabLayout in AlertDialog using ViewPager2

我對編寫應用程序比較陌生,目前正在我的第二個項目中工作。 我有一個名為AddNetwork的活動,其中包含一個應該打開AlertDialog的按鈕。 AlertDialog我想要一個帶有兩個選項卡的TabLayout ,每個選項卡都顯示不同的內容。 我一直試圖實現這一目標大約 8 個小時,我發現了一些教程可以部分解決我的問題,但沒有什么是真正切中要害的。 我想我可以使用ViewPager2解決我的問題,但我還沒有設法讓它工作。 截至目前,我的代碼工作如下:

AddNetwork.java創建的實例AlertDialogSelectWifi.java ,延伸DialogFragment和膨脹的alertdialog_select_wifi.XML包含布局文件TabLayoutViewPager2 另外,在DialogFragment ,我想設置一個適配器的viewPager ,即ViewPagerAdapter.java ,延伸FragmentStateAdapter 從那里我想附加兩個片段AlertDialogRecentFragment.java (帶有fragment_alert_dialog_recent.xml )和AlertDialogTypeFragment.java (帶有fragment_alert_dialog_type.xml )。 請注意,后者尚未包含在代碼中,因此到目前為止我只會向選項卡添加一個片段(我猜)。 所以目前,我的代碼是我找到並遵循的所有教程的有點混亂的混合體。 它不會導致任何錯誤,我可以打開 Alertdialog,但是, fragment_alert_dialog_recent.xml和選項卡不可見。 我真的不知道我還可以嘗試或更改我的代碼。 總的來說,我不確定在AlertDialogSelectWifi.java文件中設置ViewPagerAdapter是否正確。 我錯過了什么或做錯了什么? 非常感謝任何幫助!

這是我的代碼:

添加網絡.java

public class AddNetwork extends AppCompatActivity {

    Context context = this;

    @Override
    protected void onCreate(final Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_add_network);


        //BUTTON
        final MaterialButton buttonSelectWifi;
        buttonSelectWifi = (MaterialButton) findViewById(R.id.button2);
        buttonSelectWifi.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {

                //CREATE ALERT DIALOG
                FragmentManager fm = getSupportFragmentManager();
                DialogFragment dialog = AlertDialogSelectWifi.newInstance(context);
                dialog.show(fm, "dialog");

            }
        });
    }
}

AlertDialogSelectWifi.java

public class AlertDialogSelectWifi extends DialogFragment {

    static Context mContext;

    public static AlertDialogSelectWifi newInstance(Context context) {
        mContext = context;
        return new AlertDialogSelectWifi();
    }


    @NonNull
    @Override
    public Dialog onCreateDialog(@Nullable Bundle savedInstanceState) {
        AlertDialog.Builder builder = new AlertDialog.Builder(getActivity(), R.style.AlertDialogTheme);

        LayoutInflater inflater = requireActivity().getLayoutInflater(); //getActivity().getLayoutInflater();
        View alertLayout = inflater.inflate(R.layout.alertdialog_select_wifi, null);

        builder.setTitle("Add Saved Network")
                .setView(alertLayout)
                .setCancelable(true)
                .setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        dialog.dismiss();
                    }
                });

        return builder.create();
    }

    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.alertdialog_select_wifi, container, false);
        return view;
    }

    @Override
    public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);


        ViewPager2 viewPager = view.findViewById(R.id.viewpager);
        TabLayout tabLayout = view.findViewById(R.id.tablayout);
        ViewPagerAdapter adapter = new ViewPagerAdapter(getActivity(), mContext, viewPager);

        viewPager.setAdapter(adapter);

        new TabLayoutMediator(tabLayout, viewPager,
                new TabLayoutMediator.TabConfigurationStrategy() {
                    @Override
                    public void onConfigureTab(@NonNull TabLayout.Tab tab, int position) {
                        tab.setText("Tab " + (position + 1));
                    }
                }).attach();
    }
}

ViewPageAdapter.java

public class ViewPagerAdapter extends FragmentStateAdapter {

    private LayoutInflater mInflater;
    private ViewPager2 viewPager;

    public  ViewPagerAdapter(FragmentActivity fragmentActivity, Context context, ViewPager2 viewPager) {
        super(fragmentActivity);
        this.mInflater = LayoutInflater.from(context);
        this.viewPager = viewPager;
    }

    @NonNull
    @Override
    public Fragment createFragment(int position) {
        return AlertDialogRecentFragment.newInstance();
    }

    @Override
    public int getItemCount() {
        return 0;
    }
}

如果我正確理解您的問題,請像這樣更改您的適配器:

public class ViewPagerAdapter extends FragmentStateAdapter {

public  ViewPagerAdapter(FragmentActivity fragmentActivity) {
    super(fragmentActivity);
}

@NonNull
@Override
public Fragment createFragment(int position) {
    if(position == 0)
    return new AlertDialogRecentFragment();
    else
    return new AlertDialogTypeFragment();
}

  @Override
  public int getItemCount() {
    return 2;
  }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM