首页 > 学院 > 开发设计 > 正文

SwipeView+ListView实现下拉刷新效果

2019-11-09 14:39:25
字体:
来源:转载
供稿:网友

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("古代美女"); }}
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表