swipeRefreshLayout

SwipeRefreshLayout

2016-04-18  本文已影响320人  一洼世界

代码搬运工.

http://blog.csdn.net/zhangphil/article/details/46965377 原作

Paste_Image.png

以一个SwipeRefreshLayout包裹ListView,SwipeRefreshLayout接管ListView的下拉事件,若ListView被用户触发下拉动作后,SwipeRefreshLayout启动下拉刷新的UI表现样式,下拉刷新完毕,在SwipeRefreshLayout提供的接口中回调更新ListView中的数据。

<android.support.v4.widget.SwipeRefreshLayout  
    android:id="@+id/swipeRefreshLayout"  
    android:layout_width="match_parent"  
    android:layout_height="match_parent" >  
    <ListView  
        android:id="@+id/listView"  
        android:layout_width="match_parent"  
        android:layout_height="match_parent" >  
    </ListView>  
</android.support.v4.widget.SwipeRefreshLayout>  



 初始化
 swipeRefreshLayout = (SwipeRefreshLayout) findViewById(R.id.swipeRefreshLayout);  
 ListView listView = (ListView) findViewById(R.id.listView);  
  // 设置刷新动画的颜色,可以设置1或者更多.  
  // 我们暂时使用三个Android系统自带的颜色。  
    swipeRefreshLayout.setColorSchemeResources(  
            android.R.color.holo_blue_bright,  
            android.R.color.holo_orange_light,  
            android.R.color.holo_green_light);  

  swipeRefreshLayout.setOnRefreshListener(new OnRefreshListener() {  
        // SwipeRefreshLayout接管其包裹的ListView下拉事件。  
        // 每一次对ListView的下拉动作,将触发SwipeRefreshLayout的onRefresh()。  
        @Override  
        public void onRefresh() {  
          //业务逻辑
               longTimeOperation();  
        }  
    });  

 // 每一次下拉刷新将触发更新操作动作。  
// 这里将是比较耗时的操作:如网络请求的数据,加载一个大图片。  
// 简单期间,我们假设就是简单的将count数据加1,然后更新显示。  
//  
// 备注:swipeRefreshLayout.setRefreshing(true) 到  
// swipeRefreshLayout.setRefreshing(false)之间的这段代码 ,  
// 在实际的应用开发中一般就是线程化的、耗时的或者后台的操作代码。  
private void longTimeOperation() {  
    // true,刷新开始,所以启动刷新的UI样式.  
    swipeRefreshLayout.setRefreshing(true);  

    // 开始启动刷新...  
    // 在这儿放耗时操作的 AsyncTask线程、后台Service等代码。  

    // add(0,xxx)每次将更新的数据xxx添加到头部。  
    data.add(0, "" + count++);  
    adapter.notifyDataSetChanged();  

    // 刷新完毕.  

    // false,刷新完成,因此停止UI的刷新表现样式。  
    swipeRefreshLayout.setRefreshing(false);  
}  

}

上一篇 下一篇

猜你喜欢

热点阅读