android ListView上拉加载更多 下拉刷新功能实现(采用pull-to-refresh)

Android实现上拉加载更多功能以及下拉刷新功能,

采用了目前比较火的PullToRefresh,他是目前实现比较好的下拉刷新的类库。

目前他支持的控件有:ListView, ExpandableListView,GridView,WebView等。

下载地址:https://github.com/chrisbanes/Android-PullToRefresh

首先第一步当然是导入libriay到咱们的项目了,具体导入方式,这里不再赘述。

下面是个例子采用的是ListView,当然其余的和这个类似

1、布局文件activity_main.xml

01 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
02     xmlns:tools="http://schemas.android.com/tools"
03     android:layout_width="match_parent"
04     android:layout_height="match_parent"
05     tools:context=".MainActivity" >
06  
07       <com.handmark.pulltorefresh.library.PullToRefreshListView
08         android:id="@+id/pull_refresh_list"
09         android:layout_width="fill_parent"
10         android:layout_height="fill_parent" />
11 </RelativeLayout>

2、要实现下拉刷新的功能很简单,只需要实现OnRefreshListener的OnRefresh方法即可。这里说一下如何实现上拉和下拉分别执行不同的操作。

这里参考了http://blog.csdn.net/ueryueryuery/article/details/17440465

原理是:根据下拉和上拉显示的布局的可见状态类区分上拉还是下拉,然后执行相应操作。

在PullToRefresh的类库的com.handmark.pulltorefresh.library包下,打开PullToRefreshBase.java,在这个类的最后面添加如下代码:

1 public boolean isHeaderShown() {
2     return getHeaderLayout().isShown();
3 }
4  
5 public boolean isFooterShown() {
6     return getFooterLayout().isShown();
7 }

3、在Activity的代码如下:

01 public class MainActivity extends ListActivity {
02  
03     private PullToRefreshListView mPullToRefreshListView;
04      
05     private LinkedList<String> mItemList;
06     private ArrayAdapter<String> adapter;
07      
08     private Context context;
09     @Override
10     protected void onCreate(Bundle savedInstanceState) {
11         super.onCreate(savedInstanceState);
12         setContentView(R.layout.activity_main);
13         context = this;
14         initData();
15          
16         adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, mItemList);
17          
18         //初始化控件
19         mPullToRefreshListView = (PullToRefreshListView)findViewById(R.id.pull_refresh_list);
20         ListView mListView = mPullToRefreshListView.getRefreshableView();
21         mListView.setAdapter(adapter);
22          
23         //设置pull-to-refresh模式为Mode.Both
24         mPullToRefreshListView.setMode(Mode.BOTH);
25          
26         //设置上拉下拉事件
27         mPullToRefreshListView.setOnRefreshListener(new OnRefreshListener<ListView>() {
28  
29             @Override
30             public void onRefresh(PullToRefreshBase<ListView> refreshView) {
31                  
32                 if (refreshView.isHeaderShown()){
33                     Toast.makeText(context, "下拉刷新",Toast.LENGTH_SHORT).show();
34                     //下拉刷新 业务代码
35                 }else {
36                     Toast.makeText(context, "上拉加载更多",Toast.LENGTH_SHORT).show();
37                     //上拉加载更多 业务代码
38                 }
39                  
40             }
41         });
42          
43     }
44  
45  
46     private void initData(){
47         //初始化数据
48         mItemList = new LinkedList<String>();
49         mItemList.addAll(Arrays.asList(data));
50          
51     }
52      
53     private String[] data  = new String[]{"data1","data2","data3","data4","data5","data6",
54             "data1","data2","data3","data4","data5","data6"};
55 }

如上代码所示,在OnRefresh的实现代码中,用以区分上拉还是下拉,关键代码如下:

1 if (refreshView.isHeaderShown()){
2                     Toast.makeText(context, "下拉刷新",Toast.LENGTH_SHORT).show();
3                     //下拉刷新 业务代码
4                 }else {
5                     Toast.makeText(context, "上拉加载更多",Toast.LENGTH_SHORT).show();
6                     //上拉加载更多 业务代码
7                 }

至此,运行项目,可以得到演示结果了

原文地址 : http://www.dutycode.com/post-13.html

我的博客:http://www.dutycode.com

参考网址:http://blog.csdn.net/ueryueryuery/article/details/17440465

时间: 2024-12-11 18:08:22

