布局文件:
<android.support.v4.view.ViewPager
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1" />
<RadioGroup
android:id="@+id/radioGroup1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:gravity="center">
</RadioGroup>
MainActivity代码:
public class MainActivity extends Activity {
private RadioGroup radioGroup;
private ViewPager pager;
@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);
// 创建RadioButton
RadioButton button = new RadioButton(MainActivity.this);
// 把RadioButton加入到RadioGroup中
radioGroup.addView(button);
}
// 7设置适配器
pager.setAdapter(new MyPagerAdapter(list));
// 15小圆点的实现
radioGroup = (RadioGroup) findViewById(R.id.radioGroup1);
// 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;
}
};
};
}
适配器代码:
//8 继承PagerAdapter
public class MyPagerAdapter extends PagerAdapter {
// 9设置属性 并且创建有参构造方法
private ArrayList<ImageView> 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 );
}
}