ViewPager加载图片控件:
ViewPager会默认加载当前页和当前页的左右两页。
一开始当前页是下标0,所以一开始默认加载第0页(指下标,下同)和第1页。
当你向右滑动,当前页为第1页时,ViewPager会加载第2页,这时一共有3页存在(第0,1,2页)。
再向右滑动,当前页为第2页时,会移除第0页,加载第3页,同理向左滑动当前页为第1页时,会移除第3页。
所以我们可以通过这个原理使ViewPager始终只加载3页的图片。
如何实现呢?
只需在在PagerAdapter中的instantiateItem(...)与destroyItem(...) 方法中添加加载与移除图片的实现
instantiateItem(...) |
加载图片 |
destroyItem(...) |
移除回收图片 |
ViewPager+Fragment
我们不希望加载预加载下一页,只需加载用户关注的当前页。因为预加载的话,消耗资源,甚至肯能导致一些异常。这是我们所讨厌的。
简单的实现
自己定义个类,将ViewPager的源代码copy到其中,修改DEFAULT_OFFSCREEN_PAGES = 0。
通过setOffscreenPageLimit(0)来设置不提前预加载,但这样的设置没有效果。
通过研究ViewPager的 源码可以设置该类默认的DEFAULT_OFFSCREEN_PAGES = 0,来预防预加载
ViewPager加载图片控件:
ViewPager会默认加载当前页和当前页的左右两页。
一开始当前页是下标0,所以一开始默认加载第0页(指下标,下同)和第1页。
当你向右滑动,当前页为第1页时,ViewPager会加载第2页,这时一共有3页存在(第0,1,2页)。
再向右滑动,当前页为第2页时,会移除第0页,加载第3页,同理向左滑动当前页为第1页时,会移除第3页。
所以我们可以通过这个原理使ViewPager始终只加载3页的图片。
如何实现呢?
只需在在PagerAdapter中的instantiateItem(...)与destroyItem(...) 方法中添加加载与移除图片的实现
instantiateItem(...) |
加载图片 |
destroyItem(...) |
移除回收图片 |
ViewPager+Fragment
我们不希望加载预加载下一页,只需加载用户关注的当前页。因为预加载的话,消耗资源,甚至肯能导致一些异常。这是我们所讨厌的。
简单的实现
自己定义个类,将ViewPager的源代码copy到其中,修改DEFAULT_OFFSCREEN_PAGES = 0。
通过setOffscreenPageLimit(0)来设置不提前预加载,但这样的设置没有效果。
通过研究ViewPager的 源码可以设置该类默认的DEFAULT_OFFSCREEN_PAGES = 0,来预防预加载