- xml布局
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v4.view.ViewPager>
2.获取控件并添加适配器(传过去一个上下文和集合)
vp.setAdapter(new ImagePager(MainActivity.this,list));
3.创建适配器继承PagerAdapter并实现其中的两个抽象方法,还需在重写两个抽象方法
destroyItem和instantiateItem
import android.content.Context;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import com.example.lx1018.MainActivity;
import com.example.lx1018.ulit.ImageloaderUtil;
import com.nostra13.universalimageloader.core.ImageLoader;
import java.util.List;
/**
* Created by Administrator on 2017/10/19 0019.
*/
public class ImagePager extends PagerAdapter {
private Context context;
private List<String> list;
public ImagePager(Context context, List<String> list) {
this.context = context;
this.list = list;
}
//返回viewpager的总数
@Override
public int getCount() {
return Integer.MAX_VALUE;
}
//视图跟下标相同
@Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
}
//添加视图
@Override
public Object instantiateItem(ViewGroup container, int position) {
//返回当前显示的视图
ImageView imageView = new ImageView(context);
//设置图片的平铺
imageView.setScaleType(ImageView.ScaleType.FIT_XY);
//加载网络的图片list.get(position%list.size())
ImageLoader.getInstance().displayImage(list.get(position%list.size()),imageView, ImageloaderUtil.getImageOptions());
//添加到容器
container.addView(imageView);
return imageView;
}
//移除视图
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View) object);
}
}
4.设置初始化位置
vp.setCurrentItem(list.size()*1000);