PullToRefreshScrollView
来源:互联网 发布:网络机顶盒换系统 编辑:程序博客网 时间:2024/05/22 05:21
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);
}
}
};
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_scroll_layout, container, false);
refreshScrollView = view.findViewById(R.id.refresh_scroll_view);
viewPager = view.findViewById(R.id.image_view_pager);
listView = view.findViewById(R.id.scroll_list_view);
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 getJsonString(String json) {
//这个结合记录轮播图的所有地址
imageUrlList = new ArrayList<String>();
//解析数据
Gson gson = new Gson();
LunBoBean lunBoBean = gson.fromJson(json, LunBoBean.class);
List<LunBoBean.DataBean.EssayBean> essay = lunBoBean.getData().getEssay();
for (LunBoBean.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 getJsonString(String json) {
//解析
Gson gson = new Gson();
DataDataBean dataDataBean = gson.fromJson(json, DataDataBean.class);
//先清空一下数据
list.clear();
//添加到集合的最前边,,,,(0,,,,)
list.addAll(0,dataDataBean.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 getJsonString(String json) {
//解析
Gson gson = new Gson();
DataDataBean dataDataBean = gson.fromJson(json, DataDataBean.class);
//往后面添加...
list.addAll(dataDataBean.getResults());
//设置适配器
setAdapter();
//停止刷新
refreshScrollView.onRefreshComplete();
}
});
}
/**
* 设置适配器的方法
*/
private void setAdapter() {
if (listViewAdapter == null){
listViewAdapter = new ListViewAdapter(getActivity(),list);
listView.setAdapter(listViewAdapter);
}else {
listViewAdapter.notifyDataSetChanged();
}
}
@Override
public void handleMessage(Message msg) {
if (msg.what == 0){
//显示下一页....拿到当前页+1
viewPager.setCurrentItem(viewPager.getCurrentItem() +1);
//再次发送消息
handler.sendEmptyMessageDelayed(0,2000);
}
}
};
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_scroll_layout, container, false);
refreshScrollView = view.findViewById(R.id.refresh_scroll_view);
viewPager = view.findViewById(R.id.image_view_pager);
listView = view.findViewById(R.id.scroll_list_view);
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 getJsonString(String json) {
//这个结合记录轮播图的所有地址
imageUrlList = new ArrayList<String>();
//解析数据
Gson gson = new Gson();
LunBoBean lunBoBean = gson.fromJson(json, LunBoBean.class);
List<LunBoBean.DataBean.EssayBean> essay = lunBoBean.getData().getEssay();
for (LunBoBean.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 getJsonString(String json) {
//解析
Gson gson = new Gson();
DataDataBean dataDataBean = gson.fromJson(json, DataDataBean.class);
//先清空一下数据
list.clear();
//添加到集合的最前边,,,,(0,,,,)
list.addAll(0,dataDataBean.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 getJsonString(String json) {
//解析
Gson gson = new Gson();
DataDataBean dataDataBean = gson.fromJson(json, DataDataBean.class);
//往后面添加...
list.addAll(dataDataBean.getResults());
//设置适配器
setAdapter();
//停止刷新
refreshScrollView.onRefreshComplete();
}
});
}
/**
* 设置适配器的方法
*/
private void setAdapter() {
if (listViewAdapter == null){
listViewAdapter = new ListViewAdapter(getActivity(),list);
listView.setAdapter(listViewAdapter);
}else {
listViewAdapter.notifyDataSetChanged();
}
}
}
//自定义ListView
public class MyListView extends ListView {
public MyListView(Context context) {
super(context);
}
public MyListView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public MyListView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
/**
* 重新计算高度
* @param widthMeasureSpec
* @param heightMeasureSpec
*/
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST);
super.onMeasure(widthMeasureSpec, expandSpec);
}
阅读全文
0 0
- PullToRefreshScrollView
- PullToRefreshScrollView
- PullToRefreshScrollView
- PullToRefreshScrollView
- PullToRefreshScrollView
- PullToRefreshScrollView
- 使用PullToRefreshScrollView
- PullToRefreshScrollView+ListView
- PullToRefreshScrollView用法
- PullToRefreshScrollView结合StickyHeaderGridView
- PullToRefreshScrollView嵌套两个GridView
- Android PullTorefreshScrollview回到顶部
- PullToRefreshScrollView的使用
- PullToRefreshScrollView显示不完全
- PullToRefreshScrollView嵌套viewpager
- PullToRefreshScrollView 添加滚动监听
- PullToRefreshScrollView的使用
- PullToRefreshScrollView+ViewPager+MyListView
- javascript中的&&与||
- git 常用命令(4)- git中本地与远程库的关联与取消
- 对数据结构和算法的总结和思考(六)--计数排序
- OkHttp的请求拦截器,实现请求拦截,打印日志到logcat
- npm WARN enoent ENOENT: no such file or directory, open 'E:\Program Files\nodejs \package.json' npm
- PullToRefreshScrollView
- 高可用eureka服务发现实例
- HTML5中 data-*属性的实际用途
- 跨进程实现音乐播放器
- socket,tcp,http三者之间的区别和原理
- 对数据结构和算法的总结和思考(七)--二分查找
- 台式机如何内外网同时上(笔记本同理,笔记本可以连WiFi)
- 前端用Sass实现星级评定效果,简单快捷实现星级切换。
- 数组NSArray遍历(Objective-C 开发范例)