重写ViewPager实施单一交有关切换到这个问题,并没有缓存

简介:

我们需要解决这个问题:切换时,可以实现单独的消息到左和右,但我不知道的情况下根据岗位总数。只是不知道ViewPagerAdapter的getCount数量。

因为帖子内容的数据图片和布局比較复杂。所以不让ViewPager缓存。否则消耗内存太大。


重写ViewPager

public class LazyViewPager extends ViewGroup {
	
	private boolean isCanScroll = true;
	
    public boolean isCanScroll() {
		return isCanScroll;
	}

	public void setCanScroll(boolean isCanScroll) {
		this.isCanScroll = isCanScroll;
	}

	private static final String TAG = "LazyViewPager";
    private static final boolean DEBUG = false;

    private static final boolean USE_CACHE = false;

    <span style="color:#ff0000;">private static final int DEFAULT_OFFSCREEN_PAGES = 0;//默认的载入页面,ViewPager是1个,所以会载入两个Fragment</span>
    private static final int MAX_SETTLE_DURATION = 600; // ms


重写ViewPager的setAdapter能够实现单个帖子指定跳转到的页数

public void setAdapter(PagerAdapter adapter,int position) {
        if (mAdapter != null) {
            mAdapter.unregisterDataSetObserver(mObserver);
            mAdapter.startUpdate(this);
            for (int i = 0; i < mItems.size(); i++) {
                final ItemInfo ii = mItems.get(i);
                mAdapter.destroyItem(this, ii.position, ii.object);
            }
            mAdapter.finishUpdate(this);
            mItems.clear();
            removeAllViews();
            mCurItem = 0;
            scrollTo(0, 0);
        }

        mAdapter = adapter;

        if (mAdapter != null) {
            if (mObserver == null) {
                mObserver = new PagerObserver();
            }
            mAdapter.registerDataSetObserver(mObserver);
            mPopulatePending = false;
            if (mRestoredCurItem >= 0) {
                mAdapter.restoreState(mRestoredAdapterState, mRestoredClassLoader);
               <span style="color:#ff0000;"> if(position>0){
                	setCurrentItemInternal(position, false, true);
                }else{
                	setCurrentItemInternal(mRestoredCurItem, false, true);
                }</span>
                mRestoredCurItem = -1;
                mRestoredAdapterState = null;
                mRestoredClassLoader = null;
            } else {
                populate(position);
            }
        }
    }

只是前提是设置这个ViewPager的Adapter的getCount的数量为1000或者Integer.Max


假设要实现ViewPager的Fragment不反复运行onCreateView方法,须要重写destroyItem

private class MyFragmentAdapter extends FragmentPagerAdapter{

		public MyFragmentAdapter(FragmentManager fm) {
			super(fm);
			// TODO Auto-generated constructor stub
		}

		@Override
		public Fragment getItem(int arg0) {
			// TODO Auto-generated method stub
			MyFragment fragment = new MyFragment(arg0);
			return fragment;
		}

		@Override
		public int getCount() {
			// TODO Auto-generated method stub
			return 10;
		}
		
		@Override
		public void destroyItem(ViewGroup container, int position, Object object) {
			// TODO Auto-generated method stub
//			super.destroyItem(container, position, object);
		}
		
		@Override
		public void destroyItem(View container, int position, Object object) {
			// TODO Auto-generated method stub
//			super.destroyItem(container, position, object);
		}
	}

假设要设置ViewPager实现左右无限切换,能够通过重写Adapter的getItem()方法。


@Override
		public Fragment getItem(int arg0) {
			// TODO Auto-generated method stub
			MyFragment fragment = fragments.get(arg0%4);
			return fragment;
		}

前提是getCount是个非常大的数

复制去Google翻译 翻译结果
MyFragment 为arg0

版权声明:本文博主原创文章,博客,未经同意不得转载。






本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/4882506.html,如需转载请自行联系原作者


相关文章
|
缓存 NoSQL Redis
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(七)
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(七)
157 0
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(七)
|
缓存 NoSQL Redis
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(六)
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(六)
171 0
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(六)
|
缓存 NoSQL Redis
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(五)
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(五)
149 0
|
缓存 NoSQL Redis
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(四)
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(四)
173 0
|
缓存 NoSQL Redis
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(三)
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(三)
171 0
|
缓存 NoSQL Redis
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(二)
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(二)
140 0
|
缓存 NoSQL Redis
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(一)
REDIS02_基于SpringBoot+Mybatis+Redis重写Redis的序列化的缓存实战(一)
142 0
|
缓存 Java 容器
【第五篇】Volley代码修改之图片二级缓存以及相关源码阅读(重写ImageLoader.ImageCache)
前面http://www.cnblogs.com/androidsuperman/p/8a157b18ede85caa61ca5bc04bba43d0.html 有讲到使用LRU来处理缓存的,但是只是处理内存里面的缓存,没进行文件缓存和处理,那么如何实现Volley在本地的缓存呢 一般硬盘缓存使用com.
914 0
|
1月前
|
消息中间件 缓存 NoSQL
Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
74 6