在Adapter中重写getItemPosition方法,这么做的原因google一下应该都能找到蛮多的解释的,在这边也简单的理解一下,当数据改变时想要动态的更新ViewPager的显示时,如果有用过BaseAdapter重写过的一般都知道可以直接调用adapter.notifyDataSetChanged()来动态的更新数据的显示;但是在这里调用notifyDataSetChanged却发现ViewPager并没有进行相应的数据更新(具体原因是什么现在还不是很理解,可以的话有空查看一下源代码);重写getItemPosition让它返回POSITOIN_NONE;这样做的目的是notifyDataSetChanged时返回空,这样就会从数据重新填充,再外部更新数据然后调用notifyDataSetChanged更新就达到了目的了。 具体的Adapter代码如下:public classImageScanAdapater extends PagerAdapter{
private List mListViews;
public ImageScanAdapater(Listlists){
this.mListViews = lists;
}
@Override
public int getCount() {
return mListViews.size();
}
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
return arg0 == arg1;
}
@Override
public void destroyItem(View container, int position, Object object) {
((ImageViewTouchViewPager)container).removeView((View)object);
}
@Override
public ObjectinstantiateItem(View container, intposition) {
((ImageViewTouchViewPager)container).addView(mListViews.get(position), 0);
return mListViews.get(position);
}
@Override
public Parcelable saveState(){
return null;
}
@Override
public int getItemPosition(Object object) {
return POSITION_NONE;
}
}
然后外部就可以想BaseAdapter一样更新数据了,但是google出来的说这样对内存的开销比较浪费;不过想一下也明白了,每次更新都要重新填充一遍,所以浪费是必须,但现在也等着用浪费就浪费吧,
最后如果简单的更新View的显示,可以设置Tag,通过findViewByTag来更新,不用这么浪费的。
以后可能再深入。