OnItemClickListener:
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
String text=mListView.getItemAtPosition(position)+"";
Toast.makeText(this, "位置:"+position+"内容:"+text, Toast.LENGTH_LONG).show();
}
position是指当前点击到地方的位置,比如说当点击第一个ListView时,弹出的position将会是0,点击第二个ListView时,弹出的position将会是1.
效果图:
OnScrollListener:
手指下拉动态添加数据源:
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
switch (scrollState){
case SCROLL_STATE_FLING:
Log.d("Main","用户在手指离开屏幕之前,由于用力划了一下,视图仍依靠惯性继续滑动");
Map<String,Object>map=new HashMap<>();
map.put("pic",R.mipmap.ic_launcher);
map.put("text","增加项");
data.add(map);
//必须要进行UI线程刷新,否则不会显示出增加项
simpleAdapter.notifyDataSetChanged();
break;
case SCROLL_STATE_IDLE:
Log.d("Main","视图已经停止滑动");
break;
case SCROLL_STATE_TOUCH_SCROLL:
Log.d("Main","手指没有离开屏幕,视图正在滑动");
break;
}
打印日志:
手指下拉动态的增加数据源
下图红笔圈出来的地方就是动态增加数据源的代码:
完整代码
public class MainActivity extends AppCompatActivity implements AdapterView.OnItemClickListener,AbsListView.OnScrollListener {
private ListView mListView;
private ArrayAdapter arrayAdapter;
private SimpleAdapter simpleAdapter;
private List<Map<String, Object>> data;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mListView = (ListView) findViewById(R.id.listview);
mListView.setOnItemClickListener(this);
mListView.setOnScrollListener(this);
//SimpleAdapter(context,data,resource,from,to)
/**
*context:上下文
* data:数据源(List<? extends Map<String,?>>data)一个Map所组成的List集合
* 每一个Map都会去对应ListView列表中的一行
* 每一个Map(键值-对)中的键必须包含所有在from中指定的键
* resource:列表项的布局id
* from:Map中的键名
* to:绑定数据视图中的ID,与from成对应关系
*/
data = new ArrayList<>();
simpleAdapter = new SimpleAdapter(this, getData(), R.layout.item, new String[]{"pic", "text"}, new int[]{R.id.imageview, R.id.textview_pic});
mListView.setAdapter(simpleAdapter);
}
private List<Map<String, Object>> getData() {
for (int i = 0; i < 20; i++) {
Map<String, Object> map = new HashMap<>();
map.put("pic", R.mipmap.xiao);
map.put("text", "身份" + i);
data.add(map);
}
return data;
}
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
String text=mListView.getItemAtPosition(position)+"";
Toast.makeText(this, "位置:"+position+"内容:"+text, Toast.LENGTH_LONG).show();
}
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
switch (scrollState){
case SCROLL_STATE_FLING:
Log.d("Main","用户在手指离开屏幕之前,由于用力划了一下,视图仍依靠惯性继续滑动");
Map<String,Object>map=new HashMap<>();
map.put("pic",R.mipmap.ic_launcher);
map.put("text","增加项");
data.add(map);
//必须要进行UI线程刷新,否则不会显示出增加项
simpleAdapter.notifyDataSetChanged();
break;
case SCROLL_STATE_IDLE:
Log.d("Main","视图已经停止滑动");
break;
case SCROLL_STATE_TOUCH_SCROLL:
Log.d("Main","手指没有离开屏幕,视图正在滑动");
break;
}
}
@Override
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
}
}