一直以来想搞明白这个不完全的VIewPager是怎么做到的,有幸看到这片篇文章

有二种实现方法

1.设置的属性

  1.clipChildren属性

  2.setPageMargin

  3.更新Item外界面

2.重写getPageWidth

  public class MultiplePagerAdapter extends PagerAdapter {
    private List<Integer> mList;
    private LayoutInflater layoutInflater;

    public MultiplePagerAdapter(Context context, List<Integer> list) {
        super();
        this.mList = list;
        layoutInflater = LayoutInflater.from(context);
    }

    @Override
    public int getCount() {
        return mList.size();
    }

    @Override
    public boolean isViewFromObject(View view, Object object) {
        return view == object;
    }

    /**
     * 页面宽度所占ViewPager测量宽度的权重比例,默认为1
     */
    @Override
    public float getPageWidth(int position) {
        return (float) 0.8;
    }

    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        View view = (View) object;
        ((ViewPager) container).removeView(view);
    }

    @Override
    public Object instantiateItem(ViewGroup container, int position) {

        // 自己实现
        return null;
    }
}

自定义控件_VIewPager显示多个Item

 

相关文章:

  • 2022-01-21
  • 2021-06-07
  • 2022-12-23
  • 2022-12-23
  • 2021-08-02
  • 2021-08-10
  • 2022-12-23
猜你喜欢
  • 2021-09-02
  • 2021-06-02
  • 2022-12-23
  • 2021-07-26
  • 2021-10-25
  • 2021-11-23
相关资源
相似解决方案