1 对于Gallery的循环滚动,设置adapter的getCount为Integer.MAX_VALUE。滚动切换效果没有ViewPager好看
public class GalleryAdapter extends BaseAdapter {
private List<ImageView> list;
public GalleryAdapter(List<ImageView> list){
this.list = list;
}
public int getCount() {
return Integer.MAX_VALUE; //让Gallery可以右侧循环滚动
}
public Object getItem(int position) {
return list.get(position % list.size());
}
public long getItemId(int position) {
return position;
}
public View getView(int position, View convertView, ViewGroup parent) {
return list.get(position % list.size());//让Gallery可以右侧循环滚动
}
}
2 ViewPager的循环滚动,也可通过设置Count来实现,但是数量有一定的不足之处,本demo实现了ViewPager的单向循环滚动和双向循环滚动,都使用了2种方式,详见demo
// 指引页面数据适配器
class GuidePageAdapter extends PagerAdapter {
private List<ImageView> pageViews;
public GuidePageAdapter(List<ImageView> list) {
pageViews = list;
}
public int getCount() {
return pageViews.size();
}
public boolean isViewFromObject(View arg0, Object arg1) {
return arg0 == arg1;
}
public int getItemPosition(Object object) {
return super.getItemPosition(object);
}
public void destroyItem(View arg0, int arg1, Object arg2) {
((ViewPager) arg0).removeView(pageViews.get(arg1));
}
public Object instantiateItem(View arg0, int arg1) {
((ViewPager) arg0).addView(pageViews.get(arg1));
return pageViews.get(arg1);
}
public void restoreState(Parcelable arg0, ClassLoader arg1) {
}
public Parcelable saveState() {
return null;
}
public void startUpdate(View arg0) {
}
public void finishUpdate(View arg0) {
}
}