在参考了众多大神的博客之后,终于学会了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的下载地址,上面的代码是全部的,如果没有积分就不用去下载了。