在这里,当我登陆到第一个片段时,所有视图都被加载并滚动,但是当我来自第三个片段时,即来自其他活动,我需要进入第三个片段,而当导航到第一个片段时,视图却没有加载,这使得不可滚动。 Firstfragment xml包含recyclerview和Group元素。
MyActivity类:
MyAdapter adapter = new MyAdapter(this, getSupportFragmentManager(), fragments);
viewPager.setOffscreenPageLimit(3);
viewPager.setAdapter(adapter);
tabLayout.setupWithViewPager(viewPager);
//MyAdapter
public class MyAdapter extends FragmentPagerAdapter {
private Context mContext;
private List<Fragment> fragmentList ;
public MyAdapter(Context context, FragmentManager fm,List<Fragment> fragmentList) {
super(fm);
mContext = context;
this.fragmentList = fragmentList;
}
@Override
public Fragment getItem(int position) {
return fragmentList.get(position);
}
@Override
public int getCount() {
return 3;
}
@Override
public CharSequence getPageTitle(int position) {
switch (position) {
case 0:
return mContext.getString(R.string.firstfragmentname);
case 1:
return mContext.getString(R.string.seconsfrag);
case 2:
return mContext.getString(R.string.thirdfrag);
default:
return null;
}
}
}
//XML has custom viewpager
<ScrollView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginTop="@dimen/headerHeight"
android:layout_marginBottom="@dimen/footerHeight"
android:fadingEdgeLength="0dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_30_60"
android:layout_marginTop="10dp"
android:layout_marginEnd="@dimen/dp_30_60"
android:orientation="vertical">
<TextView
android:id="@+id/sp_header"
style="@style/pageTitle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"
android:layout_marginBottom="10dp"
android:text="@string/my_bill" />
<com.view.Tab
android:id="@+id/tab_custom"
android:layout_width="match_parent"
android:layout_height="@dimen/tab_height" />
<com.custom.CustomViewPager
android:id="@+id/sp_viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginStart="@dimen/dp_10_53"
android:layout_marginTop="4dp"
android:layout_marginEnd="@dimen/dp_10_53"
android:layout_marginBottom="4dp" />
</LinearLayout>
</ScrollView>
//CustomViepager
public class CustomViepager extends ViewPager {
public CustomViepager(Context context) {
super(context);
initPageChangeListener();
}
public CustomViepager(Context context, AttributeSet attrs) {
super(context, attrs);
initPageChangeListener();
}
private void initPageChangeListener() {
addOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {
@Override
public void onPageSelected(int position) {
requestLayout();
}
});
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
View child = getChildAt(getCurrentItem());
if (child != null) {
child.measure(widthMeasureSpec, MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));
int h = child.getMeasuredHeight();
heightMeasureSpec = MeasureSpec.makeMeasureSpec(h, MeasureSpec.EXACTLY);
}
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
}
@Override
public void setCurrentItem(int item) {
super.setCurrentItem(item, false);
}
@Override
public void setCurrentItem(int item, boolean smoothScroll) {
super.setCurrentItem(item, false);
}
}
答案 0 :(得分:0)
使用简单的视图传呼机,并尝试像这样使用它
CustomPagerAdapter
import androidx.fragment.app.Fragment
import androidx.fragment.app.FragmentManager
import androidx.fragment.app.FragmentStatePagerAdapter
class MyPagerAdapter(fm: FragmentManager, behaviour: Int) : FragmentStatePagerAdapter(fm, behaviour) {
private val mFragmentList = ArrayList<Fragment>()
override fun getItem(position: Int): Fragment {
return mFragmentList[position]
}
override fun getCount(): Int {
return mFragmentList.size
}
fun addFragment(fragment: Fragment) {
mFragmentList.add(fragment)
}
}
活动/片段中
private var mAdapter: MyPagerAdapter? = null
在onCreate
mAdapter = MyPagerAdapter(getChildFragmentManager(), FragmentStatePagerAdapter.BEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENT)
mAdapter?.addFragment(YOUR_FIRST_FRAGMENT)
mAdapter?.addFragment(YOUR_SECOND_FRAGMENT)
mAdapter?.addFragment(YOUR_THIRD_FRAGMENT)
sp_viewpager.offscreenPageLimit = 3
sp_viewPAger.adapter = mAdapter
当您要降落在所需位置时,在上面的代码之后编写
sp_viewpager.setCurrentItem(1/2/3,true/false)
答案 1 :(得分:0)
@LakwinderSingh answer 这个问题是完美的。
只想强调一件事,主要技巧或真正的问题在于 offscreen page limit
它是寻呼机在当前片段的左侧或右侧创建的片段数,默认情况下该值为 1。< /p>
这就是为什么当我们滚动到第三个片段时它不会加载任何东西,因为加载第三个片段需要同时向左加载 2 个片段,通过更改 offscreen page limit
值我们可以确定数量在这种情况下,在特定时间加载的片段数量为 2。
如果我们这样做,那么我们还必须将 PagerAdapter 的默认函数 destroyItem()
覆盖为一个没有 super
的空函数,以便不会同时销毁和创建太多片段,导致使滑动断断续续或使片段空白。