刚刚开通简书,趁热打铁来一篇博客
在Android中,下拉刷新非常常见,谷歌官方也提供了控件方便我们做刷新,就是SwipeRefreshLayout。现在我就来做一个ListView的下拉刷新
- 这是主布局
<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/swp"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ListView
android:id="@+id/lv"
android:layout_width="match_parent"
android:layout_height="match_parent">
</ListView>
</android.support.v4.widget.SwipeRefreshLayout>
ListView的条目布局非常地简单,就是一个TextView。
- 这是MainActivity的代码,非常简单
public class MainActivity extends AppCompatActivity implements SwipeRefreshLayout.OnRefreshListener {
private ListView lv;
private SwipeRefreshLayout swp;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
lv = (ListView) findViewById(R.id.lv);
lv.setAdapter(new MyAdapter());
swp = (SwipeRefreshLayout) findViewById(R.id.swp);
swp.setColorSchemeResources(android.R.color.holo_blue_bright,
android.R.color.holo_green_light,
android.R.color.holo_orange_light,
android.R.color.holo_red_light);//设置圆圈旋转的颜色(随机)
// swp.setDistanceToTriggerSync(400);// 设置手指在屏幕下拉多少距离会触发下拉刷新
// swp.setProgressBackgroundColor(R.color.red); // 设定下拉圆圈的背景
// swp.setSize(SwipeRefreshLayout.LARGE); // 设置圆圈的大小
swp.setOnRefreshListener(this);//设置刷新监听
}
@Override
public void onRefresh() {
Log.d("alan", "刷新");
new Handler().postDelayed(new Runnable() {
@Override
public void run() {
// 停止刷新
swp.setRefreshing(false);
}
},3000); // 5秒后发送消息,停止刷新
}
class MyAdapter extends BaseAdapter {
@Override
public int getCount() {
return 20;
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = View.inflate(getApplicationContext(), R.layout.item, null);
return view;
}
}
}
结果图如下
以上就是SwipeRefreshLayout的基本使用