【 Android 】ViewPager + TabLayout + Fragment 数据初始化问题
2024-09-06 08:36:19
在 ViewPager 和 Fragment 配合使用的时候,ViewPager 会使用预加载机制,使得我们在没有切换到到对应页面时,就已经加载好了,这是个非常不好的用户体验。
所以本示例项目就诞生了。
关键字:setUserVisibleHint
实例:
示例结构:
使用Activity
嵌套Fragment
MainActivity
public class MainActivity extends AppCompatActivity { private ArrayList<Fragment> mFragments; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); initFragment(); initView();
} private void initFragment() {
mFragments = new ArrayList<>(); AFragment aFragment = AFragment.newInstance();
BFragment bFragment = BFragment.newInstance();
CFragment cFragment = CFragment.newInstance(); mFragments.add(aFragment);
mFragments.add(bFragment);
mFragments.add(cFragment);
} private void initView() {
final TabLayout tabLayout = findViewById(R.id.tab_layout);
final ViewPager viewPager = findViewById(R.id.viewpager); viewPager.setAdapter(new FragmentStatePagerAdapter(getSupportFragmentManager()) {
@Override
public Fragment getItem(int position) {
return mFragments.get(position);
} @Override
public int getCount() {
return mFragments.size();
}
}); viewPager.setOffscreenPageLimit(mFragments.size()); viewPager.addOnPageChangeListener(new TabLayout.TabLayoutOnPageChangeListener(tabLayout)); tabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
@Override
public void onTabSelected(TabLayout.Tab tab) {
Log.d(TAG, "onTabSelected: "); viewPager.setCurrentItem(tabLayout.getSelectedTabPosition(), true);
} @Override
public void onTabUnselected(TabLayout.Tab tab) {
Log.d(TAG, "onTabUnselected: ");
} @Override
public void onTabReselected(TabLayout.Tab tab) {
Log.d(TAG, "onTabReselected: ");
}
});
}
}
AFragment
public class AFragment extends Fragment { public AFragment() {
// Requires empty public constructor
} public static AFragment newInstance() {
return new AFragment();
} @Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater,
@Nullable ViewGroup container,
@Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_a, container, false); initView(view); return view;
} private void initView(View view) { }
}
BFragment
public class BFragment extends Fragment { private boolean isFirst = true; public BFragment() {
// Requires empty public constructor
} public static BFragment newInstance() {
return new BFragment();
} @Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
} @Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater,
@Nullable ViewGroup container,
@Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_b, container, false); initView(view); return view;
} @Override
public void setUserVisibleHint(boolean isVisibleToUser) {
super.setUserVisibleHint(isVisibleToUser); if (isVisibleToUser && isFirst) {
Log.d(TAG, "BFragment 首次加载"); isFirst = false;
}
} private void initView(View view) { }
}
CFragment
和BFragment
相似,就不赘述了。
MainActivity
对应的布局文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
android:orientation="vertical"
tools:context=".ui.activity.MainActivity"> <android.support.design.widget.TabLayout
android:id="@+id/tab_layout"
android:layout_width="match_parent"
android:layout_height="50dp"
app:tabMode="scrollable"
app:tabSelectedTextColor="@color/colorAccent"> <android.support.design.widget.TabItem
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="A" /> <android.support.design.widget.TabItem
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="B" /> <android.support.design.widget.TabItem
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="C" /> </android.support.design.widget.TabLayout> <android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:overScrollMode="never"
android:scrollbars="none" /> </LinearLayout>
AFragment
、 BFragment
、 CFragment
对应的布局文件就不赘述了,可以随意自定义。
源码下载:
https://github.com/cnwutianhao/ViewPager
最新文章
- django 强制登录最佳实践
- IE8下调用Active控件
- 网站缓存数据到tomcat服务器
- ccc 函数中写函数
- Linux 统计某个字符串出现的次数
- Create Stacked Canvas to Scroll Horizontal Tabular Data Blocks In Oracle Forms
- MVC中过虑特殊字符检测
- 10.24 noip模拟试题
- [HAOI 2010]软件安装
- GoLang函数参数的传递练习
- PAT 乙级 1063 计算谱半径(20) C++版
- GPUImage中曝光滤镜实现——GPUImageExposureFilter
- grunt源码解析:整体运行机制&;grunt-cli源码解析
- kohana 简单使用
- Pyplot绘图的格式
- 微信小程序详解——页面之间的跳转方式【路由】和参数传递
- number to string
- scala学习之实现RPC通信
- Android-ListView-SimpleCursorAdapter
- 火狐浏览器(FireFox)安装Flash插件失败处理方法
热门文章
- 达信:深度解读COSO新版企业风险管理框架(ERM)
- 【oracle】select into from 和 insert into select 的用法和区别
- SQL Server 默认跟踪(Trace)捕获事件详解
- time、datetime
- Bring JavaScript to your Java enterprise with Vert.x
- django ORM CRUD
- Flask视图之CBV示列
- NOIP2013-2014提高组题目浅析
- 2090. 「ZJOI2016」旅行者 分治,最短路
- NOIP2019翻车前写(and 抄)过的代码