android ListView上拉加载更多 下拉刷新功能实现(采用pull-to-refresh)的相关文章

robotium listview上拉加载更多/下拉刷新

ListView listview = (ListView) solo.getView("id/list"); int[] location = new int[2]; listview.getLocationOnScreen(location); location[1] = location[1] + listview.getBottom(); Log.i(TAG, "[Location x]: " + Integer.toString(location[0]))

结合SwipeRefreshLayout可以上拉加载更多下拉刷新的RecyclerView

源码下载地址:http://download.csdn.net/detail/zhou_anzhuojinjie/9661542 话不多说直接上代码 dependencies { compile fileTree(include: ['*.jar'], dir: 'libs') androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', { exclude group: 'com.android.supp

关于DropDownListView的上拉加载更多下拉刷新

试用了一下网上提供的DropDownListView  感觉很怪怪的   只要数据不够铺满全屏   listview的头布局不会隐藏掉,可以实现点击刷新,加载更多也是一样的    如果数据是加满全屏的   这样感觉使用起来非常舒服了,具体效果看demo demo下载地址    http://download.csdn.net/detail/u012303938/8717103 看代码   DropDownListView package com.example.update; import an

ListView上拉加载和下拉刷新多种实现方式

ListView上拉加载和下拉刷新多种实现方式 该篇为ListView下拉刷新和上拉加载实现的各种方法大合集.可能在具体的细节逻辑上处理不太到位,但基本上完成逻辑的实现.细节方面,个人可以根据自己的需求进行完善. 该博客将以四种思路来完成下拉刷新和上拉加载 自定义View实现上拉加载和下拉刷新 使用PullToRefresh 实现上拉加载和下拉刷新 使用Ultra-Pull-To-Refresh实现上拉加载和下拉刷新 使用SwipeToRefreshLayout实现上拉加载和下拉刷新 如果你对L

你必须了解的RecyclerView的五大开源项目-解决上拉加载、下拉刷新和添加Header、Footer等问题

前段时间做项目由于采用的MD设计,所以必须要使用RecyclerView全面代替ListView.但是开发中遇到了需要实现RecyclerView上拉加载.下拉刷新和添加Header以及Footer等需求问题,现将问题解决中用到的五大开源项目总结下来,方便他人. 首先介绍下RecyclerView,RecyclerView相比ListView增加了很多新特性: ? Adapter中的ViewHolder模式 - 对于ListView来说,通过创建ViewHolder来提升性能并不是必须的.因为L

读取网上gson数据,展示到gridview上,然后上拉加载,下拉刷新

NetWorkUtil.class package com.example.liangminghui20160425; import java.io.IOException; import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.client.ClientProtocolException; import org.apache.http.client.HttpC

18.小程序上拉加载和下拉刷新

在微信小程序上实现下拉刷新.上拉加载的效果 使用系统提供的onPullDownRefresh.onReachBottom这2个事件, 前提需要在app.json或page.json配置文件中设置,才能使用. app.json是全应用的页面都可以使用该事件,page.json则只是对应的页面才可以使用. 示例: app.json: 在app.json文件里设置window属性 page.json: 在page.json文件里直接设置属性 示例: 结合导航栏loading显示正在加载的效果 Page

微信小程序上拉加载和下拉刷新(wepy)

这篇随笔主要是记录在用wepy写小程序下拉刷新和上拉加载功能时遇到的数据显示不完全的问题及解决方法. 网上很多关于小程序的上拉加载和下拉刷新的文章的实现方法,无非两种,一是用scroll-view组件,另一种则是使用onReachBottom()和onPullDownRefresh()两个页面事件处理函数. scroll-view实现不好的是不能使用onPullDownRefresh,只能检测滚动到顶部触发刷新或者其它动画操作,以及在其内部使用textarea.map.canvas.video等

Vue-上拉加载与下拉刷新(mint-ui:loadmore)一个页面使用多个上拉加载后冲突问题

所遇问题: 该页面为双选项卡联动,四个部分都需要上拉加载和下拉刷新功能,使用的mint-ui的loadmore插件,分别加上上拉加载后,只有最后一个的this.$refs.loadmore.onTopLoaded();和this.$refs.loadmore.onBottomLoaded(); 有效,其他的三个都无效,这两句话是意思是查询完要调用一次,用于重新定位 分析原因: 首先这四个模块都是用的 <mt-loadmore :top-method="loadTop" :bott