如何在Android ViewPager2 中动态添加和删除页面? [英] How to dynamically add and remove pages in Android ViewPager2?

查看:514
本文介绍了如何在Android ViewPager2 中动态添加和删除页面?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

这就是我想要做的.addNewQRCard() 是由按钮触发的 onclick 事件,用于向 viewpager 添加新图像.我必须始终将适配器设置为新项目.但是为什么在我的情况下 onStart() 不做那件事.请给我最佳实践,我应该使用它从 viewPager2 动态添加和删除视图.

Here is what I was trying to do. addNewQRCard() is onclick event fired by a button to add new images to viewpager. I have to always set the adapter to new items. But why in my case onStart() doesn't do that job. Please give me the best practice that I should use to add and delete views dynamically from viewPager2.

public class AddPage extends AppCompatActivity {

    private ViewPager2 viewPager2;
    private ArrayList<ModelItem> items;
    private AdapterSlider adapter;

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

        viewPager2 = findViewById(R.id.viewPagerImageSlider);

        items = new ArrayList<>();
        items.add(new ModelItem(R.drawable.image1));


        adapter = new AdapterSlider(items,viewPager2);

        viewPager2.setAdapter(adapter);

        viewPager2.setClipToPadding(false);
        viewPager2.setClipChildren(false);
        viewPager2.setOffscreenPageLimit(3);
        viewPager2.getChildAt(0).setOverScrollMode(RecyclerView.OVER_SCROLL_NEVER);

        CompositePageTransformer compositePageTransformer = new CompositePageTransformer();
        compositePageTransformer.addTransformer(new MarginPageTransformer(40));
        compositePageTransformer.addTransformer(new ViewPager2.PageTransformer() {
            @Override
            public void transformPage(@NonNull View page, float position) {
                float r = 1 - Math.abs(position);
                page.setScaleY(0.85f + r * 0.15f);
            }
        });

        viewPager2.setPageTransformer(compositePageTransformer);
    }

    @Override
    protected void onStart() {
        super.onStart();
        adapter = new AdapterQRSlider(sliderItems,viewPager2);

        viewPager2.setAdapter(adapter);
    }

    public void addNewQRCard(View view) {   //this is the button which i used to add new childs
        items.add(new ModelSlider(R.drawable.image2));

        adapter = new AdapterSlider(items,viewPager2);

        viewPager2.setAdapter(adapter);
    }
}

适配器类

public class AdapterSliderextends RecyclerView.Adapter<AdapterSlider.ViewHolder>{

    private ArrayList<ModelSlider> items;
    private ViewPager2 viewPager2;

    public AdapterSlider(ArrayList<ModelSlider> items, ViewPager2 viewPager2) {
        this.items= items;
        this.viewPager2 = viewPager2;
    }

    @NonNull
    @Override
    public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        return new ViewHolder(
                LayoutInflater.from(parent.getContext()).inflate(
                        R.layout.slide_item_container,
                        parent,
                        false
                )
        );
    }

    @Override
    public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
        holder.setImage(items.get(position));
    }

    @Override
    public int getItemCount() {
        return items.size();
    }

    class ViewHolder extends RecyclerView.ViewHolder{

        private ImageView imageView;

        public ViewHolder(@NonNull View itemView) {
            super(itemView);
            imageView = itemView.findViewById(R.id.imageSlide);
        }

        void setImage(ModelSlider items){
            imageView.setImageResource(sliderItem.getImage());
        }
    }
}

模型类

public class ModelSlider {

    private int image;

    public ModelSlider(int image){
        this.image = image;
    }

    public int getImage() {
        return image;
    }
}

推荐答案

您可以在添加新项目时通知适配器,就像使用 RecyclerView 一样.像这样

You can notify adapter when you adding new items just like the way you do it with RecyclerView. Something like this

public void addNewQRCard(View view) {
    items.add(new ModelSlider(R.drawable.image2));
    // instead of of resetting adapter to ViewPager,
    // just notify its adapter of item inserted
    adapter.notifyItemInserted(items.size - 1)
}

这篇关于如何在Android ViewPager2 中动态添加和删除页面?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