简单的应用Android的轮播图

刚开始使用轮播图搞不定,是新手经常遇到的问题,下面放一段代码,给大家参考。


public class MainActivity extends Activity {

int[] images = null;//图片资源ID
String[] titles = null;//标题

ArrayList<ImageView> imageSource = null;//图片资源
ArrayList<View> dots = null;//点
TextView title = null;
ViewPager viewPager;//用于显示图片
MyPagerAdapter  adapter;//viewPager的适配器
private  int currPage = 0;//当前显示的页
private  int oldPage = 0;//上一次显示的页
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

init();
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}

public void init(){
images = new int[]{
R.drawable.a,
R.drawable.b,
R.drawable.c,
R.drawable.d,
R.drawable.e
};
titles = new String[]{
"这是第1张图片",
"这是第2张图片",
"这是第3张图片",
"这是第4张图片",
"这是第5张图片"
};
//将要显示的图片放到list集合中
imageSource = new ArrayList<ImageView>();
for(int i = 0; i < images.length;i++){
ImageView image = new ImageView(this);
image.setBackgroundResource(images[i]);
imageSource.add(image);
}

//获取显示的点(即文字下方的点,表示当前是第几张)
dots = new ArrayList<View>();
dots.add(findViewById(R.id.dot1));
dots.add(findViewById(R.id.dot2));
dots.add(findViewById(R.id.dot3));
dots.add(findViewById(R.id.dot4));
dots.add(findViewById(R.id.dot5));

//图片的标题
title = (TextView) findViewById(R.id.title);
title.setText(titles[0]);

//显示图片的VIew
viewPager = (ViewPager) findViewById(R.id.vp);
//为viewPager设置适配器
adapter = new MyPagerAdapter();
viewPager.setAdapter(adapter);
//为viewPager添加监听器,该监听器用于当图片变换时,标题和点也跟着变化
MyPageChangeListener listener = new MyPageChangeListener();
viewPager.setOnPageChangeListener(listener);

//开启定时器,每隔2秒自动播放下一张(通过调用线程实现)(与Timer类似,可使用Timer代替)
ScheduledExecutorService scheduled =  Executors.newSingleThreadScheduledExecutor();
//设置一个线程,该线程用于通知UI线程变换图片
ViewPagerTask pagerTask = new ViewPagerTask();
scheduled.scheduleAtFixedRate(pagerTask, 2, 2, TimeUnit.SECONDS);
}



// ViewPager每次仅最多加载三张图片(有利于防止发送内存溢出)
private class MyPagerAdapter extends PagerAdapter{
@Override
public int getCount() {
System.out.println("getCount");
return images.length;
}
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
//判断将要显示的图片是否和现在显示的图片是同一个
//arg0为当前显示的图片,arg1是将要显示的图片
System.out.println("isViewFromObject");
return arg0 == arg1;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
System.out.println("destroyItem==" + position);
//销毁该图片
container.removeView(imageSource.get(position));
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
//初始化将要显示的图片,将该图片加入到container中,即viewPager中
container.addView(imageSource.get(position));
System.out.println("instantiateItem===" + position +"===="+container.getChildCount());
return imageSource.get(position);
}
}


//监听ViewPager的变化
private class MyPageChangeListener implements OnPageChangeListener{
@Override
public void onPageScrollStateChanged(int arg0) {

}

@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {

}

@Override
public void onPageSelected(int position) {
//当显示的图片发生变化之后
//设置标题
title.setText(titles[position]);
//改变点的状态
dots.get(position).setBackgroundResource(R.drawable.dot_focused);
dots.get(oldPage).setBackgroundResource(R.drawable.dot_normal);
//记录的页面
oldPage = position;
currPage = position;
}
}

private class ViewPagerTask implements Runnable{
@Override
public void run() {
//改变当前页面的值
currPage =(currPage+ 1)%images.length;
//发送消息给UI线程
handler.sendEmptyMessage(0);
}
}

private Handler handler= new Handler(){
public void handleMessage(Message msg) {
//接收到消息后,更新页面
viewPager.setCurrentItem(currPage);
};
};
}


放上部分代码,欢迎大家交流。





网盘http://pan.baidu.com/s/1mgveTr6

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值