SwipeView+ListView实现下拉刷新效果

1.编写布局文件
SwipeView是V4包里的,可系统直接导包使用。
activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools" android:id="@+id/swipeView"
android:layout_width="match_parent" android:layout_height="match_parent"
 tools:context="com.soft.qianyu.swipeviewdemo.MainActivity">
    <ListView
        android:id="@+id/lv"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    </ListView>
</android.support.v4.widget.SwipeRefreshLayout>

2,编写ListView的item布局文件
这里只是简单的使用listview,所以使用的是ArrayAdapter,不需要单独写item布局文件,使用的是系统的android.R.layout.simple_list_item_1布局文件。

3,在Activity中编写获得控件相应的控件并进行操作
MainActivity.java

public class MainActivity extends AppCompatActivity {
    //1.声明各个变量
    //声明Listview、数组适配器ArrayAdapter、数据源ArrayList
    ListView lv;
    ArrayAdapter<String> adapter;
    ArrayList<String> datas;
    //声明下拉刷新的标记,根据这个来判断加载哪一组数据。
    boolean flag = true;
    //声明刷新控件swipview
    SwipeRefreshLayout swipeView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        init();
    }
    //2.初始化各个控件
    private void init() {
//初始化listview、数据源、获取初始数据
lv = (ListView) findViewById(R.id.lv);
datas = new ArrayList<String>();
getData();
//初始化适配器:
/*第一个参数是当前上下文
*第二个参数是系统默认的listviewItem布局
*第三个参数是数据源
*/
adapter = new ArrayAdapter<String>(MainActivity.this,android.R.layout.simple_list_item_1,datas);
//为Listview设置适配器
lv.setAdapter(adapter);

//3.以下代码是对SwipeView的操作

swipeView = (SwipeRefreshLayout) findViewById(R.id.swipeView);
 //修改进度条的背景颜色
swipeView.setProgressBackgroundColorSchemeColor(Color.GRAY);     
 //修改进度条的颜色(若数据很多,可以转一圈换一个颜色)
 swipeView.setColorSchemeColors(Color.YELLOW,Color.GREEN);
 //为swipeView设置下拉监听(只有设置监听了才能修改数据)
swipeView.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
     @Override
    public void onRefresh() {
    //刷新listview之前先清空数据源
        datas.clear();
    //根据flag的值来确定加载哪一组数据
        if (flag){
             refresh();
         }else {
             getData();
         }
         //修改数据后要通知控件的适配器数据改变了!
         adapter.notifyDataSetChanged();
         //重新设置flag的值,要不然达不到刷新效果
         flag =!flag;
         //刷新结束,关闭刷新效果
         swipeView.setRefreshing(false);
            }
        });

    }

    private void getData() {
        datas.add("赵云");
        datas.add("关羽");
        datas.add("曹操");
        datas.add("吕布");
        datas.add("貂蝉");
        datas.add("西施");
        datas.add("李师师");
    }
    private void refresh() {
        datas.add("常胜将军");
        datas.add("汉寿亭候");
        datas.add("奸雄");
        datas.add("三国无双");
        datas.add("三国美女");
        datas.add("国代美女");
        datas.add("古代美女");
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值