Android中View的点击事件

一、View的clickable属性

使用ConstraintLayout写布局可以减少嵌套,对于有些背景或者点击区域的问题,可以使用View加载背景或者增大点击区域。对于点击事件可以加到View上,并且可以将在View区域内的其它可以点击的View添加上属性android:clickable=“false”。需要注意的是不要在View上添加以下的三个属性:

            android:clickable="true"
            android:focusableInTouchMode="true"
            android:focusable="true"

如果添加了这几个属性,点击View时 会出现点击两次才能响应事件。View的点击背景变化效果,可以使用以下的selector.

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
      <item android:state_pressed="true" android:drawable="@color/green_00612E" />
      <item  android:drawable="@color/green_47AF4D"/>
</selector>

RecyclerView的item布局是一个ConstraintLayout,给这个ConstraintLayout添加一个点击效果,也不要在ConstraintLayout中添加上述的三个属性,否则也会出现点击两次才会响应的现象。

二、View的background属性

View手指点上后变色,手指松开后恢复原来的颜色,只需要android:state_pressed="true"和android:state_pressed="false"两个item就行。使用默认的item,即没有android:state_pressed=“false”,则只有点击时的效果,松开后默认的item不起作用。

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item  android:state_pressed="true">
        <shape android:shape="rectangle">
            <corners android:radius="@dimen/dp4"/>
            <solid android:color="@color/white_AC"/>
            <stroke android:color="@color/white_EA" android:width="@dimen/dp1"/>
        </shape>
    </item>

    <item  android:state_pressed="false">
        <shape android:shape="rectangle">
            <corners android:radius="@dimen/dp4"/>
            <solid android:color="@color/white"/>
            <stroke android:color="@color/white_EA" android:width="@dimen/dp1"/>
        </shape>
    </item>
</selector>

使用:

        <View
            android:id="@+id/viewBg"
            android:layout_width="0dp"
            android:layout_height="@dimen/dp143"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            android:background="@drawable/bg_sel_corner_white"
            android:layout_marginLeft="@dimen/dp12"
            android:layout_marginRight="@dimen/dp11"
            android:layout_marginTop="@dimen/dp12"
            android:paddingBottom="@dimen/dp27"
            />
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android动画会改变View的位置和大小,如果不正确处理,会导致View点击事件位置也改变。 解决方法: 1. 使用属性动画(ObjectAnimator)替代补间动画(TranslateAnimation、ScaleAnimation等),属性动画不会改变View的位置和大小。 2. 在补间动画结束后,重新设置View的位置和大小。 3. 在View的onTouchEvent方法,使用getRawX和getRawY获取触摸点的坐标,而不是getX和getY获取相对于View的坐标。这样可以避免动画导致的位置变化。 示例代码: 使用属性动画: ```java ObjectAnimator animator = ObjectAnimator.ofFloat(view, "translationX", 0, 100); animator.setDuration(1000); animator.start(); ``` 在补间动画结束后重新设置View的位置和大小: ```java TranslateAnimation animation = new TranslateAnimation(0, 100, 0, 0); animation.setDuration(1000); animation.setAnimationListener(new Animation.AnimationListener() { @Override public void onAnimationStart(Animation animation) { } @Override public void onAnimationEnd(Animation animation) { view.setTranslationX(100); } @Override public void onAnimationRepeat(Animation animation) { } }); view.startAnimation(animation); ``` 在View的onTouchEvent方法使用getRawX和getRawY获取触摸点的坐标: ```java @Override public boolean onTouchEvent(MotionEvent event) { int action = event.getAction(); if (action == MotionEvent.ACTION_DOWN) { float x = event.getRawX(); float y = event.getRawY(); // 处理点击事件 return true; } return super.onTouchEvent(event); } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值