一个案例教你简单地玩转ViewPager(三)之带指示点的图片自动轮播效果

此文在我的个人网站,我的简书,我的CSDN博客
同时发布,请多多关注!

前言

这周因为工作上的问题,搞到都没时间写博客了。之前自己对于很多公司上的招聘要求的工作经验都还没什么大概印象,现在倒是明白了。一个困扰自己几天的问题,问了一下有多年经验的人,一下子就能给你提供到突破点的建议。这也明白到自己需要提高的地方太多了。嗯,现在还是一步一步地提高自己吧!

这周这篇给大家带来的是ViewPager系列的最后一篇-图片轮播效果

图片自动轮播

如果你已经错过上两篇,可以戳下面的传送门哦:D

一个案例教你简单地玩转ViewPager(一)之带指示点的引导页

一个案例教你简单地玩转ViewPager(二)之ViewPaper+TabLayout+Fragment顶部标签界面滑动

Talk is cheap,show u the code

  • 自定义ViewPager-CarouselViewPager
private int displayTime = 3000;//图片展示的时间,默认为3秒
    private CarouselDirection direction = CarouselDirection.LEFT;//图片自动滑动的方向向左

    public CarouselViewPager(Context context) {
        super(context);
    }

    public CarouselViewPager(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    /**
     * 设置图片展示时间
     * @param time
     */
    public void setDisplayTime(int time){
        displayTime = time;
    }

    /**
     * 设置图片自动滑动的方向
     * @param direction
     */
    public void setDirection(CarouselDirection direction) {
        this.direction = direction;
    }

    /**
     * 开始自动轮播
     */
    public void start(){
        stop();
        postDelayed(automaticDisplay,displayTime);
    }

    /**
     * 停止自动轮播
     */
    public void stop(){
        removeCallbacks(automaticDisplay);
    }

    /**
     * 图片轮播方向枚举类
     */
    public enum CarouselDirection {
        LEFT,RIGHT
    }

    private Runnable automaticDisplay = new Runnable() {
        @Override
        public void run() {
            display(direction);
        }
    };

    /**
     * 图片轮播
     * @param direction
     */
    private synchronized void display(CarouselDirection direction) {
        PagerAdapter pagerAdapter = getAdapter();
        if (pagerAdapter != null ) {
            int count = pagerAdapter.getCount();//图片的张数
            int currentItem = getCurrentItem();//当前展示到第几张

            switch (direction) {
                case LEFT:
                    currentItem++;
                    //当前展示的图片为最后一张时,则返回第一张
                    if (currentItem >= count ){
                        currentItem = 0;
                    }
                    break;
                case RIGHT:
                    currentItem--;
                    //当前展示的图片为最后一张时,则返回第一张
                    if (currentItem < 0){
                        currentItem = count-1;
                    }
                    break;
            }
            setCurrentItem(currentItem);
        }
        start();
    }

    @Override
    protected void onFinishInflate() {
        addOnPageChangeListener(new OnPageChangeListener() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

            }

            @Override
            public void onPageSelected(int position) {

            }

            @Override
            public void onPageScrollStateChanged(int state) {
                if (state == SCROLL_STATE_IDLE){
                    start();
                } else if (state == SCROLL_STATE_DRAGGING) {
                    stop();
                }
            }
        });
    }
  • 贴上布局
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:orientation="vertical"
              android:layout_width="match_parent"
              android:layout_height="match_parent">

<com.pyz.viewpagerdemo.ui.CarouselViewPager
    android:id="@+id/mCarouselView"
    android:layout_width="match_parent"
    android:layout_height="300dp">

</com.pyz.viewpagerdemo.ui.CarouselViewPager>

    <!--轮播图片的指示点-->
    <LinearLayout
        android:id="@+id/pointLayout"
        android:layout_width="wrap_content"
        android:layout_height="10dp"
        android:layout_centerHorizontal="true"
        android:layout_below="@+id/mCarouselView"
        android:orientation="horizontal">

    </LinearLayout>

</RelativeLayout>
  • 在Fragment中使用CarouselViewPager自定义控件
   private CarouselViewPager mCarouselView;
    private List<ImageView> ivList = new ArrayList<ImageView>();
    private int[] ivIds = {R.mipmap.pic1, R.mipmap.pic2, R.mipmap.pic3, R.mipmap.pic4};

    private ImageView[] indicationPoint;//指示点控件
    private LinearLayout pointLayout;

    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container,
                             @Nullable Bundle savedInstanceState) {
        View rootView = inflater.inflate(R.layout.fragment2_layout, container, false);
        initViews(rootView);
        initData();
        return rootView;
    }

    private void initViews(View rootView) {
        mCarouselView = (CarouselViewPager) rootView.findViewById(R.id.mCarouselView);
        pointLayout = (LinearLayout) rootView.findViewById(R.id.pointLayout);
    }

    private void initData() {
        for (int i = 0; i < ivIds.length; i++) {
            ImageView iv = new ImageView(getActivity());
            iv.setImageResource(ivIds[i]);
            ivList.add(iv);
        }

        //动态生成指示点
        indicationPoint = new ImageView[ivList.size()];
        for (int i = 0; i < indicationPoint.length; i++) {
            ImageView point = new ImageView(getActivity());
            LinearLayout.LayoutParams layout = new LinearLayout.LayoutParams(10, 10);
            layout.setMargins(10, 0, 10, 0);
            point.setLayoutParams(layout);

            indicationPoint[i] = point;
            if (i == 0) {
                indicationPoint[i].setBackgroundResource(R.mipmap.page_indicator_focused);
            } else {
                indicationPoint[i].setBackgroundResource(R.mipmap.page_indicator_unfocused);
            }
            pointLayout.addView(point);
        }

        mCarouselView.setAdapter(new CarouselPagerAdapter(ivList));
        mCarouselView.addOnPageChangeListener(this);
        //设置图片展示的时间
        mCarouselView.setDisplayTime(2000);
        //图片开始轮播
        mCarouselView.start();

    }

    @Override
    public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

    }

    @Override
    public void onPageSelected(int position) {
        setPointColor(position % ivList.size());

    }

    @Override
    public void onPageScrollStateChanged(int state) {

    }

    private void setPointColor(int selectItem) {
        for (int i = 0; i < indicationPoint.length; i++) {
            if (i == selectItem) {
                indicationPoint[i].setBackgroundResource(R.mipmap.page_indicator_focused);
            } else {
                indicationPoint[i].setBackgroundResource(R.mipmap.page_indicator_unfocused);
            }

        }
    }

