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 ...
随机推荐
- android M Launcher之LauncherModel (二)
上一篇我们通过LauncherModel的创建 ,实例化,以及与LauncherModel之间的沟通方式.初步了解了LauncherModel一些功能及用法,如果对LauncherModel一系列初始 ...
- JDK 源码学习——ByteBuffer
ByteBuffer 在NIO的作用 Java SE4 开始引入Java NIO,相比较于老的IO,更加依赖底层实现.引入通道(Channels),选择器(selector),缓冲(Buffers). ...
- How To Handle MLOG$_AP_SUPPLIER_SITES_AL, MLOG$_AP_SUPPLIERS Growing So Much? Having Lots of Data
How To Handle MLOG$_AP_SUPPLIER_SITES_AL, MLOG$_AP_SUPPLIERS Growing So Much? Having Lots of Data (文 ...
- Android图表库MPAndroidChart(十二)——来点不一样的,正负堆叠条形图
Android图表库MPAndroidChart(十二)--来点不一样的,正负堆叠条形图 接上篇,今天要说的,和上篇的类似,只是方向是有相反的两面,我们先看下效果 实际上这样就导致了我们的代码是比较类 ...
- Android TV开发总结(二)构建一个TV Metro界面(仿泰捷视频TV版)
前言:上篇是介绍构建TV app前要知道的一些事儿,开发Android TV和手机本质上没有太大的区别,屏大,焦点处理,按键处理,是有别于有手机和Pad的实质区别.今天来介绍TV中Metro UI风格 ...
- linux简单命常用令
Linux常用命令总结 切换:cd tmp cd/tmp/yun cd 切换到host目录 cd .. 显示:ll Top显示系统情况 Netstat显示网络情况 Ifconfig显示网络配置 Mor ...
- GDAL库三个读取Jpeg2000格式驱动测试
0.目的 GDAL库中提供了四五种读取Jpeg2000的驱动,但是各个驱动读取数据的效率各不相同,下面就针对三种读取jpeg2000的效率进行测试. GDAL库中提供的读取Jpeg2000的驱动有下面 ...
- Socket层实现系列 — send()类发送函数的实现
主要内容:socket发送函数的系统调用.Socket层实现. 内核版本:3.15.2 我的博客:http://blog.csdn.net/zhangskd 发送流程图 以下是send().sendt ...
- 03安卓TextView
一 TextView 父类 : View >概念:文本控件 :文本内容的显示 默认配置不可编辑 子类EditText可以编辑 *********************** ...
- UNIX环境高级编程——线程属性
pthread_attr_t 的缺省属性值 属性 值 结果 scope PTHREAD_SCOPE_PROCESS 新线程与进程中的其他线程发生竞争. detachstate PTHREAD_CREA ...
