Android使用ViewPager实现图片轮播系列之一:简单实现

目录

0、介绍:

系列文章:

1、布局文件:

2、VPTest1Activity


0、介绍:

使用ViewPager简单实现图片轮播:最简单,手动滑动

系列文章:

Android使用ViewPager实现图片轮播系列之二:自动轮播

Android使用ViewPager实现图片轮播系列之三:手动滑动 + 左右箭头

Android使用ViewPager实现图片轮播系列之四:手动滑动 + 左右箭头 + 删除数据

1、布局文件:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.gs.common3.aView.viewpager.VPTest1Activity">

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

</android.support.constraint.ConstraintLayout>

2、VPTest1Activity

public class VPTest1Activity extends AppCompatActivity {

    @BindView(R.id.viewPager)
    ViewPager viewPager;

    private int[] imagePaths = {
            R.mipmap.scenery1, R.mipmap.scenery2, R.mipmap.scenery3, R.mipmap.scenery4,
            R.mipmap.scenery5
    };

    ArrayList<ImageView> imageViewList;
    private MyAdapter pageAdapter;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_vptest1);
        ButterKnife.bind(this);

        initData();
    }

    private void initData() {
        imageViewList = new ArrayList<>();
        viewPager.setCurrentItem(0);
        setDataToViewPager();
    }

    /**
     * 把数据设置到 ViewPager 上
     */
    private void setDataToViewPager() {
        // 将图片放到集合中
        imageViewList = new ArrayList<>();
        for (int imagePath : imagePaths) {
            ImageView imageView = new ImageView(this);
            imageView.setImageResource(imagePath);
//            Glide.with(this).load(imagePath).into(imageView);
            imageView.setScaleType(ImageView.ScaleType.FIT_XY);
            imageViewList.add(imageView);
        }

        // 进行适配
        pageAdapter = new MyAdapter();
        if (viewPager != null) {
            viewPager.setAdapter(pageAdapter);
        }
    }

    /**
     * 自定义适配器
     */
    private class MyAdapter extends PagerAdapter {
        @Override
        public int getCount() {
            return imageViewList.size();
        }

        @Override
        public Object instantiateItem(ViewGroup container, final int position) {
            ImageView imageView = imageViewList.get(position);
            ViewParent viewParent = imageView.getParent();
            if (viewParent != null) {
                ViewGroup viewGroup = (ViewGroup) viewParent;
                viewGroup.removeView(imageView);
            }
            container.addView(imageView);
            return imageView;
        }

        @Override
        public void destroyItem(View view, int num, Object object) {
        }

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

}
发布了632 篇原创文章 · 获赞 758 · 访问量 51万+

猜你喜欢

转载自blog.csdn.net/songzi1228/article/details/103779950