首页 > 程序开发 > 移动开发 > Android >

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

2016-06-27

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

 大家都知道为ViewPager构建适配器继承PagerAdapter,怎么构建就不说了。Viewpager会默认加载当前页和当前页的左右两页。一开始当前页是下标0,所以一开始默认加载第0页(指下标,下同)和第1页。当你向右滑动,当前页为第1页时,ViewPager会加载第2页,这时一共有3页存在(第0,1,2页)。再向右滑动,当前页为第2页时,会移除第0页,加载第3页,同理向左滑动当前页为第1页时,会移除第3页。这么说应该懂了吧。
  知道了上面的原理,就可以让ViewPager始终只加载3页的图片。加载是执行instantiateItem(...)方法,移除是执行destroyItem(...)方法,可以在instantiateItem(...)里加载某一页的图片,在destroyItem(...)里回收某一页的图片。附上代码:
 

 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;
  }
  
 }
}

相关文章
最新文章
热点推荐