ViewPager无限轮播图

//布局文件
<android.support.v4.view.ViewPager
android:id="@+id/pager"
android:layout_width=“match_parent”
android:layout_height=“400dp”
></android.support.v4.view.ViewPager>

//MainActivity
public class MainActivity extends Activity {

private RadioGroup radioGroup;

@Override
protected void onCreate(Bundle savedInstanceState) {
	super.onCreate(savedInstanceState);
	setContentView(R.layout.activity_main);
	// 1写Viewpager 找到控件
	pager = (ViewPager) findViewById(R.id.pager);
	// 2数据
	int arr[] = { R.drawable.a1, R.drawable.a12, R.drawable.a4,
			R.drawable.a5, R.drawable.a8 };
	// 3把数据添加到集合
	final ArrayList<ImageView> list = new ArrayList<ImageView>();
	for (int i = 0; i < arr.length; i++) {
		// 4创建一个 imageview
		ImageView imageView = new ImageView(MainActivity.this);
		// 5设置图片
		imageView.setImageResource(arr[i]);
		// 6加入几何
		list.add(imageView);
	}
	// 7设置适配器
	pager.setAdapter(new MyPagerAdapter(list));
	// 15小圆点的实现
	radioGroup = (RadioGroup) findViewById(R.id.radioGroup1);
	// 16创建RadioButton
	for (int i = 0; i < arr.length; i++) {
		// 创建RadioButton
		RadioButton button = new RadioButton(MainActivity.this);
		// 把RadioButton加入到RadioGroup中
		radioGroup.addView(button);
	}
	// 17设置第一个点选中
	// check()选中
	// radioGroup.getChildAt(0).getId()获取id
	radioGroup.check(radioGroup.getChildAt(0).getId());
	// 18 实现 页面和远点的联动
	// Viewpager 页面切换事件
	pager.setOnPageChangeListener(new OnPageChangeListener() {

		@Override
		public void onPageSelected(int arg0) {
			//由于页面无限了 所以arg0也变成无限大了
			arg0=arg0%list.size();
			// 页面切换成功会调用这个方法
			// 页面切换成功后 ,我肯要选中对应的小圆点
			radioGroup.check(radioGroup.getChildAt(arg0).getId());
		}

		@Override
		public void onPageScrolled(int arg0, float arg1, int arg2) {
			// 页面滑动

		}

		@Override
		public void onPageScrollStateChanged(int arg0) {
			// 滑动状态改变调用

		}
	});
	// 19实现自动轮播
	handler.sendEmptyMessageDelayed(0, 3000);
	//21实现无限轮播
}

Handler handler = new Handler() {
	public void handleMessage(android.os.Message msg) {
		switch (msg.what) {
		case 0:
			//20切换页面
			//要先知道我在展示那个页面
			int currentItem = pager.getCurrentItem();
			//得到展示页面的索引 索引加一
			currentItem+=1;
			// 设置给Viewpager
			pager.setCurrentItem(currentItem);
			handler.sendEmptyMessageDelayed(0, 3000); 
			break;

		}
	};
};
private ViewPager pager;

}

//适配器
//8 继承PagerAdapter
public class MyPagerAdapter extends PagerAdapter {
// 9设置属性 并且创建有参构造方法
private ArrayList list;

public MyPagerAdapter(ArrayList<ImageView> list) {
	super();
	this.list = list;
}

@Override//有多少个页面
public int getCount() {
	// 10返回list.size();

// return list.size();
//21页面无限
return Integer.MAX_VALUE;
}

@Override
public boolean isViewFromObject(View arg0, Object arg1) {
	// 11 arg0==arg1;
	return arg0==arg1;
}

@Override
public Object instantiateItem(ViewGroup container, int position) {
	//22由于页面无限了所以position也变成无限大了( %取余  )
	position=position%list.size();
	//12获取集合中的imageview
	 ImageView imageView = list.get(position);
	 //13把imageview加入viewpager 中
	 container.addView(imageView);
	 //返回imagerview
	 return imageView;
}

@Override
public void destroyItem(ViewGroup container, int position, Object object) {
	 //14移除imageview
	container.removeView((View) object );
	
}

}

猜你喜欢

转载自blog.csdn.net/qq_43040490/article/details/84966406