当前位置:主页 > 移动开发 > Android代码 >

android 解决ViewPager加载大量图片内存溢出问题

时间:2021-01-26 15:24:10 | 栏目:Android代码 | 点击:

1.大家都知道为ViewPager构建适配器继承PagerAdapter,怎么构建就不说了。Viewpager会默认加载当前页和当前页的左右两页。一开始当前页是下标0,所以一开始默认加载第0页(指下标,下同)和第1页。当你向右滑动,当前页为第1页时,ViewPager会加载第2页,这时一共有3页存在(第0,1,2页)。再向右滑动,当前页为第2页时,会移除第0页,加载第3页,同理向左滑动当前页为第1页时,会移除第3页。这么说应该懂了吧。

知道了上面的原理,就可以让ViewPager始终只加载3页的图片。加载是执行instantiateItem(...)方法,移除是执行destroyItem(...)方法,可以在instantiateItem(...)里加载某一页的图片,在destroyItem(...)里回收某一页的图片。附上代码:

2.代码实例:

package com.example.test;
 
import java.util.ArrayList;
 
import android.app.Activity;
import android.os.Bundle;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.View;
import android.widget.ImageView;
 
public class TestActivity extends Activity{
 
 private ViewPager mPager;
 private ArrayList<View> views;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 views=new ArrayList<View>();
 views.add(new ImageView(this));
 views.add(new ImageView(this));
 views.add(new ImageView(this));
 views.add(new ImageView(this));
 views.add(new ImageView(this));
 views.add(new ImageView(this));
 views.add(new ImageView(this));
 views.add(new ImageView(this));
  
 mPager=new ViewPager(this);
 mPager.setAdapter(new MyPagerAdapter());
 setContentView(mPager);
 }
 
 class MyPagerAdapter extends PagerAdapter{
 
 @Override
 public void destroyItem(View container, int position, Object object) {
  //在此次回收图片
  //........回收代码
  
  //移除页面
  ((ViewPager)container).removeView(views.get(position));
 }
 
 @Override
 public Object instantiateItem(View container, int position) {
  // 在此次加载图片
  //......加载图片代码
  
  //加载页面
  ((ViewPager)container).addView(views.get(position), 0);
  return views.get(position);
 }
 
 @Override
 public int getCount() {
  // TODO Auto-generated method stub
  return views.size();
 }
 
 @Override
 public boolean isViewFromObject(View arg0, Object arg1) {
  // TODO Auto-generated method stub
  return false;
 }
  
 }
}

您可能感兴趣的文章:

相关文章