栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Android 使用ViewPager实现手动左右切换页面和底部点点跟随切换效果

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Android 使用ViewPager实现手动左右切换页面和底部点点跟随切换效果

前言:

本篇是 Android 使用ViewPager实现基本的翻页效果 的升级版 添加了底部点点点图片的切换效果

一、首先是布局页面activity_main.xml




    
	
    

接下来是各个子页面,进行左右切换显示不同的内容carousel_first.xml,其余子页面同理




    

二、创建MyPagerAdapter类继承与PagerAdapter ,这个PagerAdapter主要是viewpager的适配器,可以实现控件的滑动效果。里面具体重写的方法可以查看这篇文章 传送门

public class MyPagerAdapter extends PagerAdapter {
    private ArrayList viewArrayList = new ArrayList<>();

    public MyPagerAdapter(ArrayList viewArrayList) {
        this.viewArrayList = viewArrayList;
    }

    @Override
    public int getCount() {
        return viewArrayList.size();
    }

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

    @NonNull
    @Override
    public Object instantiateItem(@NonNull ViewGroup container, int position) {
        container.addView(viewArrayList.get(position),0);
        return viewArrayList.get(position);
    }

    @Override
    public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
        container.removeView(viewArrayList.get(position));
    }
}

三、MainActivity.java 代码 注释已经在代码中详细给出

public class MainActivity extends AppCompatActivity {
    private MyPagerAdapter myPagerAdapter;
    private ViewPager viewPager;
    private LinearLayout viewGroup;
    private ArrayList viewArrayList = new ArrayList<>();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        viewPager = findViewById(R.id.viewPager);
        viewGroup = findViewById(R.id.viewGroup);
        @SuppressLint("InflateParams") View carousel_first = LayoutInflater.from(this).inflate(R.layout.carousel_first, null);
        @SuppressLint("InflateParams") View carousel_second = LayoutInflater.from(this).inflate(R.layout.carousel_second, null);
        @SuppressLint("InflateParams") View carousel_third = LayoutInflater.from(this).inflate(R.layout.carousel_third, null);
        viewArrayList.add(carousel_first);
        viewArrayList.add(carousel_second);
        viewArrayList.add(carousel_third);

        //将点点的图添加到视图ViewGroup中
        for (int i = 0; i < viewArrayList.size(); i++) {
            ImageView imageView = new ImageView(this);
            //设置图片的宽高 为10像素
            imageView.setLayoutParams(new ViewGroup.LayoutParams(10, 10));
            if (i == 0) {
                //第一个为默认选中状态
                imageView.setImageResource(R.drawable.icon_page_select);
            } else {
                imageView.setImageResource(R.drawable.icon_page_normal);
            }
            LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
            params.leftMargin = 5;
            params.rightMargin = 5;
            viewGroup.addView(imageView, params);
        }
        myPagerAdapter = new MyPagerAdapter(viewArrayList);
        //设置缓存页数
        viewPager.setOffscreenPageLimit(viewArrayList.size() - 1);
        viewPager.setAdapter(myPagerAdapter);
        //添加页面更改监听器
        viewPager.addOnPageChangeListener(onPageChangeListener);
    }

    private ViewPager.onPageChangeListener onPageChangeListener = new ViewPager.OnPageChangeListener() {
        @Override
        public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

        }

        @Override
        public void onPageSelected(int position) {
            //当新页面选中时调用此方法,position 为新选中页面的位置索引
            //在所选页面的时候,点点图片也要发生变化
            setImageBackground(position);
        }

        @Override
        public void onPageScrollStateChanged(int state) {

        }
    };

    
    private void setImageBackground(int selectItem) {
        for (int i = 0; i < viewArrayList.size(); i++) {
            ImageView imageView = (ImageView) viewGroup.getChildAt(i);
            imageView.setBackground(null);
            if (i == selectItem) {
                imageView.setImageResource(R.drawable.icon_page_select);
            } else {
                imageView.setImageResource(R.drawable.icon_page_normal);
            }
        }
    }
}

效果如图所示:

做个记录方便以后翻阅,有任何问题都可以在评论区指出~

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/490270.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号