爱程序网

viewpager和fragment预加载的解决

来源: 阅读:

在使用Viewpager和fragment处理中会出现预加载的问题,最近看别人的代码,终于找到了一个很好的处理方法

能有效的解决预加载的问题,在fragment都继承一个重写setUserVisibleHint类的基类

如图是效果图

      

其实在是一个fragment中,用Viewpager和fragment再展示3个界面

不过如果你是在activity中实现Viewpager和fragment的结合不要这么麻烦  这句代码就够了 viewPager.setOffscreenPageLimit(3)不用重写什么MyLazyFragment 了;

如下是主要代码

package com.ithello.suibianxie.activity.notice;

import android.support.v4.app.Fragment;

public abstract class MyLazyFragment extends Fragment {
    
    protected boolean isVisible;

    /**
     * 在这里实现Fragment数据的缓加载.
     * 
     * @param isVisibleToUser
     */
    
    @Override
    public void setUserVisibleHint(boolean isVisibleToUser) {
        super.setUserVisibleHint(isVisibleToUser);
        if (getUserVisibleHint()) {
            isVisible = true;
            onVisible();
        } else {
            isVisible = false;
            onInvisible();
        }
    }

    protected abstract void onVisible();

    protected abstract void onInvisible();
}

其中第一个fragment的处理方法和其他的不同

package com.ithello.suibianxie.activity.fragment;

import org.xutils.x;
import org.xutils.common.Callback;
import org.xutils.http.RequestParams;

import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

import com.ithello.suibianxie.R;
import com.ithello.suibianxie.activity.notice.MyLazyFragment;
import com.ithello.suibianxie.common.GlobalData;
import com.ithello.suibianxie.util.Constant;

public class VideoListFragment extends MyLazyFragment{
    
    private boolean isPrepared;
    private boolean isFirstLoad = false;
    private TextView tView;
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        //return inflater.inflate(R.layout.videolistfragment, container, false);
        View view = inflater.inflate(R.layout.videolistfragment, null);
        isPrepared = true;
        initView(view);
        System.out.println("1");
        firstLoad();
        return view;
    }
    
    private void initView(View view) {
        // TODO Auto-generated method stub
        tView=(TextView)view.findViewById(R.id.tv_videofragment);
    }

    @Override
    protected void onVisible() {
        // TODO Auto-generated method stub
        Log.d("jiejie", "11 isPreparen:" + isPrepared + ", isVisible" + isVisible);
        if(!isPrepared || !isVisible){
            return;
        }
        if(!isFirstLoad){
            isFirstLoad = true;
            //firstLoad();
        }
    }

    private void firstLoad() {
        // TODO Auto-generated method stub
        requestDates();
    }

    private void requestDates() {
        // TODO Auto-generated method stub
        RequestParams params = new RequestParams(Constant.findAppArticleList_url);
        params.addBodyParameter("rc", GlobalData.getGlobalData().getRc());
        params.addBodyParameter("page", 1+"");
        params.addBodyParameter("rows", 10 +"");
        params.addBodyParameter("appOS", "android");
        x.http().get(params, new Callback.CommonCallback<String>() {

            @Override
            public void onCancelled(CancelledException arg0) {
                // TODO Auto-generated method stub
                
            }

            @Override
            public void onError(Throwable arg0, boolean arg1) {
                // TODO Auto-generated method stub
                
            }

            @Override
            public void onFinished() {
                // TODO Auto-generated method stub
                
            }

            @Override
            public void onSuccess(String arg0) {
                // TODO Auto-generated method stub
                Log.d("jiejie", arg0);
                tView.setText(arg0);
            }
        });
    }

    @Override
    protected void onInvisible() {
        // TODO Auto-generated method stub
        
    }

}
package com.ithello.suibianxie.activity.fragment;

import java.util.ArrayList;
import java.util.List;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import org.xutils.x;
import org.xutils.common.Callback;
import org.xutils.http.RequestParams;

import android.os.Bundle;
import android.text.format.DateUtils;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ListView;

import com.handmark.pulltorefresh.library.PullToRefreshBase;
import com.handmark.pulltorefresh.library.PullToRefreshBase.OnLastItemVisibleListener;
import com.handmark.pulltorefresh.library.PullToRefreshBase.OnRefreshListener;
import com.handmark.pulltorefresh.library.PullToRefreshListView;
import com.ithello.suibianxie.R;
import com.ithello.suibianxie.activity.notice.MyLazyFragment;
import com.ithello.suibianxie.adapter.ArticleAdapter;
import com.ithello.suibianxie.common.GlobalData;
import com.ithello.suibianxie.entity.Article;
import com.ithello.suibianxie.util.Constant;

public class ArticleFragment extends MyLazyFragment {
    // private List<Article> list = new ArrayList<Article>();
    private List<JSONObject> list = new ArrayList<JSONObject>();
    private PullToRefreshListView mPullToRefreshListView;
    private ListView listView;
    private ArticleAdapter mAdapter;