源码下载

ViewPagerDemo

喜欢的可以点点Star哦!

总结

在代码上注释也写得比较清楚明白的了,不过在这篇中大家应该可以看到与第一篇不同的是,这次的指示点是根据图片的张数而动态创建的,这也解决了在布局文件上的直接使用控件造成的代码冗余。通过这三篇的ViewPager系列文章,相信大家可以轻松简单地掌握其用法了吧。

参考文章:手把手教你用ViewPager自定义实现Banner轮播

最后

小弟不才,还望多多指教!

  • 8
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的示例: 1. 首先,在你的布局文件中添加 ViewPager 和指示器: ```xml <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <androidx.viewpager.widget.ViewPager android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="200dp" /> <LinearLayout android:id="@+id/indicator_layout" android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center" android:orientation="horizontal" android:paddingTop="10dp" android:paddingBottom="10dp" /> </LinearLayout> ``` 2. 在你的 Activity 或 Fragment 中,定义一个 ArrayList 来存储轮播图的图片资源: ```java private ArrayList<Integer> mImageResources = new ArrayList<>(); ``` 3. 在 onCreate 方法中,初始化 ViewPager 和指示器: ```java ViewPager viewPager = findViewById(R.id.view_pager); LinearLayout indicatorLayout = findViewById(R.id.indicator_layout); // 将图片资源添加到 ArrayList 中 mImageResources.add(R.drawable.image1); mImageResources.add(R.drawable.image2); mImageResources.add(R.drawable.image3); // 创建 Adapter PagerAdapter adapter = new PagerAdapter(getSupportFragmentManager(), mImageResources); // 设置 Adapter 和监听器 viewPager.setAdapter(adapter); viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { } @Override public void onPageSelected(int position) { // 更新指示器 updateIndicator(position); } @Override public void onPageScrollStateChanged(int state) { } }); // 添加指示器 for (int i = 0; i < mImageResources.size(); i++) { ImageView indicator = new ImageView(this); indicator.setImageResource(R.drawable.indicator_unselected); indicatorLayout.addView(indicator); } // 设置当前项为第一项 updateIndicator(0); ``` 4. 创建 Adapter 类,并在其中实现轮播图的逻辑: ```java public class PagerAdapter extends FragmentPagerAdapter { private ArrayList<Integer> mImageResources; public PagerAdapter(FragmentManager fm, ArrayList<Integer> imageResources) { super(fm); mImageResources = imageResources; } @Override public Fragment getItem(int position) { // 计算实际位置 position = position % mImageResources.size(); return ImageFragment.newInstance(mImageResources.get(position)); } @Override public int getCount() { // 返回一个很大的数,保证可以循环滑动 return Integer.MAX_VALUE; } } ``` 5. 创建 Fragment 类,用来显示图片: ```java public class ImageFragment extends Fragment { private int mImageResource; public static ImageFragment newInstance(int imageResource) { ImageFragment fragment = new ImageFragment(); Bundle args = new Bundle(); args.putInt("image_resource", imageResource); fragment.setArguments(args); return fragment; } @Override public void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); if (getArguments() != null) { mImageResource = getArguments().getInt("image_resource"); } } @Nullable @Override public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { ImageView imageView = new ImageView(getContext()); imageView.setImageResource(mImageResource); return imageView; } } ``` 6. 最后,实现指示器的更新方法: ```java private void updateIndicator(int position) { LinearLayout indicatorLayout = findViewById(R.id.indicator_layout); for (int i = 0; i < indicatorLayout.getChildCount(); i++) { ImageView indicator = (ImageView) indicatorLayout.getChildAt(i); if (i == position % mImageResources.size()) { indicator.setImageResource(R.drawable.indicator_selected); } else { indicator.setImageResource(R.drawable.indicator_unselected); } } } ``` 这样就完成了一个简单ViewPager 轮播图。需要注意的是,为了实现循环滑动,Adapter 中 getCount 方法返回了一个很大的数,而getItem 方法中使用了取模运算符来计算实际位置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值