SwipeRefreshLayout实现上拉下拉刷新
1:在布局中添加SwipeRefreshLayout和Listview组件
- <?xml version="1.0" encoding="utf-8"?>
- <RelativeLayout
- style="@style/BaseStyle.White"
- xmlns:android="http://schemas.android.com/apk/res/android">
- <!--下拉刷新-->
- <android.support.v4.widget.SwipeRefreshLayout
- android:id="@+id/srl_refresh"
- style="@style/BaseStyle">
- <!--上拉更多-->
- <ListView
- android:id="@+id/lv_person_goods"
- style="@style/BaseStyle"
- android:gravity="center"
- android:horizontalSpacing="@dimen/margin_standard"
- android:numColumns="2"
- android:scrollbarStyle="outsideOverlay"
- android:verticalSpacing="@dimen/margin_standard"/>
- </android.support.v4.widget.SwipeRefreshLayout>
- <!--数据为空时显示的View-->
- <TextView
- android:id="@+id/tv_no_data"
- style="@style/BaseStyle.FullWrap"
- android:layout_marginTop="@dimen/textview_width_small"
- android:gravity="center_horizontal"
- android:text="暂无数据"
- android:textColor="@color/text_title_standard"
- android:textSize="@dimen/font_size_small"
- android:visibility="gone"/>
- </RelativeLayout>
2:在主页面使用
- /**
- * Created by pengkv on 2014/12/5.
- * 我的宝贝列表页面,用于选择添加到拍卖场
- */
- public class MySaleGoodsListViewActivity extends VolleyActivity implements IInit, IResponseHandler, IPagination, SwipeRefreshLayout.OnRefreshListener {
- private int auctionID;
- private GoodsInfoViewModel mViewModel;
- private TextView mEmptyTV;//空白视图
- private ListView mListView;//专场列表
- private PersonGoodsListAdapter mAdapter;//适配器
- private SwipeRefreshLayout mSwipeRefreshLayout;//下拉刷新布局
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_me_auction_goods_list);
- init();
- }
- @Override
- public void init() {
- ActionBarUtil.setup(this, "我店铺的宝贝");
- auctionID = getIntent().getIntExtra(EnumIntentKey.AUCTION_ID.toString(), 0);
- mListView = (ListView) findViewById(R.id.lv_person_goods);
- mEmptyTV = (TextView) findViewById(R.id.tv_no_data);
- mSwipeRefreshLayout = (SwipeRefreshLayout) findViewById(R.id.srl_refresh);//下拉刷新组件
- mSwipeRefreshLayout.setOnRefreshListener(this);//设置刷新监听器
- mSwipeRefreshLayout.setColorSchemeResources(R.color.background_blue_standard, R.color.white, R.color.background_blue_standard, R.color.white);//设置下拉刷新组件的颜色
- mViewModel = new GoodsInfoViewModel();
- fetchData(FIRST);//得到喜欢列表数据
- }
- @Override
- public void fetchData(int tag) {
- GetGoodsListForSellParam param = new GetGoodsListForSellParam(Data.getUserID(), 1, mViewModel.getPageIndex(), Data.PAGE_SIZE_MEDIUM);
- SquareApi.getGoodsListForSell(this, param, tag);
- }
- /**
- * 更新适配器
- */
- @Override
- protected void onRestart() {
- super.onRestart();
- mViewModel.reset();
- fetchData(FIRST);//得到喜欢列表数据
- }
- @Override
- public void updateUI(Object response, final int tag) {
- if (response == null) return;
- if (tag == FIRST) {
- //得到喜欢列表数据
- mViewModel.inflate(response);
- //通过判断喜欢列表适配器mAdapter是否为空来做分页处理
- if (mAdapter == null) {
- //当适配器为空
- mSwipeRefreshLayout.setRefreshing(false);//下拉刷新组件停止刷新
- mAdapter = new PersonGoodsListAdapter(this, mViewModel.getList());
- mListView.setAdapter(mAdapter);//ListView绑定喜欢适配器
- /**
- * 上拉更多
- */
- mListView.setOnScrollListener(new AbsListView.OnScrollListener() {
- @Override
- public void onScrollStateChanged(AbsListView view, int scrollState) {
- switch (scrollState) {
- case SCROLL_STATE_IDLE:
- if (mListView.getLastVisiblePosition() == mViewModel.getList().size() - 1) {
- if (!mViewModel.isComplete()) {
- fetchNewData(FIRST);
- }
- }
- break;
- }
- }
- @Override
- public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
- }
- });
- mListView.setEmptyView(mEmptyTV);//将此图片绑定到喜欢列表ListView
- } else {
- mAdapter.notifyDataSetChanged();//适配器更新数据
- }
- mListView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
- @Override
- public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
- Intent i = new Intent();
- if (getIntent().getBooleanExtra(EnumIntentKey.IS_SELECT_LINK.toString(), false)) { // 选择发送链接
- i.putExtra(EnumIntentKey.GOODS_ID.toString(), mViewModel.getList().get(position).getGoodsID());
- i.putExtra(EnumIntentKey.GOODS_NAME.toString(), mViewModel.getList().get(position).getGoodsName());
- setResult(RESULT_OK, i);
- } else { // 添加到专场
- i.setClass(MySaleGoodsListViewActivity.this, AddAuctionGoodsActivity.class);
- i.putExtra(EnumIntentKey.AUCTION_GOODS_ID.toString(), mViewModel.getList().get(position).getGoodsID());
- i.putExtra(EnumIntentKey.IS_DO.toString(), true);
- i.putExtra(EnumIntentKey.AUCTION_ID.toString(), auctionID);
- startActivity(i);
- }
- finish();
- }
- });
- }
- }
- @Override
- public void fetchNewData(int tag) {
- mViewModel.increasePageIndex();
- fetchData(FIRST);//得到喜欢的拍品列表数据
- }
- @Override
- public void onRefresh() {
- mViewModel.reset();//重置页索引和完成状态
- mAdapter = null;//清空适配器
- fetchData(FIRST);//得到喜欢的拍品列表数据
- }
- }
解析:
(下拉刷新)主页面需要实现SwipeRefreshLayout.OnRefreshListener接口,然后在
- @Override
- public void onRefresh() {
- }
方法中实现更新
(上拉更多)上拉更多需要监听setOnScrollListener()方法
- mListView.setOnScrollListener(new AbsListView.OnScrollListener() {
- @Override
- public void onScrollStateChanged(AbsListView view, int scrollState) {
- switch (scrollState) {
- case SCROLL_STATE_IDLE:
- if (mListView.getLastVisiblePosition() == mViewModel.getList().size() - 1) {
- if (!mViewModel.isComplete()) {
- fetchNewData(FIRST);
- }
- }
- break;
- }
- }
- @Override
- public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
- }
- });
SwipeRefreshLayout实现上拉下拉刷新的更多相关文章
- 练习使用XRecyclerView,可上拉下拉刷新。
package com.lixu.testxrecyclerview; import android.support.v7.app.AppCompatActivity; import android. ...
- iOS不得姐项目--推荐关注模块(一个控制器控制两个tableView),数据重复请求的问题,分页数据的加载,上拉下拉刷新(MJRefresh)
一.推荐关注模块(一个控制器控制两个tableView) -- 数据的显示 刚开始加载数据值得注意的有以下几点 导航控制器会自动调整scrollView的contentInset,最好是取消系统的设置 ...
- 解决iscroll.js上拉下拉刷新手指划出屏幕页面无法回弹问题
博客已迁移至http://zlwis.me. 使用过iscroll.js的上拉下拉刷新效果的朋友应该都碰到过这个问题:在iOS的浏览器中,上拉或下拉刷新时,当手指划出屏幕后,页面无法弹回.很多人因为解 ...
- swift实现UItableview上拉下拉刷新模块
最近用写个项目 发现上拉下拉刷新模块没找到合适的 so 自己写了一个 由于最近忙 教程就不写了 里面有 直接贴地址https://github.com/DaChengTechnology/DCRefr ...
- 打造android万能上拉下拉刷新框架——XRefreshView (二)
打造Android万能上拉下拉刷新框架--XRefreshView(一) 打造Android万能上拉下拉刷新框架--XRefreshView(三) 一.前言 自从上次发表了打造android万能上拉下 ...
- 打造Android万能上拉下拉刷新框架--XRefreshView(三)
转载请注明出处:http://blog.csdn.net/footballclub/ 打造Android万能上拉下拉刷新框架–XRefreshView(一) 打造Android万能上拉下拉刷新框架–X ...
- ListView实现上拉下拉刷新加载功能
第一步.首先在你项目中创建一个包存放支持下拉刷新和上拉加载的类:
- iOS 上拉下拉刷新简单实现代码
一般说到上拉刷新下拉刷新,很多人可能想到的是一个第三方开源框架EGORefresh,下面说下,如何自己写代码实现. UITableView本身是一个UIScrollView,所以UITableView ...
- 【PullToRefresh 系列基本用法】 Android装上拉下拉刷新控制具体的解释
转载请注明:http://blog.csdn.net/duguang77/article/details/40921601 作者信息: Chris Banes大神详情:https://github.c ...
随机推荐
- C语言完美体系
**第 1 篇 C 语言第一阶段 13 1.1C 语言第一阶段--语言课程概述 13 1.1.1 什么是语言,什么是 C 语言 13 1.1.2 基本常识 14 1.1.3 人与计算机之间的更好的交互 ...
- Android碎裂的粒子效果
最近看到一段时间都没怎么更新文章了,一直在学习iOS相关内容.偶然间看到一个碎裂的粒子效果,觉得很有意思,就查了查,参考下网上的思路自己撸了个轮子. 好了,说了这么多,先看看效果吧~ 依惯例,先说下行 ...
- XCode使用技巧
XCode使用技巧 自动生成get.set方法 @property 用法 #import <Foundation/Foundation.h> @interface People : NSO ...
- 将meteor部署到自己的服务器(deploy meteor to your own server)
安装指定版本的node # 所有版本在:https://nodejs.org/download/release/# current dir:/rootwget -c https://nodejs.or ...
- Servlet规范总结
Servlet接口 Servlet规范的核心接口即是Servlet接口,它是所有Servlet类必须实现的接口,在Java Servelt API中已经提供了两个抽象类方便开发者实现Servlet类, ...
- 如何优雅地退出python程序
如何优雅地退出python程序 一个单模的python程序,启动之后要能够优雅地关闭.即当用户按Ctrl+C或者kill pid的时候,程序都能从容关闭.实现起来非常简单. is_running = ...
- sublime text的Ctrl+alt+up快捷键失效问题解决
上周一入职了新公司,安装了sublime text3 之后发现多行光标定位快捷键"Ctrl+alt+up|down"不能使用了.最后发现是快捷键冲突.我的电脑安装的是win7专业版 ...
- Java进阶(三十七)java 自动装箱与拆箱
Java进阶(三十七)java 自动装箱与拆箱 前言 这个是jdk1.5以后才引入的新的内容.java语言规范中说道:在许多情况下包装与解包装是由编译器自行完成的(在这种情况下包装称为装箱,解包装称为 ...
- 【unix网络编程第三版】阅读笔记(四):TCP客户/服务器实例
本篇博客主要记录一个完整的TCP客户/服务器实例的编写,以及从这个实例中引发的对僵死进程的处理等问题. 1. TCP客户/服务器功能需求 本实例完成以下功能: (1) 客户从标准输入读入一行文本,并写 ...
- (七十八)使用第三方框架INTULocationManager实现定位
前面(第七十五.七十六篇)讲述了如何通过CoreLocation获取位置,授权.获取等相当复杂,如果借助于第三方框架,可以简单的实现授权与定位. 首先在GitHub中搜索LocationManager ...
