如果想要让应用用户流畅的滑动体验的话,那么就必须对activity和fragment的生命周期有一个完整的概念以及在何种情况下会触发哪些事件。
在自己目前做的项目中,就遇到了这样的问题,那么就把自己的解决方法罗列,重点在于onpause,onstop,onstart,onresume的事件处理。
某些耗时的操作延迟加载,先展示总体页面。
当对某些复杂的页面进行切换时,先隐藏后显示,如果不是特别卡顿不需要隐藏,如果卡顿严重的话强烈推荐隐藏,提升用户体验。
代码如下:
package com.hengtiansoft.mecb.fragment; import java.io.IOException; import java.util.ArrayList; import java.util.List; import android.os.Bundle; import android.os.Handler; import android.support.v4.view.ViewPager; import android.support.v4.view.ViewPager.OnPageChangeListener; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.ListView; import android.widget.RadioButton; import android.widget.RadioGroup; import android.widget.Toast; import android.widget.RadioGroup.OnCheckedChangeListener; import com.hengtiansoft.mecb.R; import com.hengtiansoft.mecb.adapter.FragmentTabPagerAdapter; import com.hengtiansoft.mecb.adapter.ProductOnSaleAdapter; import com.hengtiansoft.mecb.model.MenuProductOnSaleModel; import com.viewpagerindicator.UnderlinePageIndicator; public class MenuProductFragment extends BaseFragment{ private ViewPager mVpProductPage; private FragmentTabPagerAdapter mTabPagerProductAdapter; private List<BaseFragment> mProductTabFragment; private RadioGroup mRgProductTab; private RadioButton mRbOnSale; private RadioButton mRbForSale; private RadioButton mRbOffSale; private UnderlinePageIndicator mIndicator; private View mView; //流畅显示切换所用的线程 private Handler handler = new Handler(); @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { mView = inflater.inflate(R.layout.fragment_menu_product, container, false); initView(mView); return mView; } @Override public void onStart() { super.onStart(); handler.postDelayed(new Runnable() { public void run() { setData(mView); } }, 200); setListener(mView); } @Override public void onResume() { super.onResume(); handler.postDelayed(new Runnable() { public void run() { mVpProductPage.setVisibility(View.VISIBLE); } }, 0); } @Override public void onPause() { super.onPause(); handler.postDelayed(new Runnable() { public void run() { mVpProductPage.setVisibility(View.INVISIBLE); } }, 100); } private void initView(View view) { mVpProductPage = (ViewPager)view.findViewById(R.id.vp_product_page); mIndicator = (UnderlinePageIndicator)view.findViewById(R.id.indicator_product_sort); mRgProductTab = (RadioGroup) view.findViewById(R.id.rg_product_tab); mRbOnSale = (RadioButton)view.findViewById(R.id.rb_product_onsale); mRbOffSale = (RadioButton)view.findViewById(R.id.rb_product_offsale); mRbForSale = (RadioButton)view.findViewById(R.id.rb_product_forsale); } private void setData(View view) { mProductTabFragment = new ArrayList<BaseFragment>(); mProductTabFragment.add(new ProductOnSaleFragment()); mProductTabFragment.add(new ProductForSaleFragment()); mProductTabFragment.add(new ProductOffSaleFragment()); mTabPagerProductAdapter = new FragmentTabPagerAdapter(mProductTabFragment, getChildFragmentManager()); mVpProductPage.setAdapter(mTabPagerProductAdapter); mVpProductPage.setOffscreenPageLimit(2); mIndicator.setViewPager(mVpProductPage); mIndicator.setFades(false); } private void setListener(View view) { mRgProductTab.setOnCheckedChangeListener(new OnCheckedChangeListener(){ @Override public void onCheckedChanged(RadioGroup arg0, int checkedId) { if(checkedId == mRbOnSale.getId()){ mVpProductPage.setCurrentItem(0,false); }else if(checkedId == mRbForSale.getId()){ mVpProductPage.setCurrentItem(1,false); }else{ mVpProductPage.setCurrentItem(2,false); } } }); mIndicator.setOnPageChangeListener(new OnPageChangeListener(){ @Override public void onPageScrollStateChanged(int position) { } @Override public void onPageScrolled(int arg0, float arg1, int arg2) { } @Override public void onPageSelected(int position) { switch(position){ case 0: mRbOnSale.setChecked(true); break; case 1: mRbForSale.setChecked(true); break; case 2: mRbOffSale.setChecked(true); break; default: break; } } }); } }