美文网首页
ViewPage的使用

ViewPage的使用

作者: 图之 | 来源:发表于2018-10-25 17:02 被阅读0次

    ViewPager是Android扩展包v4包中的类
    作用:
    左右切换当前的view,实现滑动切换的效果
    注意:
    1.ViewPager类直接几层了ViewGroup类,和LinearLayout等布局一样,都是一个容器,需要在里面添加我们想要显示的内容。
    2.ViewPager类需要PagerAdapter适配器类提供数据,与ListView、RecyclerView类似

    使用:
    建立ViewPage的步骤:
    1.在XML布局中加入android.support.v4.view.ViewPager
    2.在activity中加载要显示的页卡
    当需要加载的页卡是View时:

    LayoutInflater lf = getLayoutInflater().from(this);
    view1 = lf.inflate(R.layout.layout1, null);
    view2 = lf.inflate(R.layout.layout2, null);
    view3 = lf.inflate(R.layout.layout3, null);
    viewList = new ArrayList<View>();
    // 将要分页显示的View装入数组中
    viewList.add(view1);
    viewList.add(view2);
    viewList.add(view3);
    

    当需要加载的页卡是Fragment时:

    Fragment1 f1=new Fragment1 ();
    Fragment2 f2=new Fragment2 ();
    Fragment3 f3=new Fragment3();
    Fragment4 f4=new Fragment4 ();
    //将要分页的view装入数组中
    List<Fragment>  list = new ArrayList<Fragment>();
    List.add(f1);
    List.add(f2);
    List.add(f3);
    List.add(f4);
    

    3.用相应的适配器Adapter关联上面的页卡(View/Fragment)和ViewPager
    PagerAdapter 数据源:List<View>
    FragmentPagerAdapter数据源:List<Fragment>
    FragmentStatePagerAdapter数据源:ListView<Fragment>
    当页卡是View时:用ViewPagerAdapter
    当页卡是Fragment时:用FragmentAdapter

    4.在activity里绑定adapter
    ViewPagerAdapter:

    private ViewPager viewPager;
    viewPager.setAdapter(new MyViewPagerAdapter(views));
    viewPager.setCurrentItem(0);
    //设置页面切换时候的监听器(可选,用了之后要重写它的回调方法处理页面切换时候的事务)
    viewPager.setOnPageChangeListener(new MyOnPageChangeListener());
    FragmentPagerAdapter:
    //设置页面切换时的监听器(可选,用了之后要重写它的回调方法处理页面切换时候的事务)
    vp.addOnPageChangeListener(this); vp.setAdapter(new MyFragmentAdapter(getSupportFragmentManager(), list)
    

    5.设置切换、滑动动画
    利用Viewpage自带的方法setPageTransformer()可用于设置切换动画
    步骤:
    1.先定义动画效果类
    DepthPageTransformer.java

    public class DepthPageTransformer implements ViewPager.PageTransformer {
        private static final float MIN_SCALE = 0.75f;                                                         
        public void transformPage(View view, float position) {                                       
            int pageWidth = view.getWidth();                                                                       
            if (position < -1) {      // [-Infinity,-1)                                                                   
                // This page is way off-screen to the left.                                                       
                view.setAlpha(0);                                                                                                 
            } else if (position <= 0) {    // [-1,0]                                                                       
                // Use the default slide transition when moving to the left page                           
                view.setAlpha(1);
                view.setTranslationX(0);
                view.setScaleX(1);
                view.setScaleY(1);
            } else if (position <= 1) {        // (0,1]
                // Fade the page out.
                view.setAlpha(1 - position);
                // Counteract the default slide transition
                view.setTranslationX(pageWidth * -position);
                // Scale the page down (between MIN_SCALE and 1)
                float scaleFactor = MIN_SCALE+ (1 - MIN_SCALE) * (1 - Math.abs(position));
                view.setScaleX(scaleFactor);
                view.setScaleY(scaleFactor);
            } else { // (1,+Infinity]
                // This page is way off-screen to the right.
                view.setAlpha(0);
            }
        }
    }
    

    2.动画方法调用:

    mViewPager.setPageTransformer(true, new DepthPageTransformer());
    

    FragmentStatePagerAdapter 和 FragmentPagerAdapter 的异同:
    • 同

    PageAdapter 是 FragmentPagerAdapter 以及FragmentStatePagerAdapter 的基类,可将上面的FragmentPagerAdapter 替换成FragmentStatePagerAdapter

    • 异

    FragmentPagerAdapter使用时,每一个生成的 Fragment 都将保存在内存之中,而 FragmentStatePagerAdapter 只保留了当前显示的Fragment,其他划过的Fragment离开视线后,就会被销毁;而在页面需要显示时,再生成新的实例。

    即当拥有大量的页面时,使用FragmentStatePagerAdapter不必在内存中占用大量的内存

    相关文章

      网友评论

          本文标题:ViewPage的使用

          本文链接:https://www.haomeiwen.com/subject/xwsctqtx.html