在参考了众多大神的博客之后,终于学会了Fragment懒加载,特此记录以便以后学习。Fragment懒加载是通过setUserVisibleHint()这个方法实现的,
代码如下:
MainActivity
package com.example.ai.demo4;
import android.support.design.widget.TabLayout;
import android.support.v4.app.Fragment;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import com.example.ai.demo4.fragment.AFragment;
import com.example.ai.demo4.fragment.BFragment;
import com.example.ai.demo4.fragment.CFragment;
import java.util.ArrayList;
public class MainActivity extends AppCompatActivity{
//声明变量
private TabLayout mTabLayout;
private ViewPager mViewPager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//加载控件的实例对象
initView();
//设置底部tab的页面
initData();
}
//加载控件的实例对象
private void initView() {
mTabLayout = findViewById(R.id.tablayout);
mViewPager = findViewById(R.id.viewpager);
}
//设置底部tab的页面
private void initData() {
//填充数据
ArrayList<Fragment> fragmentList = new ArrayList<>();
fragmentList.add(new AFragment());
fragmentList.add(new BFragment());
fragmentList.add(new CFragment());
//为tab命名
ArrayList<String> titleList = new ArrayList<>();
for (int i = 0; i < 3; i++) {
titleList.add("Page_"+i);
}
//配置适配器
MainAdapter adapter = new MainAdapter(getSupportFragmentManager(), fragmentList, titleList);
mViewPager.setAdapter(adapter);
mTabLayout.setupWithViewPager(mViewPager);
}
}
MainActivity.xml
说明:TabLayout,sdk的版本必须是22,要想使用这个控件,你必须下载或更新sdk的版本,你要更新的22也就是5.1的版本,才会有这个控件的出现。
添加库:implementation 'com.android.support:design:26.1.0'(Android stuido版本不同后面的数字有不同)
<?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">
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="300dp"/>
<android.support.design.widget.TabLayout
android:id="@+id/tablayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_scrollFlags="scroll|enterAlways"
app:tabBackground="?attr/colorPrimary"
app:tabIndicatorHeight="2dp"
app:tabTextColor="@android:color/white"/>
</LinearLayout>
基类BaseFragment,使用Fragment时,继承它即可
package com.example.ai.demo4.fragment;
import android.support.v4.app.Fragment;
import android.util.Log;
public abstract class BaseFragment extends Fragment {
//是否可见
protected boolean isVisble;
// 标志位,标志Fragment已经初始化完成。
public boolean isPrepared = false;
/**
* 实现Fragment数据的缓加载
* @param isVisibleToUser
*/
@Override
public void setUserVisibleHint(boolean isVisibleToUser){
super.setUserVisibleHint(isVisibleToUser);
if (getUserVisibleHint()) {
isVisble = true;
onVisible();
}else{
isVisble = false;
onInVisible();
}
}
//当fragment不可见时调用
protected void onInVisible() {}
//当fragment可见时调用
protected void onVisible() {
//加载数据
loadData();
}
//加载数据
protected abstract void loadData();
}
AFragment类:
package com.example.ai.demo4.fragment;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import com.example.ai.demo4.R;
public class AFragment extends BaseFragment{
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState){
Log.d("------", "A----onCreateView");
View view = inflater.inflate(R.layout.fragment_a, container, false);
//初始化view的各控件
isPrepared = true;
loadData();
return view;
}
@Override
protected void loadData() {
if(!isPrepared || !isVisble) {
return;
}
//填充各控件的数据
}
@Override
public void onDestroyView() {
super.onDestroyView();
Log.v("----","A销毁了");
}
AFragment.xml
<?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">
<TextView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:text="aaaaaaa"/>
</LinearLayout>
照 AFragment类写三个,因为要有三个才能测试是否懒加载。有什么问题留言,24小时在线。。
下面是demo的下载地址,上面的代码是全部的,如果没有积分就不用去下载了。