Android动画全篇系列(六)——状态动画

一、状态动画介绍

我们可以将动画和selector结合,就可以实现在View的不同状态下,播放相应的动画。

二、实现

我们以是否按压View作为例子。当按压的时候,View逐渐变成透明,非按压的时候,View逐渐不透明。

  1. 先在drawable文件夹中创建一个根标签为 <selector> 的标签:
    图片
  2. 然后分别创建两个 <item>,一个是按压的状态,一个是非按压的状态:
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true">
       
    </item>

    <item android:state_pressed="false">
       
    </item>
</selector>
  1. 在两个 <item> 标签里面定义动画。完整代码如下:
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true">
        <objectAnimator
            android:propertyName="alpha"
            android:valueType="floatType"
            android:valueTo="0"
            android:duration="1000"/>
    </item>

    <item android:state_pressed="false">
        <objectAnimator
            android:propertyName="alpha"
            android:valueType="floatType"
            android:valueTo="1"
            android:duration="1000"/>
    </item>
</selector>

注意:此处的objectAnimator中,建议只使用一个值。如果使用两个值,假设现在按压进行透明度1=>0的过程,在动画并没有播放完的情况下,你松手了,那么就会直接进行0=>1的动画过程。在视觉上产生不连贯的感觉。

而你只使用一个值的时候,那么无论你什么时候切换动画,startValue都会实时通过getter方法来获取最新的值。

  1. 给布局中的View添加stateListAnimator属性:
android:stateListAnimator="@drawable/selector_anim_press"

或者通过代码来实现:

animatorView.stateListAnimator = 
AnimatorInflater.loadStateListAnimator(context,R.drawable.selector_anim_press)

本Demo中是以state_pressed作为例子,所以如果View默认clickable = false,注意改成 true。

效果如下所示:
效果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值