    private int page = 0;
    private int rows = 10;
    private int total = 0;
    // private String urlString
    // ="http://111.39.245.155:9527/dtbt/findAppArticleList.action";

    // 标志位,标志已经初始化完成
    private boolean isPrepared;
    private boolean isFirstLoad = false;

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        // return super.onCreateView(inflater, container, savedInstanceState);
        // return inflater.inflate(R.layout.articlefragment, container, false);
        View view = inflater.inflate(R.layout.articlefragment, null);
        initListView(view);
        isPrepared = true;
        System.out.println("2");
        return view;
    }

    @Override
    protected void onVisible() {
        // TODO Auto-generated method stub
        Log.d("jiejie", "22  isPrepared:" + isPrepared + ", isVisible" + isVisible);
        if (!isPrepared || !isVisible) {
            return;
        }
        if (!isFirstLoad) {
            isFirstLoad = true;
            firstLoad();
        }

    }

    @Override
    protected void onInvisible() {
        // TODO Auto-generated method stub
    }

    private void firstLoad() {
        // TODO Auto-generated method stub
//        mAdapter.notifyDataSetChanged();
//        list.clear();
        page = 1;
        requestDate(page);
    }

    private void initListView(View view) {
        // TODO Auto-generated method stub
        listView = (ListView)view.findViewById(R.id.art_listview);
    
    }

    

    /**
     * 进行网络的请求
     * 
     * @param page2
     */
    protected void requestDate(int page2) {
        // TODO Auto-generated method stub
        RequestParams params = new RequestParams(
                Constant.findAppArticleList_url);
        params.addBodyParameter("rc", GlobalData.getGlobalData().getRc());
        params.addBodyParameter("page", page2 + "");
        params.addBodyParameter("rows", rows + "");
        params.addBodyParameter("appOS", "android");
        x.http().get(params, new Callback.CommonCallback<String>() {

            @Override
            public void onCancelled(CancelledException arg0) {
                // TODO Auto-generated method stub

            }

            @Override
            public void onError(Throwable arg0, boolean arg1) {
                // TODO Auto-generated method stub

            }

            @Override
            public void onFinished() {
                // TODO Auto-generated method stub

            }

            @Override
            public void onSuccess(String arg0) {
                // TODO Auto-generated method stub
                System.out.println(arg0);
                Log.d("jiejie", arg0);
                if(arg0 != null){
                    try {
                        JSONObject object= new JSONObject(arg0);
                        JSONArray array = object.getJSONArray("rows");
                        JSONObject dataJsonObject;
                        for(int i = 0 ; i<array.length();i++){
                            dataJsonObject =array.getJSONObject(i);
                            list.add(dataJsonObject);
                        }
                    } catch (JSONException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                    mAdapter = new ArticleAdapter(getActivity(), list);
                    listView.setAdapter(mAdapter);
                }
            }
        });
    }

}
package com.ithello.suibianxie.activity.fragment;

import org.xutils.x;
import org.xutils.common.Callback;
import org.xutils.http.RequestParams;

import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

import com.ithello.suibianxie.R;
import com.ithello.suibianxie.activity.notice.MyLazyFragment;
import com.ithello.suibianxie.common.GlobalData;
import com.ithello.suibianxie.util.Constant;

public class NoticeFragment extends MyLazyFragment{
    private boolean isPrepared;
    private boolean  isFirstLoad = false;
    private TextView tView ;
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        //return inflater.inflate(R.layout.noticefragment, container, false);
        View view = inflater.inflate(R.layout.noticefragment, null);
        isPrepared = true;
        initView(view);
        System.out.println("3");
        return view;
    }
    private void initView(View view) {
        // TODO Auto-generated method stub
        tView = (TextView)view.findViewById(R.id.tv_notice);
    }
    @Override
    protected void onVisible() {
        // TODO Auto-generated method stub
        Log.d("jiejie", "33 isPreparen" + isPrepared + ", isVisibletrue" + isVisible);
        if(!isPrepared || !isVisible){
            return;
        }
        if(!isFirstLoad){
            isFirstLoad = true;
            firstLoad();
        }
    }

    @Override
    protected void onInvisible() {
        // TODO Auto-generated method stub
        
    }
    private void firstLoad() {
        // TODO Auto-generated method stub
        stHttoop();
    }
    private void stHttoop() {
        // TODO Auto-generated method stub
        RequestParams params = new RequestParams(Constant.findAppArticleList_url);
        params.addBodyParameter("rc", GlobalData.getGlobalData().getRc());
        params.addBodyParameter("page", 1+"");
        params.addBodyParameter("rows", 10 +"");
        params.addBodyParameter("appOS", "android");
        x.http().get(params, new Callback.CommonCallback<String>() {

            @Override
            public void onCancelled(CancelledException arg0) {
                // TODO Auto-generated method stub
                
            }

            @Override
            public void onError(Throwable arg0, boolean arg1) {
                // TODO Auto-generated method stub
                
            }

            @Override
            public void onFinished() {
                // TODO Auto-generated method stub
                
            }

            @Override
            public void onSuccess(String arg0) {
                // TODO Auto-generated method stub
                Log.d("jiejie", arg0);
                tView.setText(arg0);
            }
        });
    }

}

