viewpager+轮播+点+无限循环

private void initData(HeaderViewHolder headerViewHolder) {
        headerViewHolder.convenientBanner.startTurning(5000);
        networkImages.clear();
        for (int i = 0; i < banner.size(); i++) {
            networkImages.add(oss_url + "/" + banner.get(i).getImage());
        }
        //网络加载例子
        headerViewHolder.convenientBanner.setPages(new CBViewHolderCreator<NetworkImageHolderView>() {
            @Override
            public NetworkImageHolderView createHolder() {
                return new NetworkImageHolderView();
            }
        }, networkImages)
                .setPageIndicator(new int[]{R.drawable.ic_page_indicator, R.drawable.ic_page_indicator_focused});
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用ViewPager实现轮播图需要以下步骤: 1. 在布局文件中添加ViewPager控件。 2. 编写适配器Adapter,将图片加载到ViewPager中。 3. 在Activity中,实例化ViewPager和Adapter,并将Adapter设置给ViewPager。 4. 在Adapter中,重写instantiateItem方法,返回加载的视图,并设置监听器,实现无限循环滚动效果。 5. 使用Handler和Runnable实现自动轮播功能。 以下是一个简单的示例代码: 1. 布局文件中添加ViewPager控件: ``` <android.support.v4.view.ViewPager android:id="@+id/viewPager" android:layout_width="match_parent" android:layout_height="200dp" /> ``` 2. 编写适配器Adapter,将图片加载到ViewPager中: ``` public class ViewPagerAdapter extends PagerAdapter { private Context context; private int[] images; public ViewPagerAdapter(Context context, int[] images) { this.context = context; this.images = images; } @Override public int getCount() { return images.length; } @Override public boolean isViewFromObject(@NonNull View view, @NonNull Object object) { return view == object; } @NonNull @Override public Object instantiateItem(@NonNull ViewGroup container, int position) { ImageView imageView = new ImageView(context); imageView.setScaleType(ImageView.ScaleType.CENTER_CROP); imageView.setImageResource(images[position]); container.addView(imageView); return imageView; } @Override public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) { container.removeView((ImageView) object); } } ``` 3. 在Activity中,实例化ViewPager和Adapter,并将Adapter设置给ViewPager: ``` ViewPager viewPager = findViewById(R.id.viewPager); int[] images = {R.drawable.image1, R.drawable.image2, R.drawable.image3}; ViewPagerAdapter adapter = new ViewPagerAdapter(this, images); viewPager.setAdapter(adapter); ``` 4. 在Adapter中,重写instantiateItem方法,返回加载的视图,并设置监听器,实现无限循环滚动效果: ``` @Override public Object instantiateItem(@NonNull ViewGroup container, int position) { ImageView imageView = new ImageView(context); imageView.setScaleType(ImageView.ScaleType.CENTER_CROP); imageView.setImageResource(images[position]); container.addView(imageView); // 设置监听器,实现无限循环滚动效果 imageView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { int currentPosition = viewPager.getCurrentItem(); if (currentPosition == images.length - 1) { viewPager.setCurrentItem(0); } else { viewPager.setCurrentItem(currentPosition + 1); } } }); return imageView; } ``` 5. 使用Handler和Runnable实现自动轮播功能: ``` private Handler handler = new Handler(); private Runnable runnable = new Runnable() { @Override public void run() { int currentPosition = viewPager.getCurrentItem(); if (currentPosition == images.length - 1) { viewPager.setCurrentItem(0); } else { viewPager.setCurrentItem(currentPosition + 1); } handler.postDelayed(this, 3000); } }; @Override protected void onResume() { super.onResume(); handler.postDelayed(runnable, 3000); } @Override protected void onStop() { super.onStop(); handler.removeCallbacks(runnable); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值