viewpager+hander实现轮播图

MyAdapter

   private ArrayList<ImageView> arrayList;

   public VPAdapter(ArrayList arrayList) {
      this.arrayList = arrayList;
     }
    @Override
    public int getCount() {
        return arrayList.size();
    }

    @Override
    public boolean isViewFromObject(View view, Object object) {
            return view == object;
        }
/**
 * 实例化
 * @param container
 * @param position
 * @return
 */
@Override
public Object instantiateItem(ViewGroup container, int position) {
    container.addView(arrayList.get(position));
    return arrayList.get(position);
}
/**
 * 销毁
 * @param container
 * @param position
 * @param object
 */
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
     container.removeView(arrayList.get(position));
}

activity

 private ViewPager viewpager;
private TextView textView;
private TextView textView2;
private TextView textView3;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    initView();
    initData();
}
ArrayList<ImageView> arrayList;
private void initData() {
    arrayList = new ArrayList<>();
    int[] ints = new int[]{R.drawable.a, R.drawable.b, R.drawable.a};
    for (int i = 0; i < ints.length; i++) {
        ImageView imageView = new ImageView(this);
        imageView.setImageResource(ints[i]);
        arrayList.add(imageView);
    }
    viewpager.setAdapter(new VPAdapter(arrayList));
    handler.sendEmptyMessageDelayed(0,1000);
}

private void initView() {
    viewpager = (ViewPager) findViewById(R.id.viewpager);
    textView = (TextView) findViewById(R.id.textView);
    textView2 = (TextView) findViewById(R.id.textView2);
    textView3 = (TextView) findViewById(R.id.textView3);
    viewpager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
        @Override
        public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
            textView3.setText("当前变化后的:" + position);
        }

        @Override
        public void onPageSelected(int position) {
            textView.setText("当前选中页:" + position);
        }

        @Override
        public void onPageScrollStateChanged(int state) {
            textView2.setText("当前将要变化状态:" + state);
        }
    });

}

//---------------------------自动轮播------------------------

//    Timer
Handler handler = new Handler() {
    @Override
    public void handleMessage(Message msg) {
        int nowPage = viewpager.getCurrentItem(); //max =2  ;当前页
        //arrayList.size() = 3; 下一页
        int nextpage = nowPage+1 == arrayList.size() ? 0:nowPage+1;
        viewpager.setCurrentItem(nextpage);
        if (nowPage+1 == arrayList.size()){
            Intent intent = new Intent(MainActivity.this,Main2Activity.class);
            MainActivity.this.startActivity(intent);
            return;
        }
        sendEmptyMessageDelayed(0,1000);
    }
};
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
资源包主要包含以下内容: ASP项目源码:每个资源包中都包含完整的ASP项目源码,这些源码采用了经典的ASP技术开发,结构清晰、注释详细,帮助用户轻松理解整个项目的逻辑和实现方式。通过这些源码,用户可以学习到ASP的基本语法、服务器端脚本编写方法、数据库操作、用户权限管理等关键技术。 数据库设计文件:为了方便用户更好地理解系统的后台逻辑,每个项目中都附带了完整的数据库设计文件。这些文件通常包括数据库结构图、数据表设计文档,以及示例数据SQL脚本。用户可以通过这些文件快速搭建项目所需的数据库环境,并了解各个数据表之间的关系和作用。 详细的开发文档:每个资源包都附有详细的开发文档,文档内容包括项目背景介绍、功能模块说明、系统流程图、用户界面设计以及关键代码解析等。这些文档为用户提供了深入的学习材料,使得即便是从零开始的开发者也能逐步掌握项目开发的全过程。 项目演示与使用指南:为帮助用户更好地理解和使用这些ASP项目,每个资源包中都包含项目的演示文件和使用指南。演示文件通常以视频或图文形式展示项目的主要功能和操作流程,使用指南则详细说明了如何配置开发环境、部署项目以及常见问题的解决方法。 毕业设计参考:对于正在准备毕业设计的学生来说,这些资源包是绝佳的参考材料。每个项目不仅功能完善、结构清晰,还符合常见的毕业设计要求和标准。通过这些项目,学生可以学习到如何从零开始构建一个完整的Web系统,并积累丰富的项目经验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值