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

目录

0、相关文章

系列文章:

1、前言

2、布局文件

3、VPTest4Activity.java


0、相关文章

ViewPager动态添加删除及刷新页面

系列文章:

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

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

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

1、前言

手动滑动 + 左右箭头 + 删除数据

2、布局文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.gs.common3.aView.viewpager.VPTest4Activity">

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

    <ImageView
        android:id="@+id/ivPre"
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:background="@color/white"
        android:layout_centerVertical="true"
        android:src="@drawable/arrow_back_black" />

    <ImageView
        android:id="@+id/ivNext"
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:background="@color/white"
        android:layout_alignParentEnd="true"
        android:layout_centerVertical="true"
        android:src="@drawable/arrow_forward_black" />

    <Button
        android:id="@+id/btnDelete"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:text="删除"/>

</RelativeLayout>

3、VPTest4Activity.java

/**
 * Android使用ViewPager实现图片轮播系列之四:手动滑动 + 左右箭头 + 删除数据
 */
public class VPTest4Activity extends AppCompatActivity {

    @BindView(R.id.viewPager)
    ViewPager viewPager;
    @BindView(R.id.ivPre)
    ImageView ivPre;
    @BindView(R.id.ivNext)
    ImageView ivNext;
    @BindView(R.id.btnDelete)
    Button btnDelete;

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

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

//    private int[] imagePaths = {
//            R.mipmap.scenery1, R.mipmap.scenery2
//    };

//    private int[] imagePaths = {
//            R.mipmap.scenery1
//    };

    ArrayList<ImageView> imageViewList;
    private MyPagerAdapter myPagerAdapter;
    private int currentPosition;

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

    @OnClick({R.id.ivPre, R.id.ivNext, R.id.btnDelete})
    public void onViewClicked(View view) {
        switch (view.getId()) {
            case R.id.ivPre:
                currentPosition -= 1;
                viewPager.setCurrentItem(currentPosition);
                break;
            case R.id.ivNext:
                currentPosition += 1;
                viewPager.setCurrentItem(currentPosition);
                break;
            case R.id.btnDelete:
                deleteData();
                break;
        }
    }

    private void deleteData() {

        // 只有一条数据 删除数据后直接 finish 当前界面
        if (imageViewList.size() == 1) {
//            LogUtils.e("currentPosition: " + currentPosition);
            imageViewList.remove(currentPosition);
            finish();
        } else {// 数据不止一条
            // 当前显示的是最后一条数据,删除当前数据后展示前一条数据
            if (currentPosition == imageViewList.size() - 1) {
                imageViewList.remove(currentPosition);
                myPagerAdapter.notifyDataSetChanged();
            } else {// 当前显示的不是最后一条数据,删除当前数据后展示后一条数据
                imageViewList.remove(currentPosition);
                myPagerAdapter.notifyDataSetChanged();
                if (imageViewList.size() == 1) {
                    ivNext.setVisibility(View.GONE);
                }
            }
        }

    }

    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);
        }

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

        //  第一次进入 不显示前置箭头
        ivPre.setVisibility(View.GONE);

        // 列表数据只有一条
        if (imageViewList.size() == 1) {
            // 不显示后一条箭头
            ivNext.setVisibility(View.GONE);
        }

        viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

            }

            @Override
            public void onPageSelected(int position) {
                currentPosition = position;
                // 第一个位置 不显示前置箭头
                ivPre.setVisibility(position == 0 ? View.GONE : View.VISIBLE);
                // 最后一个位置 不显示后置箭头
                ivNext.setVisibility(position == imageViewList.size() - 1 ? View.GONE : View.VISIBLE);
            }

            @Override
            public void onPageScrollStateChanged(int state) {

            }
        });
    }

    /**
     * 自定义适配器
     */
    private class MyPagerAdapter 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;
        }

        @Override
        public int getItemPosition(Object object) {
            return POSITION_NONE;
        }
    }
}
发布了632 篇原创文章 · 获赞 758 · 访问量 51万+

猜你喜欢

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