使用pullToRefresh进行下拉刷新和上拉加载
2017-10-18 20:07
645 查看
1.使用import moundle导进这个库文件,添加库文件的依赖
.此时左下角可能会报错,只需要点击install...去下载16版本的sdk,还需要下载19版本的buildTools
2.代码实现:
private PullToRefreshListView refreshListView;
private List<DataDataBean.ResultsBean> list = new ArrayList<>();//记录当前展示的所有数据
private ListViewAdapter listViewAdapter;
private int page_num = 1;
private ILoadingLayout startLabels;
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_listview_layout,container,false);
refreshListView = view.findViewById(R.id.refresh_list_view);
return view;
}
@Override
public void onActivityCreated(@Nullable Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
//1.首次加载
getDataFromNet();
//2.设置刷新模式
/*设置pullToRefreshListView的刷新模式,BOTH代表支持上拉和下拉,PULL_FROM_END代表上拉,PULL_FROM_START代表下拉 */
refreshListView.setMode(PullToRefreshBase.Mode.BOTH);
//3.通过getLoadingLayoutProxy 方法来指定上拉和下拉时显示的状态的区别(也就是设置向下拉的时候头部里面显示的文字)
//此时这里设置的是下拉刷新的时候显示的文字,所以第一个设置true表示现在是刷新,第二个设置为false
startLabels = refreshListView.getLoadingLayoutProxy(true, false);
startLabels.setPullLabel("下拉刷新");
startLabels.setRefreshingLabel("正在刷新...");
startLabels.setReleaseLabel("放开刷新");
ILoadingLayout endLabels = refreshListView.getLoadingLayoutProxy(false, true);
endLabels.setPullLabel("上拉刷新");
endLabels.setRefreshingLabel("正在载入...");
endLabels.setReleaseLabel("放开刷新...");
//4.设置监听事件
refreshListView.setOnRefreshListener(new PullToRefreshBase.OnRefreshListener2<ListView>() {
//下拉刷新的时候调用的方法....请求第一页的数据,清空之前的数据,然后再添加设置适配器
@Override
public void onPullDownToRefresh(PullToRefreshBase<ListView> refreshView) {
//下拉刷新....请求第一页的数据,清空之前的数据,然后再添加设置适配器
getRefreshData();
}
//上拉刷新的时候调用的方法..page++,然后在请求数据
@Override
public void onPullUpToRefresh(PullToRefreshBase<ListView> refreshView) {
//上拉刷新/加载...加载的时候页数++
page_num++;
getDataFromNet();
}
});
}
/**
* 下拉刷新获取数据
*/
private void getRefreshData() {
NetDataUtil.getData("http://gank.io/api/data/Android/10/1", getActivity(), new JsonCallBack() {
@Override
public void getJsonString(String json) {
//解析
Gson gson = new Gson();
DataDataBean dataDataBean = gson.fromJson(json, DataDataBean.class);
//先清空一下数据
list.clear();
//添加到集合的最前边,,,,(0,,,,)
list.addAll(0,dataDataBean.getResults());
//设置适配器
setAdapter();
//设置适配器之后停止刷新的操作
refreshListView.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 getJsonString(String json) {
//解析
Gson gson = new Gson();
DataDataBean dataDataBean = gson.fromJson(json, DataDataBean.class);
//往后面添加...
list.addAll(dataDataBean.getResults());
//设置适配器
setAdapter();
//停止刷新
refreshListView.onRefreshComplete();
}
});
}
private void setAdapter() {
if (listViewAdapter == null){
listViewAdapter = new ListViewAdapter(getActivity(),list);
refreshListView.setAdapter(listViewAdapter);
}else {
listViewAdapter.notifyDataSetChanged();
}
}
.此时左下角可能会报错,只需要点击install...去下载16版本的sdk,还需要下载19版本的buildTools
2.代码实现:
private PullToRefreshListView refreshListView;
private List<DataDataBean.ResultsBean> list = new ArrayList<>();//记录当前展示的所有数据
private ListViewAdapter listViewAdapter;
private int page_num = 1;
private ILoadingLayout startLabels;
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_listview_layout,container,false);
refreshListView = view.findViewById(R.id.refresh_list_view);
return view;
}
@Override
public void onActivityCreated(@Nullable Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
//1.首次加载
getDataFromNet();
//2.设置刷新模式
/*设置pullToRefreshListView的刷新模式,BOTH代表支持上拉和下拉,PULL_FROM_END代表上拉,PULL_FROM_START代表下拉 */
refreshListView.setMode(PullToRefreshBase.Mode.BOTH);
//3.通过getLoadingLayoutProxy 方法来指定上拉和下拉时显示的状态的区别(也就是设置向下拉的时候头部里面显示的文字)
//此时这里设置的是下拉刷新的时候显示的文字,所以第一个设置true表示现在是刷新,第二个设置为false
startLabels = refreshListView.getLoadingLayoutProxy(true, false);
startLabels.setPullLabel("下拉刷新");
startLabels.setRefreshingLabel("正在刷新...");
startLabels.setReleaseLabel("放开刷新");
ILoadingLayout endLabels = refreshListView.getLoadingLayoutProxy(false, true);
endLabels.setPullLabel("上拉刷新");
endLabels.setRefreshingLabel("正在载入...");
endLabels.setReleaseLabel("放开刷新...");
//4.设置监听事件
refreshListView.setOnRefreshListener(new PullToRefreshBase.OnRefreshListener2<ListView>() {
//下拉刷新的时候调用的方法....请求第一页的数据,清空之前的数据,然后再添加设置适配器
@Override
public void onPullDownToRefresh(PullToRefreshBase<ListView> refreshView) {
//下拉刷新....请求第一页的数据,清空之前的数据,然后再添加设置适配器
getRefreshData();
}
//上拉刷新的时候调用的方法..page++,然后在请求数据
@Override
public void onPullUpToRefresh(PullToRefreshBase<ListView> refreshView) {
//上拉刷新/加载...加载的时候页数++
page_num++;
getDataFromNet();
}
});
}
/**
* 下拉刷新获取数据
*/
private void getRefreshData() {
NetDataUtil.getData("http://gank.io/api/data/Android/10/1", getActivity(), new JsonCallBack() {
@Override
public void getJsonString(String json) {
//解析
Gson gson = new Gson();
DataDataBean dataDataBean = gson.fromJson(json, DataDataBean.class);
//先清空一下数据
list.clear();
//添加到集合的最前边,,,,(0,,,,)
list.addAll(0,dataDataBean.getResults());
//设置适配器
setAdapter();
//设置适配器之后停止刷新的操作
refreshListView.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 getJsonString(String json) {
//解析
Gson gson = new Gson();
DataDataBean dataDataBean = gson.fromJson(json, DataDataBean.class);
//往后面添加...
list.addAll(dataDataBean.getResults());
//设置适配器
setAdapter();
//停止刷新
refreshListView.onRefreshComplete();
}
});
}
private void setAdapter() {
if (listViewAdapter == null){
listViewAdapter = new ListViewAdapter(getActivity(),list);
refreshListView.setAdapter(listViewAdapter);
}else {
listViewAdapter.notifyDataSetChanged();
}
}
相关文章推荐
- 使用pullToRefresh进行下拉刷新和上拉加载
- 使用pullToRefresh进行下拉刷新和上拉加载
- listView利用BaseAdapter及异步任务Gson解析,使用Picasso网络获取资源进行图文混排,PullToRefresh上拉刷新下拉加载
- 关于PullToRefresh对于数据的解析和上拉刷新下拉加载
- android使用PullToRefresh实现上拉加载和下拉刷新效果
- PullToRefresh上拉刷新下拉加载更多的使用
- 【Android-PullToRefresh】 上拉刷新、下拉加载 使用详解
- 使用Android开源工具PullToRefresh实现上啦刷新下拉加载
- android使用PullToRefresh实现上拉加载和下拉刷新效果
- android使用PullToRefresh实现上拉加载和下拉刷新效果
- Android使用PullToRefresh实现上拉加载和下拉刷新效果的代码
- PullToRefresh 上拉刷新,下拉加载数据 框架的简单使用
- 使用PullToRefresh实现下拉刷新和上拉加载
- 4.5.1 Good 使用PullToRefresh实现下拉刷新和上拉加载
- 使用PullToRefresh实现下拉刷新和上拉加载
- 针对自定义组件上拉刷新下拉加载更多PullToRefreshView的分析(二)
- 使用PullToRefresh实现下拉刷新和上拉加载
- 使用PullToRefresh实现下拉刷新和上拉加载
- 针对自定义组件上拉刷新下拉加载更多PullToRefreshView的分析(一)
- 使用自定义的item、Adapter和AsyncTask、第三方开源框架PullToRefresh联合使用实现自定义的下拉列表(从网络加载图片显示在item中的ImageView)