PullToRefreshScrollView+Fragment+轮播图+上拉下拉+json解析

public class Fragment02 extends Fragment{
    private PullToRefreshScrollView refreshScrollView;
    private ViewPager viewPager;
    private ListView listView;
    private List<DataDataBean3.ResultsBean> list = new ArrayList<>();//记录当前展示的所有数据
    private int page_num = 1;
    private ILoadingLayout startLabels;
    private List<String> imageUrlList;
    private Handler handler = new Handler(){
        @Override
        public void handleMessage(Message msg) {
            if (msg.what == 0){
                //显示下一页....拿到当前页+1
                viewPager.setCurrentItem(viewPager.getCurrentItem() +1);


                //再次发送消息
                handler.sendEmptyMessageDelayed(0,2000);
            }
        }
    };
    private MyAdapter3 adapter;


    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view=inflater.inflate(R.layout.fragment02,container,false);
        refreshScrollView = view.findViewById(R.id.refresh_scroll_view);
        viewPager = view.findViewById(R.id.image_view_pager);
        listView = view.findViewById(R.id.mylistview);
        return view;
    }


    @Override
    public void onActivityCreated(@Nullable Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);
        //失去焦点
        listView.setFocusable(false);




        //轮播图
        lunBoTu();


        //listView展示数据
        //1.获取网络数据,,,展示在listView上
        getDataFromNet();


        //2.设置刷新模式
        /*设置pullToRefreshListView的刷新模式,BOTH代表支持上拉和下拉,PULL_FROM_END代表上拉,PULL_FROM_START代表下拉 */
        refreshScrollView.setMode(PullToRefreshBase.Mode.BOTH);


        //3.通过getLoadingLayoutProxy 方法来指定上拉和下拉时显示的状态的区别(也就是设置向下拉的时候头部里面显示的文字)
        //此时这里设置的是下拉刷新的时候显示的文字,所以第一个设置true表示现在是刷新,第二个设置为false
        startLabels = refreshScrollView.getLoadingLayoutProxy(true, false);
        startLabels.setPullLabel("下拉刷新");
        startLabels.setRefreshingLabel("正在刷新...");
        startLabels.setReleaseLabel("放开刷新");


        ILoadingLayout endLabels = refreshScrollView.getLoadingLayoutProxy(false, true);
        endLabels.setPullLabel("上拉刷新");
        endLabels.setRefreshingLabel("正在载入...");
        endLabels.setReleaseLabel("放开刷新...");


        /**
         * 监听事件
         */
        refreshScrollView.setOnRefreshListener(new PullToRefreshBase.OnRefreshListener2<ScrollView>() {
            @Override
            public void onPullDownToRefresh(PullToRefreshBase<ScrollView> refreshView) {
                getRefreshData();
            }


            @Override
            public void onPullUpToRefresh(PullToRefreshBase<ScrollView> refreshView) {
                page_num++;
                getDataFromNet();
            }
        });
    }
    /**
     * 轮播图的方法
     */
    private void lunBoTu() {
        NetDataUtil.getData("http://v3.wufazhuce.com:8000/api/reading/index/?version=3.5.0&platform=android", getActivity(), new JsonCallBack() {
            @Override
            public void getJson(String json) {
                //这个结合记录轮播图的所有地址
                imageUrlList = new ArrayList<String>();


                //解析数据
                Gson gson = new Gson();


                DataDataBean2 lunBoBean = gson.fromJson(json, DataDataBean2.class);


                List<DataDataBean2.DataBean.EssayBean> essay = lunBoBean.getData().getEssay();


                for (DataDataBean2.DataBean.EssayBean essayBean : essay) {
                    //essayBean.getAuthor().get(0).getWeb_url()
                    imageUrlList.add(essayBean.getAuthor().get(0).getWeb_url());
                }


                //此时应该根据图片的路径,加载图片,设置适配器
                ViewPagerAdapter viewPagerAdapter = new ViewPagerAdapter(getActivity(), imageUrlList);
                viewPager.setAdapter(viewPagerAdapter);


                //1.手动可以无限滑动....maxValue....把当前开始展示的位置放在足够大的某个位置
                viewPager.setCurrentItem(imageUrlList.size() * 100000);


                //2.自动轮播
                handler.sendEmptyMessageDelayed(0, 2000);
            }
        });
    }
    /**
     * 下拉刷新获取数据
     */
    private void getRefreshData() {
        NetDataUtil.getData("http://gank.io/api/data/Android/10/1", getActivity(), new JsonCallBack() {




            @Override
            public void getJson(String json) {
                //解析
                Gson gson = new Gson();


                DataDataBean3 dataDataBean4 = gson.fromJson(json, DataDataBean3.class);
                //先清空一下数据
                list.clear();


                //添加到集合的最前边,,,,(0,,,,)
                list.addAll(0, dataDataBean4.getResults());


                //设置适配器
                setAdapter();


                //设置适配器之后停止刷新的操作
                refreshScrollView.onRefreshComplete();


                //可以设置刷新的时间....
                startLabels.setLastUpdatedLabel("上次更新时间:" + new SimpleDateFormat("HH:mm").format(new Date(System.currentTimeMillis())));//last最近的,最后一次update修改/更新
            }
        });
    }
    /**
     * 刚开始进入页面获取网络数据....还可以作为上拉加载获取数据的操作
     *
     *
     */
    private void getDataFromNet() {
        //第一个参数是接口,第二个上下文,第三个回调json数据
        NetDataUtil.getData("http://gank.io/api/data/Android/10/" + page_num, getActivity(), new JsonCallBack() {




            @Override
            public void getJson(String json) {
                //解析
                Gson gson = new Gson();


                DataDataBean3 dataDataBean = gson.fromJson(json, DataDataBean3.class);


                //往后面添加...
                list.addAll(dataDataBean.getResults());


                //设置适配器
                setAdapter();


                //停止刷新
                refreshScrollView.onRefreshComplete();
            }
        });
    }
    private void setAdapter(){
        if(adapter==null){
            adapter = new MyAdapter3(getActivity(),list);
            listView.setAdapter(adapter);


        }else{
            adapter.notifyDataSetChanged();
        }
    }


}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值