Android简单实现轮播

先上效果图

222852_npec_2811278.png

一、build.gradle(Module:app)添加依赖

compile 'com.jude:rollviewpager:1.4.6'

二、XML中添加布局(总布局最上边加上xmlns:app…… )

xmlns:app="http://schemas.android.com/apk/res-auto"
<com.jude.rollviewpager.RollPagerView
    android:id="@+id/vp_roll"
    android:layout_width="match_parent"
    android:layout_height="180dp"
    app:rollviewpager_play_delay="3000" />

app:rollviewpager_play_delay="3000"也就是设置3000ms图片自动滚动一次

三、在Activity.java中findViewById

RollPagerView vp_roll = (RollPagerView) findViewById(R.id.vp_roll);

四、创建自定义适配器

public class LoopAdapter_Scroll extends LoopPagerAdapter {

    List<Integer> imgList;

    public LoopAdapter_Scroll(RollPagerView viewPager, List<Integer> imgList) {
        super(viewPager);
        this.imgList = imgList;
    }

    @Override
    public View getView(ViewGroup container, int position) {
        ImageView view = new ImageView(container.getContext());
        view.setImageResource(imgList.get(position));
        view.setScaleType(ImageView.ScaleType.CENTER_CROP);
        view.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
        return view;
    }

    @Override
    public int getRealCount() {
        return imgList.size();
    }

}

五、给RollPagerView关联适配器

List<Integer> imgList = new ArrayList<>();
imgList.add(R.mipmap.bg_topic_1);
imgList.add(R.mipmap.bg_topic_2);
imgList.add(R.mipmap.bg_topic_3);
imgList.add(R.mipmap.bg_topic_4);
imgList.add(R.mipmap.bg_topic_5);

vp_roll.setAdapter(new LoopAdapter_Scroll(vp_roll, imgList));

六、设置点击事件(position + 1 是为了符合大众的 1,而不是程序员的 1,哈哈)

vp_roll.setOnItemClickListener(new com.jude.rollviewpager.OnItemClickListener() {
    @Override
    public void onItemClick(int position) {
        Toast.makeText(getBaseContext(), "点击轮播第" + (position + 1) + "张页面",
                       Toast.LENGTH_SHORT).show();     
    }
});

图片轮播实现了,感谢依赖的制作者。

转载于:https://my.oschina.net/AmosWang/blog/888745

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值