监听ListView列表项点击和滚动事件

本文介绍了如何在Android中使用OnItemClickListener监听ListView的点击事件,以及通过OnScrollListener实现手指下拉时动态增加数据源的功能,包括相关代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里写图片描述

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) {

    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值