关于listView滑动间距问题

大家有没有遇到过下面的效果

这里写图片描述

这里写图片描述

一般都是通过listVew加footer或者ScrollView包裹来实现,不过还有一种特别简单的方式那就是listView有一个自带的属性android:clipToPadding = true 配合paddingBottom,默认情况android:clipToPadding 为true,所以当我们只加paddingBottom的时候listview整体就会上移,底部会留一个空白,并不能实现滑动到底部再向上滑动一段距离。

1.clipChild用来定义他的子控件是否要在他应有的边界内进行绘制。 默认情况下,clipChild被设置为true。

也就是不同意进行扩展绘制。

  1. clipToPadding用来定义ViewGroup是否同意在padding中绘制。

默认情况下。cliptopadding被设置为ture, 也就是把padding中的值都进行裁切了。

所以我们只需将cliptopadding的值设置为false再加上padding就可以实现了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现ListView滑动删除的功能,可以采用以下步骤: 1. 首先创建一个ListView,并给ListView设置一个适配器; 2. 在适配器的getView()方法中,为每一个item添加一个滑动删除的功能; 3. 在item中添加一个布局,该布局包含两个子控件:一个是要显示的内容,另一个是删除按钮; 4. 给删除按钮添加点击事件,当点击删除按钮时,将该item从ListView中移除; 5. 在ListView的OnTouchListener中,监听手势滑动事件,并实现滑动删除的效果。 下面是一个简单的实现代码: ``` public class MyAdapter extends BaseAdapter implements View.OnTouchListener { private Context mContext; private List<String> mData; private int mLastPosition; private int mDownX, mDownY; private boolean isSlide = false; public MyAdapter(Context context, List<String> data) { mContext = context; mData = data; } @Override public int getCount() { return mData.size(); } @Override public Object getItem(int position) { return mData.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(final int position, View convertView, ViewGroup parent) { ViewHolder viewHolder; if (convertView == null) { convertView = LayoutInflater.from(mContext).inflate(R.layout.item_layout, null); viewHolder = new ViewHolder(); viewHolder.contentTv = convertView.findViewById(R.id.content_tv); viewHolder.deleteBtn = convertView.findViewById(R.id.delete_btn); convertView.setTag(viewHolder); } else { viewHolder = (ViewHolder) convertView.getTag(); } viewHolder.contentTv.setText(mData.get(position)); viewHolder.deleteBtn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { mData.remove(position); notifyDataSetInvalidated(); } }); convertView.setOnTouchListener(this); convertView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 点击事件 } }); return convertView; } static class ViewHolder { TextView contentTv; Button deleteBtn; } @Override public boolean onTouch(View v, MotionEvent event) { int action = event.getAction(); switch (action) { case MotionEvent.ACTION_DOWN: mDownX = (int) event.getX(); mDownY = (int) event.getY(); mLastPosition = v.getId(); isSlide = false; break; case MotionEvent.ACTION_MOVE: int moveX = (int) event.getX(); int moveY = (int) event.getY(); int deltaX = moveX - mDownX; int deltaY = moveY - mDownY; if (Math.abs(deltaX) > Math.abs(deltaY)) { isSlide = true; // 滑动事件 } break; case MotionEvent.ACTION_UP: if (!isSlide) { // 点击事件 } break; } return true; } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值