上图是SimpleAdapter的适配器
上图是ArrayAdapter的适配器
上图是OnItemClickListener点击效果
上图我滑动了一下屏幕,滑动监听器(OnScrollListener)中onScrollChanged()方法打印的日志。
上图是在onScrollChanged()方法添加的向下滑动更新数据源的功能。必须加上simple_Adapter.notifyDataSetChanged()方法,通知UI线程更新数据源。
以下是代码及注释:
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.lenovo.listview.MainActivity">
<ListView
android:id="@+id/listview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
</LinearLayout>
simpleadapter.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal"
>
<ImageView
android:layout_marginLeft="15dp"
android:id="@+id/pic"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@mipmap/ic_launcher"
/>
<TextView
android:id="@+id/text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="20sp"
android:textColor="#000000"
android:text="慕课网"
/>
</LinearLayout>
MainActivity.java
package com.example.lenovo.listview;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.AbsListView;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.Toast;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class MainActivity extends Activity implements AdapterView.OnItemClickListener,AbsListView.OnScrollListener{
private ListView lv;
private ArrayAdapter<String> arr_adapter;
private SimpleAdapter simple_Adapter;
private List<Map<String,Object>> dataList;//SimpleAdapter中的数据源
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
lv=(ListView) findViewById(R.id.listview);
//1数据源
String data[]={"慕课网1","慕课网2","慕课网3","慕课网4"};
//1.新建支配器
//ArrayAdapter(上下文,当前ListView所加载的每一个列表项所对应的布局文件,数据源)
//2.适配器加载数据源
arr_adapter=new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,data);
//3.视图(ListView)加载适配器
//lv.setAdapter(arr_adapter);//加载ArrayAdapter适配器
/*
SimpleAdapter()中的参数
1.context:上下文
2.data:数据源(List<? extends Map<String.?>>)一个Map所组成的List集合
每一个Map都会去对应列表中的一行
每一个Map(键值对)中的键必须包含所有在from中指定的键
3.resource:列表项的布局文件ID
4.from:Map中的键名
5.to:绑定数据视图中的ID,与from成对应关系
*/
dataList=new ArrayList<Map<String,Object>>();
simple_Adapter=new SimpleAdapter(this,getData(),R.layout.simpleadapter,new String[]{"pic","text"},new int[]{R.id.pic,R.id.text});
lv.setAdapter(simple_Adapter);//加载SimpleAdapter适配器
lv.setOnItemClickListener(this);//设置单个条目点击的监听事件
lv.setOnScrollListener(this);//设置滑动变化监听的事件
}
//返回数据源dataList
private List<Map<String,Object>> getData(){
for(int i=0;i<20;i++){
Map<String,Object>map=new HashMap<String,Object>();
map.put("pic",R.mipmap.ic_launcher);
map.put("text","demo"+i);
dataList.add(map);
}
return dataList;
}
@Override
public void onScrollStateChanged(AbsListView absListView, int i) {
switch (i)
{
case SCROLL_STATE_FLING:
Log.i("Main","用户在手指离开屏幕前,由于用力划了一下,视图仍以惯性向下滑动");
Map<String,Object>map =new HashMap<String,Object>();
map.put("pic",R.mipmap.ic_launcher);
map.put("text","增加项");
dataList.add(map);
simple_Adapter.notifyDataSetChanged();//必须加上simple_Adapter.notifyDataSetChanged()方法,通知UI线程更新数据源。
break;
case SCROLL_STATE_IDLE:
Log.i("Main","视图已经停止滑动");
break;
case SCROLL_STATE_TOUCH_SCROLL:
Log.i("Main","手指没有离开屏幕,仍然在滑动");
break;
}
}
@Override
public void onScroll(AbsListView absListView, int i, int i1, int i2) {
}
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
//i这个参数是ListView中元素的第几个(从0开始)
String text=lv.getItemAtPosition(i)+"";
Toast.makeText(this,"postion="+i+"text="+text,Toast.LENGTH_SHORT).show();
}
}