ListView 滑动变黑

在  Android中,ListView是最常用的一个控件,在做UI设计的时候,很多人希望能够改变一下它的背景,使他能够符合整体的UI设计,改变背景背 很简单只需要准备一张图片然后指定属性 android:background="@drawable/bg",不过不要高兴地太早,当你这么做以后,发现背景是变了,但是当你拖动,或者点击 list空白位置的时候发现ListItem都变成黑色的了,破坏了整体效果。 
这是为什么呢? 
这个要从Listview的效果说起,默认的ListItem背景是透明的,而ListView的背景是固定不变的,所以在滚动条滚动的过程中如果实时地去将当前每个Item的显示内容跟背景进行混合运算,所以android 系统为了优化这个过程用,就使用了一个叫做android:cacheColorHint的属性,在黑色主题下默认的颜色值是#191919,所以就出现了刚才的画面,有一半是黑色的 
 
那怎么办呢? 
如果你只是换背景的颜色的话,可以直接指定android:cacheColorHint为你所要的颜色,如果你是用图片做背景的话,那也只要将android:cacheColorHint指定为透明(#00000000)就可以了,当然为了美化是要牺牲一些效率的
  • 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、付费专栏及课程。

余额充值