Android-ViewPager循环滑动

本文详细介绍了如何在Android应用中实现ViewPager组件的循环滑动功能,包括XML布局实现和Java代码细节,通过设置适配器和监听器来达到循环显示图片的效果。

Android-ViewPager循环滑动

  • 介绍:咋一确实看是实现了ViewPager的循环滑动Y(^o^)Y,可以实现应用中的循环滑动显示
  • 效果图:

显示效果图

下面是xml的布局

  • 小点和显示的大图都在java代码中添加,这里用LinearLayout来添加小点
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="200dp" >

    <android.support.v4.view.ViewPager
        android:id="@+id/viewPager"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

    <RelativeLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical" >

        <LinearLayout
            android:id="@+id/viewGroup"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:paddingBottom="15dp"
            android:gravity="center_horizontal"
            android:orientation="horizontal" >
        </LinearLayout>
    </RelativeLayout>

</FrameLayout>

在JAVA代码中

import android.app.Activity;
import android.os.Bundle;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.view.View;
import android.view.ViewGroup;
import android.view.ViewGroup.LayoutParams;
import android.widget.ImageView;
import android.widget.LinearLayout;

public class MainActivity extends Activity {
    private ViewPager viewPager;
    private ImageView[] tips;// 小点
    private ImageView[] imageViews;//显示的图片
    private int[] imgIds;//图片的资源id
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        ViewGroup group = (ViewGroup) findViewById(R.id.viewGroup);//获取装小点的线性布局
        viewPager = (ViewPager) findViewById(R.id.viewPager);
        // 图片资源
        imgIds = new int[] { R.drawable.p20, R.drawable.p21, R.drawable.p22};
        tips = new ImageView[imgIds.length];
        for (int i = 0; i < tips.length; i++) {
            ImageView img = new ImageView(this);
            tips[i] = img;
            if (i == 0) {
                tips[i].setImageResource(R.drawable.yuanquan_up2);
            } else {
                tips[i].setImageResource(R.drawable.yuanquan_down2);
            }
            LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
                    new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
            params.width = 20;//小点宽度
            params.height = 20;//小点高度
            params.leftMargin = 5;//小点的左边margin距离
            params.rightMargin = 5;//小点的右边margin距离
            group.addView(img, params);//将小点添加到线性布局中
        }
        //处理了,当图片小于等于4张的时候报的错
        imageViews = imgIds.length <= 3 ? new ImageView[imgIds.length * 4] : new ImageView[imgIds.length];
        for (int i = 0; i < imageViews.length; i++) {
            imageViews[i] = new ImageView(this);
            imageViews[i].setImageResource(imgIds[i % imgIds.length]);
            //按比例扩大图片的size居中显示,使得图片长(宽)等于或大于View的长(宽) 
            //ImageView.ScaleType参考:http://blog.csdn.net/larryl2003/article/details/6919513
            imageViews[i].setScaleType(ImageView.ScaleType.CENTER_CROP);
        }
        // 设置Adapter
        viewPager.setAdapter(new MyAdapter());
        // 设置ViewPager的监听,主要是设置滑动时小点图片样式的改变
        viewPager.addOnPageChangeListener(new OnPageChangeListener() {

            @Override
            public void onPageSelected(int arg0) {
                setImageBack(arg0 % imgIds.length);
            }

            @Override
            public void onPageScrolled(int arg0, float arg1, int arg2) {

            }

            @Override
            public void onPageScrollStateChanged(int arg0) {

            }
        });
        // 设置ViewPager的默认项, 设置为长度的100倍,这样子开始就能往左滑动
        viewPager.setCurrentItem((imageViews.length) * 100);
    }

    /**
     * 
     * 设置小点的背景
     *
     */
    private void setImageBack(int selectItem) {
        for (int i = 0; i < tips.length; i++) {
            if (i == selectItem) {
                tips[i].setImageResource(R.drawable.yuanquan_up2);
            } else {
                tips[i].setImageResource(R.drawable.yuanquan_down2);
            }
        }
    }

    /**
     * 
     * ViewPager适配器
     *
     */
    public class MyAdapter extends PagerAdapter {

        @Override
        public int getCount() {
            return Integer.MAX_VALUE;
        }

        @Override
        public boolean isViewFromObject(View arg0, Object arg1) {
            return arg0 == arg1;
        }

        @Override
        public void destroyItem(ViewGroup container, int position, Object object) {
            container.removeView(imageViews[position % imageViews.length]);
        }

        @Override
        public Object instantiateItem(ViewGroup container, int position) {
            container.addView(imageViews[position % imageViews.length], 0);
            return imageViews[position % imageViews.length];
        }
    }
}

参考的地址:

http://blog.csdn.net/xiaanming/article/details/8966621

项目的地址:

http://download.csdn.net/detail/u014314614/9335273

我的感受

  • 这个循环滑动其实就是将ViewPager适配器里的返回的长度弄的很大,然后循环的显示ImageView的数组
  • 开始位置没有在第一个位置,所以一开始就可以往左边滑动
  • 不看代码的话,看起来就是循环的( ̄┰ ̄*)

想说的话

  • 博客坚持写,今后学习了新的东西就在这里记录一下,以便今后回顾,也希望小小笔记能帮助你们
  • 若内容有什么地方不对、不清楚,还望吐槽,希望大家能一起成长
  • 来一句:仅仅成为一个实施者是不够的,你需要产于到决定如何实施的过程中
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值