zoukankan      html  css  js  c++  java
  • ViewPager结合Fragment进行无限滑动

    实现ViewPager结合Fragment实现无限循环切换,这里也是在适配器里面进行的,当然使用滑动监听也能够实现

    
    import android.support.v4.app.Fragment;
    import android.support.v4.app.FragmentManager;
    import android.support.v4.app.FragmentPagerAdapter;
    import android.view.ViewGroup;
    
    import java.util.ArrayList;
    
    public class adapter extends FragmentPagerAdapter
    {
    private ArrayList<Fragment> fragmentList; public adapter(FragmentManager fm) { super(fm); } public adapter(FragmentManager fm, ArrayList<Fragment> fragmentList) { super(fm); this.fragmentList=fragmentList; } @Override public Fragment getItem(int position) { //在这里不处理position的原因是因为getItem方法在 //instantiateItem方法中调用。只要在调用前处理 //position即可,以免重复处理 return fragmentList.get(position); } @Override public int getCount()
    {
    return Integer.MAX_VALUE; } @Override public int getItemPosition(Object object)
    {
    return super.getItemPosition(object); } @Override public Object instantiateItem(ViewGroup container, int position)
    {
    //处理position。让数组下标落在[0,fragmentList.size)中,防止越界 position = position % fragmentList.size(); return super.instantiateItem(container, position); } }

    以上参考:博客http://www.ilrose.com/blog/2015/12/09/android-viewpager%E5%AE%9E%E7%8E%B0%E6%97%A0%E9%99%90%E5%BE%AA%E7%8E%AF%E6%BB%91%E5%8A%A8/ 

    经过实际检验,要传进4个fragment,否则往右边滑动会出现问题,原因不知......

    想要实现答题界面的翻页效果便可以采用这种方法,可以建立一个ReadFragment,然后new 出4个这个Fragment的对象。不同页面的共同的处理可以直接在ReadFragment里头实现,翻页的时候每一页需要改变的参数可以在滑动监听器里获取这4个对象来实现。

            Fragment a=new ReadFragment();
            Fragment b=new ReadFragment();
            Fragment c=new ReadFragment();
            Fragment d=new ReadFragment();
    
            list=new ArrayList<Fragment>();
            list.add(a);
            list.add(b);
            list.add(c);
            list.add(d);
    readViewPager.setAdapter(new adapter(getSupportFragmentManager(),list));
    readViewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener()
            {
                @Override
                public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels)
                {}
    
                @Override
                public void onPageSelected(int position)
                {
    //处理position。让position落在[0,fragmentList.size)中,防止数组越界 position
    = position % list.size(); ReadFragment fragment= (ReadFragment) list.get(position); //获得此时选中的fragment fragment.refreshState(); //翻页的时候每个页面需要改变的参数使用这个方法来实现,这个方法在ReadFragment里面,修饰器得使用public
      ... } @Override
    public void onPageScrollStateChanged(int state) {} });

    后来我发现以上这种刷新fragment的方法有个弊端,就是展示出来的第一页无法得到刷新,因为第一页显示的时候不会去调用onPageSelected,得单独处理

    以上便可以实现答题翻页。当然少不了翻页动画的实现,这个下一篇博客单独讲

  • 相关阅读:
    Linux安装软件时90%的人会遇到这个报错,如何解决?
    mongo下查询ObjectId(id)类型的数据
    解决nohup启动logstash生成的文件过大的问题
    ES集群服务器下线节点扩容后上线的流程
    knife4j的使用记录
    mongodb的update函数更新数据,更新文档中的某个具体字段的数据
    Python celery异步框架
    VueX插件使用
    Vue-router插件使用
    Vue 自定义指令
  • 原文地址:https://www.cnblogs.com/tangZH/p/6516566.html
Copyright © 2011-2022 走看看