Android 利用viewPager FragmentPagerAdapter 做一个简单的相册视图

说一下注意事项:你的布局需要用到viewparger 和 tabLayout 控件这两个控件要写全路径名
在这里插入图片描述
看图片中Tablayout的参数 设置选中 非选中 下划线颜色.
如果网络获取图片加权限 <uses-permission android:name="android.permission.INTERNET’>
展示一下布局文件
在这里插入图片描述
布局文件下面的小圆点是ImageView 当你点开你的APP时候 展示的当然是第一张所以第一个ImageView要与其它不同代表选中状态
JAVA代码部分
public class Main31Activity extends AppCompatActivity {
TabLayout tabLayout;
ViewPager viewPager;
ArrayList arrayList1 = new ArrayList<>();
ArrayList arrayListframent = new ArrayList<>();
ImageView iv13;
ImageView iv14;
ImageView iv15;
ImageView iv16;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main31);

    viewPager = findViewById(R.id.d14vp);
    tabLayout = findViewById(R.id.d14tb);
    tabLayout.setupWithViewPager(viewPager);
    iv13 = findViewById(R.id.iv13);
    iv14 = findViewById(R.id.iv14);
    iv15 = findViewById(R.id.iv15);
    iv16 = findViewById(R.id.iv16);

    arrayList1.add("第一页");
    arrayList1.add("第二页");
    arrayList1.add("第三页");
    arrayList1.add("第四页");

    d14Fragment1 d14Fragment1 = new d14Fragment1();
    d14Fragment2 d14Fragment2 = new d14Fragment2();
    d14Fragment3 d14Fragment3 = new d14Fragment3();
    d14Fragment4 d14Fragment4 = new d14Fragment4();

    arrayListframent.add(d14Fragment1);
    arrayListframent.add(d14Fragment2);
    arrayListframent.add(d14Fragment3);
    arrayListframent.add(d14Fragment4);

    viewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
        @Override
        public void onPageScrolled(int i, float v, int i1) {

        }

        @Override
        public void onPageSelected(int i) {
                   if (i==0){
                        iv13.setImageResource(R.mipmap.hongqiu);
                        iv14.setImageResource(R.mipmap.lvqiu);
                        iv15.setImageResource(R.mipmap.lvqiu);
                        iv16.setImageResource(R.mipmap.lvqiu);
                   }else if(i==1){
                       iv13.setImageResource(R.mipmap.lvqiu);
                       iv14.setImageResource(R.mipmap.hongqiu);
                       iv15.setImageResource(R.mipmap.lvqiu);
                       iv16.setImageResource(R.mipmap.lvqiu);
                   }else if(i==2){
                       iv13.setImageResource(R.mipmap.lvqiu);
                       iv14.setImageResource(R.mipmap.lvqiu);
                       iv15.setImageResource(R.mipmap.hongqiu);
                       iv16.setImageResource(R.mipmap.lvqiu);
                   }else if(i==3){
                       iv13.setImageResource(R.mipmap.lvqiu);
                       iv14.setImageResource(R.mipmap.lvqiu);
                       iv15.setImageResource(R.mipmap.lvqiu);
                       iv16.setImageResource(R.mipmap.hongqiu);
                   }
        }

        @Override
        public void onPageScrollStateChanged(int i) {

        }
    });


    M31Adapter m31Adapter = new M31Adapter(getSupportFragmentManager(), arrayList1, arrayListframent);
    viewPager.setAdapter(m31Adapter);
}

}

适配器代码

当你适配器继承FragmentPargerAdapter的时候会自动重写两个方法 getTitle是需要手动重写的 这个也是为了显示你的TitlePage

public class M31Adapter extends FragmentPagerAdapter {

ArrayList<String> arrayList1;
ArrayList<Fragment> arrayListframent;

public M31Adapter(FragmentManager fm, ArrayList<String> arrayList1, ArrayList<Fragment> arrayListframent) {
    super(fm);
    this.arrayList1 = arrayList1;
    this.arrayListframent = arrayListframent;
}

@Override
public Fragment getItem(int i) {
    return arrayListframent.get(i);
}

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

@Nullable
@Override
public CharSequence getPageTitle(int position) {
    return arrayList1.get(position);
}

}

最后看一下我们的实现效果吧
在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值