其中Viewpager和fragment的结合我用的是IndicatorViewPager来实现的

package com.ithello.suibianxie.fragment;

import com.ithello.suibianxie.R;
import com.ithello.suibianxie.activity.fragment.ArticleFragment;
import com.ithello.suibianxie.activity.fragment.NoticeFragment;
import com.ithello.suibianxie.activity.fragment.VideoListFragment;
import com.potato.viewpagerindicator.view.indicator.IndicatorViewPager;
import com.potato.viewpagerindicator.view.indicator.adapter.IndicatorFragmentPagerAdapter;
import com.potato.viewpagerindicator.view.indicator.indicator.Indicator;
import com.potato.viewpagerindicator.view.indicator.slidebar.ColorBar;
import com.potato.viewpagerindicator.view.indicator.transition.OnTransitionTextListener;

import android.content.res.Resources;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.RelativeLayout;
import android.widget.TextView;

/**
 * 第三个fragment
 * @author zh
 *
 */
public class MThreeFragment extends Fragment{
    private IndicatorViewPager indicatorViewPager;
    
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        return inflater.inflate(R.layout.mthreefragment, container, false);
    }
    @Override
    public void onActivityCreated(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onActivityCreated(savedInstanceState);
        setView();
    }
    
    private void setView() {
        // TODO Auto-generated method stub
        Resources res = getResources();
        ViewPager viewPager =(ViewPager)getActivity().findViewById(R.id.fragment_training_home_viewPager);
        Indicator indicator =(Indicator)getActivity().findViewById(R.id.fragment_training_home_fixedindicatorview);
        int color =getResources().getColor(R.color.tab_indicator_daab3c);
        indicator.setScrollBar(new ColorBar(getActivity(), color, 2));
        float unSelectSize = 14;
        float selectSize = unSelectSize * 1.0f;
        int selectColor =res.getColor(R.color.tab_title_color_select_daab3c);
        int unSelectColor = res.getColor(R.color.tab_title_color_normal_e8d6ab);
        indicator.setOnTransitionListener(new OnTransitionTextListener().setColor(selectColor, unSelectColor).setSize(selectSize, unSelectSize));
        viewPager.setOffscreenPageLimit(3);
        indicatorViewPager = new IndicatorViewPager(indicator, viewPager);
        indicatorViewPager.setAdapter(new MyAdapter(getChildFragmentManager()));
    }
    
    private String[] tabNames ={"视频","文章","通知"};
    
    private class MyAdapter extends IndicatorFragmentPagerAdapter{

        public MyAdapter(FragmentManager fragmentManager) {
            super(fragmentManager);
            // TODO Auto-generated constructor stub
        }

        @Override
        public int getCount() {
            // TODO Auto-generated method stub
            return 3;
        }
        
        @Override
        public Fragment getFragmentForPage(int position) {
            // TODO Auto-generated method stub
            Bundle bundle = new Bundle();
            if(position ==0){
                VideoListFragment videoListFragment = new VideoListFragment();
                videoListFragment.setArguments(bundle);
                return videoListFragment;
            }else if (position == 1) {
                ArticleFragment articleFragment = new ArticleFragment();
                articleFragment.setArguments(bundle);
                return articleFragment;
            }else if (position ==2) {
                NoticeFragment noticeFragment = new NoticeFragment();
                noticeFragment.setArguments(bundle);
                return noticeFragment;
            }
            VideoListFragment mainFragment = new VideoListFragment();
            mainFragment.setArguments(bundle);
            return mainFragment;
        }

        @Override
        public View getViewForTab(int position, View convertView, ViewGroup container) {
            // TODO Auto-generated method stub
            if(convertView == null){
                if(position ==0){
                    convertView = View.inflate(getActivity(), R.layout.title_bae_left, null);
                }else if (position ==1) {
                    convertView = View.inflate(getActivity(), R.layout.title_bar_middle, null);
                }else if (position == 2) {
                    convertView = View.inflate(getActivity(), R.layout.title_bar_right, null);
                }
            }
            RelativeLayout layout = (RelativeLayout)convertView;
            TextView tView = (TextView)layout.findViewById(R.id.tv);
            tView.setText(tabNames[position]);
            return convertView;
        }
        
    }
    
}

 

关于爱程序网 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助