巧秒实现无限轮播

本文介绍了一种使用Android的ViewPager实现带循环效果的图片轮播的方法。通过在图片列表首尾添加特定图片来实现无缝循环播放,并展示了如何设置指示器以跟踪当前页面。

偷下懒没上动图,只简单的截个图



先上代码

1、activity_main.xml

            <RelativeLayout
                android:layout_width="match_parent"
                android:layout_height="140dp">
                <android.support.v4.view.ViewPager
                    android:id="@+id/banner_viewpager"
                    android:layout_width="match_parent"
                    android:layout_height="140dp" />

                <LinearLayout
                    android:id="@+id/point_group"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_centerHorizontal="true"
                    android:layout_alignParentBottom="true"
                    android:layout_marginBottom="5dp"
                    android:orientation="horizontal">

                </LinearLayout>
            </RelativeLayout>

2、初始化数据,重点是在图片数组头部插入最后一张图片在尾部插入第一张图片

private void initData(){
    imgList.add(new Image("第三张图片",R.drawable.image3));//将最后一张图片插入到头部

    imgList.add(new Image("第一张图片",R.drawable.image1));//第一张图片
    imgList.add(new Image("第二张图片",R.drawable.image2));//第二张
    imgList.add(new Image("第三张图片",R.drawable.image2));//第三张

    imgList.add(new Image("第一张图片"),R.drawable.image1);//将第一张图片追加到尾部
}

3、适配器

PagerAdapter pagerAdapter = new PagerAdapter() {
        @Override
        public int getCount() {
            return imgList.size();
        }

        @Override
        public boolean isViewFromObject(View view, Object object) {
            return view==object;
        }

        @Override
        public Object instantiateItem(ViewGroup container, final int position) {
            Image image = imgList.get(position);
            int imageId = image.getImageId();
            ImageView imageView = new ImageView(activity);
            imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
            ViewGroup.LayoutParams params = new ViewGroup.LayoutParams
                    (ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);
            imageView.setImageResource(imageId);
            imageView.setLayoutParams(params);
            container.addView(imageView);
            return imageView;
        }
        @Override
        public void destroyItem(ViewGroup container, int position, Object object) {
            container.removeView((View) object);
        }
    };

3、设置ViewPaper

viewpager.setAdapter(pagerAdapter);
viewpager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

            }

            @Override
            public void onPageSelected(int position) {
                //改变指示点的状态
                //把当前点enbale 为true
                position = position%pointGroup.size();
                pointGroup.getChildAt(position).setEnabled(true);
                //把上一个点设为false                
                pointGroup.getChildAt(lastPosition).setEnabled(false);
                lastPosition = position;                
               if (position == imageList.size() - 1) {// 设置当前值为1
                    currentPosition = 1;                
               } else if (position == 0) {// 如果索引值为0了,就设置索引值为倒数第二个
                    currentPosition = imageList.size() - 2;                
               } else {                    
                   currentPosition = position;                
               }            
           }            
           @Override           
           public void onPageScrollStateChanged(int state) {//如果是静止状态,将当前页进行替换  
               if(state==ViewPager.SCROLL_STATE_IDLE){// 设置当前页,smoothScroll 平稳滑动  
                  banner_viewpager.setCurrentItem(currentPosition, false); 
               }           
           }       
 });


### 使用 JavaScript 实现无缝循环滚动/无限轮播效果 为了实现一个基于 JavaScript 的无缝循环滚动或无限轮播效果,可以采用 HTML 结构配合 CSS 样式以及 JavaScript 控制逻辑相结合的方式。下面是一个具体的实例说明。 #### 创建基础结构 首先定义好页面的基础布局,在此部分主要通过 HTML 来构建容器及其内部元素: ```html <div class="carousel"> <div class="slides" id="slides"> <!-- 图片项 --> <img src="image1.jpg" alt=""> <img src="image2.jpg" alt=""> <img src="image3.jpg" alt=""> <!-- 可继续添加更多图片... --> </div> </div> ``` 这里 `class="carousel"` 是整个轮播图的外层包裹器;`id="slides"` 则是用来放置所有待显示图像的具体区域[^1]。 #### 添加样式美化 接着利用 CSS 对上述标记进行视觉上的优化处理,确保每张图片能够按照预期方式呈现出来: ```css .carousel { width: 80%; overflow: hidden; margin: auto; } .slides img { float: left; /* 让图片水平排列 */ min-width: 100%; /* 单张图片宽度至少占满父级容器 */ } ``` 这段代码设置了 `.carousel` 容器具有固定宽度并居中显示,同时隐藏超出其边界的任何内容。对于子元素即各个 `<img>` ,设置它们浮动左对齐,并规定最小宽度等于父级容器大小以保证单屏只展示一张完整的图片[^4]。 #### 编写交互脚本 最后编写一段简单的 JavaScript 脚本来控制幻灯片切换行为: ```javascript let index = 0; function slideShow() { const slidesContainer = document.getElementById('slides'); // 获取当前容器内所有子节点(即所有的图片) let childrenNodes = Array.from(slidesContainer.children); // 将第一个孩子移动到最后面去形成环形链表的感觉 if (index >= childrenNodes.length) { slidesContainer.appendChild(childrenNodes.shift()); index = 0; } // 设置位移距离使新加入的第一个孩子刚好位于视窗之外不可见位置 slidesContainer.style.transform = 'translateX(-' + index * 100 + '%)'; // 自增索引准备下次调用 ++index; } // 开始定时任务执行动画帧更新操作 setInterval(slideShow, 3000); // 每隔三触发一次函数改变状态 ``` 该段程序实现了每隔一定时间间隔就自动向右滑动至下一张图片的功能,当到达最后一张之后又会妙地把首张重新置入队列末端从而达到所谓的“无限”播放目的[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值