该适配器可以让图片产生滑动效果,需要写入需要的图片,创建一个集合将图片放进去
views = new ArrayList<>();
ImageView view1 = new ImageView(this);
ImageView view2 = new ImageView(this);
ImageView view3 = new ImageView(this);
view1.setBackgroundResource(R.drawable.one);
views.add(view1);
view2.setBackgroundResource(R.drawable.two);
views.add(view2);
view3.setBackgroundResource(R.drawable.tree);
views.add(view3);
然后自定义适配器继承PagerAdpter,第一个getCount()写集合的数量,第二个isViewFromObject按照官方那样写,view=object
然后要重写两个方法,一个是获取item元素,container.addView(集合.get(postion)) 添加视图,然后返回视图
第二是删除元素 destroyItem方法 调用removeView删除视图,然后填入集合获取位置,这里如果有个父类调用记得删除,否则到最后一张会报错闪退。
class MyPagerAdapter extends PagerAdapter {
@Override
public int getCount() {
return views.size();
}
@Override
public boolean isViewFromObject(@NonNull View view, @NonNull Object object) {
return view==object;
}
@NonNull
@Override
public Object instantiateItem(@NonNull ViewGroup container, int position) {
container.addView(views.get(position));
return views.get(position);
}
@Override
public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
container.removeView(views.get(position));
}
}
最后再添加适配器,这里可以添加事件,比如滑动到哪个按钮就显示按钮,先隐藏按钮,需要onPageSelected里判断位置是否到了想设置的那一页,然后给button设置显示。
MyPagerAdapter adapter = new MyPagerAdapter();
pager.setAdapter(adapter);
pager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageSelected(int position) {
if (position == 2) {
btn.setVisibility(View.VISIBLE);
} else {
btn.setVisibility(View.GONE);
}
}
@Override
public void onPageScrollStateChanged(int state) {
}
});
图片资源一定要放在drawable里,如果放其他地方引用会导致图片不显示,如果图片有白,可以设置setBackgroundResource,这样就会填满整个Pager,不会留缝隙,