android5.x StateListAnimator状态动画

本文介绍如何使用StateListAnimator通过XML和代码两种方式为控件设置不同的动画效果。XML配置需放置于drawable或animator文件夹内,并可通过@animator或@drawable引用。代码实现则直接调用AnimatorInflater加载资源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

StateListAnimator有xml实现和代码实现

1.xml实现(xml文件可以放在drawable目录(不能自动提示),也可以放在animator目录中(建议))

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true">
        <set>
            <objectAnimator android:duration="500" android:propertyName="rotationX" android:valueTo="360" android:valueType="floatType" />
        </set>
    </item>

    <item android:state_pressed="false">
        <set>
            <objectAnimator android:duration="500" android:propertyName="rotationX" android:valueTo="0" android:valueType="floatType" />
        </set>
    </item>
</selector>

指定控件使用该属性
android:stateListAnimator="@animator/statelistanimator"
或
android:stateListAnimator="@drawable/statelistanimator"

<!--或者 android:stateListAnimator="@drawable/statelistanimator"-->

代码实现

Button button = (Button) findViewById(R.id.btn);

StateListAnimator animator = AnimatorInflater.loadStateListAnimator(this, R.animator.statelistanimator);
//StateListAnimator animator = AnimatorInflater.loadStateListAnimator(this, R.drawable.state);

button.setStateListAnimator(animator);
参考转自: 点击打开链接
### 实现 Android 按钮点击时的放大效果 为了实现在 Android 中当按钮被点击时产生放大的动画效果,可以通过定义 XML 动画资源并将其应用到 Button 上来完成这一目标[^1]。 #### 定义动画资源文件 创建一个新的 XML 文件位于 `res/anim` 目录下命名为 `scale_up.xml`: ```xml <?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <!-- 设置属性 --> <scale android:fromXScale="1" android:toXScale="1.2" android:fromYScale="1" android:toYScale="1.2" android:pivotX="50%" android:pivotY="50%" android:duration="200"/> </set> ``` 此代码片段设置了 X 和 Y 方向上的初始尺度为 1(即原始大小),最终变为 1.2 倍大;中心点设为中心位置 (`pivotX`, `pivotY`) 并指定了持续时间为 200ms 的过渡时间。 #### 应用动画至按钮 接着,在 Activity 或 Fragment 中加载上述动画并将它绑定给特定的 View 对象: ```java import androidx.appcompat.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.view.animation.Animation; import android.view.animation.AnimationUtils; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); final View button = findViewById(R.id.my_button); // 替换成实际 ID button.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { Animation scaleUpAnim = AnimationUtils.loadAnimation(MainActivity.this, R.anim.scale_up); v.startAnimation(scaleUpAnim); } }); } } ``` 这里通过 `setOnClickListener()` 方法监听用户的点击事件,并调用了 `startAnimation()` 来启动之前定义好的缩放动画。 对于更复杂的交互体验,还可以考虑采用 StateListAnimator 或者使用 Selector 结合 Drawable 资源的方式来自定义不同状态下控件的表现形式[^3]。另外一种方式则是利用 ObjectAnimator 类来进行更加精细控制的属性动画操作[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值