前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >5-VI--ListView事件全解析

5-VI--ListView事件全解析

作者头像
张风捷特烈
发布2018-09-26 16:22:00
7700
发布2018-09-26 16:22:00
举报
零、前言

[0.]本案例使用这篇的项目(你也可以用其他的):4-VI--☆ListView的封装支持多种条目 [1].条目点击事件 [2].条目长按事件 [3].滑动事件 [4].条目抢占交点问题

一、条目点击事件:setOnItemClickListener

几个参数----根据图片参照对应: parent:背景变成淡绿色 view:背景变成随机颜色 position:弹出来 下面未点击的变色了,可见条目已正常复用

listview点击.gif

设置点击监听
代码语言:javascript
复制
 mLv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            /**
             *
             * @param parent ListView
             * @param view 条目
             * @param position 位置
             * @param id id 测试Id和 position一样
             */
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                Log.e(TAG, "onItemClick() called with:\n "
                        + "parent = [" + parent + "], \n" +
                        "view = [" + view + "],\n " +
                        "position = [" + position + "],\n" +
                        " id = [" + id + "]");
                parent.setBackgroundColor(0x5500ff00);
                view.setBackgroundColor(ColUtils.randomColor());
                ToastUtil.showAtOnce(ChatActivity.this, "当前位置:" + position);
            }
        });

一、条目长按事件:setOnItemLongClickListener

几个参数和点击一样 值得注意的一点是返回值: true: 手指抬起时不触发条目的点击事件 false: 手指抬起时触发条目的点击事件

设置长按监听
代码语言:javascript
复制
mLv.setOnItemLongClickListener(new AdapterView.OnItemLongClickListener() {
    @Override
    public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) {
        ToastUtil.showAtOnce(ChatActivity.this, "长按--当前位置:" + position);
        return true;
    }
});
三、滑动事件:setOnScrollListener

有两个回调方法: onScrollStateChanged(AbsListView view, int scrollState) onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount)

1.onScrollStateChanged方法:view对象滑动时蓝色,滑动停止淡绿色

listview滑动.gif

代码语言:javascript
复制
 mLv.setOnScrollListener(new AbsListView.OnScrollListener() {
            /**
             *
             * @param view ListView
             * @param scrollState 上滑 1 滑动结束 0
             */
            @Override
            public void onScrollStateChanged(AbsListView view, int scrollState) {
                view.setBackgroundColor(scrollState == 0 ? 0x5500ff00 : 0x550000ff);
            }
            
            @Override
            public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
            }
        });
2.onScroll:android.widget.AbsListView.OnScrollListener#onScroll
代码语言:javascript
复制
/**
 *
 * @param view view ListView
 * @param firstVisibleItem 最顶端条目的id
 * @param visibleItemCount 可见的条目数
 * @param totalItemCount 总条目数
 */
@Override
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
    mIsLastItem = visibleItemCount + firstVisibleItem == totalItemCount;
    mIsTopItem = firstVisibleItem == 0;
}
3.基于此实现监听滑到顶端和底端

滑动到上下端监听.gif

代码语言:javascript
复制
    /**
     * 是否滑到最底端
     */
    private boolean mIsLastItem;

    /**
     * 是否滑到最顶端
     */
    private boolean mIsTopItem;
代码语言:javascript
复制
        mLv.setOnScrollListener(new AbsListView.OnScrollListener() {

            @Override
            public void onScrollStateChanged(AbsListView view, int scrollState) {
                view.setBackgroundColor(scrollState == 0 ? 0x5500ff00 : 0x550000ff);
                if (scrollState == 0) {
                    if (mIsLastItem) {
                        ToastUtil.show(ChatActivity.this, "滑到最底端");
                    }
                    if (mIsTopItem) {
                        ToastUtil.show(ChatActivity.this, "滑到最顶端");
                    }
                }
            }

            @Override
            public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {

                mIsLastItem = visibleItemCount + firstVisibleItem == totalItemCount;
                mIsTopItem = firstVisibleItem == 0;
            }
        });
四、条目抢占交点问题

只在一类布局上加上CheckBox,看图对比

交点抢占.gif

1.设置适配器的setData方法里可以获取条目内的布局:case 0:
代码语言:javascript
复制
CheckBox checkBox = (CheckBox) holder.getView(R.id.id_cb_left);
checkBox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
    @Override
    public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
        ToastUtil.showAtOnce(ChatActivity.this,
                "状态改变为:"+(isChecked?"已选择":"未选中"));
    }
});
2.解决:让checkbox默认不抢焦点
代码语言:javascript
复制
checkBox.setFocusable(false);

抢占交点解决.gif

本文由张风捷特烈原创,转载请注明 更多安卓技术欢迎访问:https://www.jianshu.com/c/004f3fe34c94 张风捷特烈个人网站,编程笔记请访问:http://www.toly1994.com 你的喜欢与支持将是我最大的动力

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.08.28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 零、前言
  • 一、条目点击事件:setOnItemClickListener
    • 设置点击监听
    • 一、条目长按事件:setOnItemLongClickListener
      • 设置长按监听
      • 三、滑动事件:setOnScrollListener
        • 1.onScrollStateChanged方法:view对象滑动时蓝色,滑动停止淡绿色
          • 2.onScroll:android.widget.AbsListView.OnScrollListener#onScroll
            • 3.基于此实现监听滑到顶端和底端
            • 四、条目抢占交点问题
              • 1.设置适配器的setData方法里可以获取条目内的布局:case 0:
                • 2.解决:让checkbox默认不抢焦点
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档