ViewPager结合Fragment进行无限滑动

 

实现ViewPager结合Fragment实现无限循环切换,这里也是在适配器里面进行的,当然使用滑动监听也能够实现


import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.view.ViewGroup;

import java.util.ArrayList;

public class adapter extends FragmentPagerAdapter
{
private ArrayList<Fragment> fragmentList; public adapter(FragmentManager fm) { super(fm); } public adapter(FragmentManager fm, ArrayList<Fragment> fragmentList) { super(fm); this.fragmentList=fragmentList; } @Override public Fragment getItem(int position) { //在这里不处理position的原因是因为getItem方法在 //instantiateItem方法中调用。只要在调用前处理 //position即可,以免重复处理 return fragmentList.get(position); } @Override public int getCount()
{
return Integer.MAX_VALUE; } @Override public int getItemPosition(Object object)
{
return super.getItemPosition(object); } @Override public Object instantiateItem(ViewGroup container, int position)
{
//处理position。让数组下标落在[0,fragmentList.size)中,防止越界 position = position % fragmentList.size(); return super.instantiateItem(container, position); } }

以上参考:博客http://www.ilrose.com/blog/2015/12/09/android-viewpager%E5%AE%9E%E7%8E%B0%E6%97%A0%E9%99%90%E5%BE%AA%E7%8E%AF%E6%BB%91%E5%8A%A8/ 

经过实际检验,要传进4个fragment,否则往右边滑动会出现问题,原因不知......

想要实现答题界面的翻页效果便可以采用这种方法,可以建立一个ReadFragment,然后new 出4个这个Fragment的对象。不同页面的共同的处理可以直接在ReadFragment里头实现,翻页的时候每一页需要改变的参数可以在滑动监听器里获取这4个对象来实现。

        Fragment a=new ReadFragment();
        Fragment b=new ReadFragment();
        Fragment c=new ReadFragment();
        Fragment d=new ReadFragment();

        list=new ArrayList<Fragment>();
        list.add(a);
        list.add(b);
        list.add(c);
        list.add(d);
readViewPager.setAdapter(new adapter(getSupportFragmentManager(),list));

 

 

readViewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener()
        {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels)
            {}

            @Override
            public void onPageSelected(int position)
            {
//处理position。让position落在[0,fragmentList.size)中,防止数组越界 position
= position % list.size(); ReadFragment fragment= (ReadFragment) list.get(position); //获得此时选中的fragment fragment.refreshState(); //翻页的时候每个页面需要改变的参数使用这个方法来实现,这个方法在ReadFragment里面,修饰器得使用public
  ... } @Override
public void onPageScrollStateChanged(int state) {} });

后来我发现以上这种刷新fragment的方法有个弊端,就是展示出来的第一页无法得到刷新,因为第一页显示的时候不会去调用onPageSelected,得单独处理

以上便可以实现答题翻页。当然少不了翻页动画的实现,这个下一篇博客单独讲

 

转载于:https://www.cnblogs.com/tangZH/p/6516566.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ViewPager2 可以使用 androidx 库中的 ViewPager2,在 dependencies 中添加 ```Groovy implementation 'androidx.viewpager2:viewpager2:1.0.0' ``` 然后在布局文件中添加 ViewPager2 控件,例如: ```xml <androidx.viewpager2.widget.ViewPager2 android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 接着,在代码中创建 FragmentAdapter,例如: ```Kotlin class MyFragmentAdapter(fragmentManager: FragmentManager, lifecycle: Lifecycle) : FragmentStateAdapter(fragmentManager, lifecycle) { override fun getItemCount(): Int = 3 // Fragment 数量 override fun createFragment(position: Int): Fragment { return when (position) { 0 -> FragmentOne() 1 -> FragmentTwo() 2 -> FragmentThree() else -> throw IndexOutOfBoundsException() } } } ``` 其中,getItemCount 返回 Fragment 数量,createFragment 返回指定位置的 Fragment 对象,例子中返回了三个 FragmentOne、FragmentTwo、FragmentThree。 最后,在 Activity 或 Fragment 中设置 ViewPager2 和 FragmentAdapter,例如: ```Kotlin val viewPager: ViewPager2 = findViewById(R.id.view_pager) val adapter = MyFragmentAdapter(supportFragmentManager, lifecycle) viewPager.adapter = adapter ``` 这样就实现了在 Fragment 之间滑动的功能。 ### 回答2: 要使用ViewPager2在Fragment之间滑动,首先需要在布局文件中定义一个ViewPager2控件,并添加相应的Fragment。 在Activity中,需要先获取ViewPager2控件的实例,并创建一个适配器来管理Fragment的切换。适配器需要继承FragmentStateAdapter,并重写getItemCount()方法和createFragment()方法。 getItemCount()方法返回Fragment的数量。 createFragment()方法根据position返回相应位置的Fragment。 然后,将适配器设置给ViewPager2控件。 接下来,就可以通过手势滑动或者使用setCurrentItem()方法来实现Fragment之间的切换。如果想要禁用滑动,可以使用setUserInputEnabled()方法来设置。 以下是一个简单的示例代码: 在布局文件中: ``` <androidx.viewpager2.widget.ViewPager2 android:id="@+id/viewPager" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 在Activity中: ```java ViewPager2 viewPager = findViewById(R.id.viewPager); FragmentStateAdapter adapter = new MyAdapter(this); viewPager.setAdapter(adapter); // 实现禁用滑动的功能 // viewPager.setUserInputEnabled(false); // 实现手动切换到指定Fragment的功能 // viewPager.setCurrentItem(2, false); ``` 适配器类: ```java private class MyAdapter extends FragmentStateAdapter { public MyAdapter(FragmentActivity fa) { super(fa); } @Override public int getItemCount() { return 3; // 返回Fragment的数量 } @NonNull @Override public Fragment createFragment(int position) { switch (position) { case 0: return new Fragment1(); case 1: return new Fragment2(); case 2: return new Fragment3(); default: return null; } } } ``` 这样,便可以在ViewPager2中实现Fragment之间的滑动切换了。 ### 回答3: ViewPager2 是 Android Support Library 中的一个组件,用于在多个 fragment 之间进行滑动切换。要在 fragment 之间使用 ViewPager2 进行滑动切换,首先需要进行以下几个步骤: 1. 添加依赖:在项目的 build.gradle 文件中添加以下依赖: ``` implementation 'androidx.viewpager2:viewpager2:1.0.0' ``` 2. 创建 Fragment:创建需要滑动切换的多个 fragment,并在它们的布局文件中添加相应的内容。 3. 创建 ViewPager2:在主 Activity 或者容器 fragment 的布局文件中添加 ViewPager2 组件: ```xml <androidx.viewpager2.widget.ViewPager2 android:id="@+id/viewPager" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 4. 创建适配器:创建一个继承自 FragmentStateAdapter 的适配器类,用于管理 fragment 的创建和绑定。在适配器中实现以下两个方法: ```java @Override public int getItemCount() { return fragmentList.size(); } @Override public Fragment createFragment(int position) { return fragmentList.get(position); } ``` 5. 绑定适配器:在主 Activity 或者容器 fragment 的代码中,实例化 ViewPager2,并设置适配器: ```java ViewPager2 viewPager = findViewById(R.id.viewPager); viewPager.setAdapter(new MyAdapter(getSupportFragmentManager(), getLifecycle())); ``` 6. 处理切换事件:可以添加切换事件监听器,监听页面的切换操作,例如: ```java viewPager.registerOnPageChangeCallback(new ViewPager2.OnPageChangeCallback() { @Override public void onPageSelected(int position) { // 处理页面切换事件 } }); ``` 通过以上步骤,就可以在 fragment 之间使用 ViewPager2 进行滑动切换了。根据实际需求,还可以自定义每个 fragment 的布局和显示内容,以及指示器等。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值