安卓给View添加动画效果【视图动画】

本文详细介绍如何在Android中使用XML动画文件实现view的旋转动画效果。从定义动画文件开始,到使用AnimationUtils加载动画,再到通过view的方法执行和清除动画,提供了一个完整的动画实现案例。

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

说明:
之前写过活动切换时的动画效果,这次我们来实现一下一般的view的动画效果。
1.首先,还是要定义动画文件
在这里插入图片描述
看一个例子play_music_rotate_anim文件:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration="@integer/play_music_duration">
    //持续时间
    <rotate android:fromDegrees="0"
        android:toDegrees="360"
        android:pivotX="50%" //旋转中心
        android:pivotY="50%"
        android:repeatCount="infinite" //无限循环
        />
</set>

温馨提示:旋转中心务必使用百分比,如果为0则不用!!!

2.使用AnimationUtils.loadAnimation方法加载动画文件
3.通过view.startAnimation方法执行动画效果,通过view.clearAnimation方法消除动画效果

代码:
1.加载动画文件

    private void init(Context context){
        mContext=context;
        mView= LayoutInflater.from(mContext).inflate(R.layout.activity_play_music_view, this,false);
        mPlayCircleBg=mView.findViewById(R.id.play_music_circle_bg);
        mPlayFlagImg=mView.findViewById(R.id.play_music_flag);
        mNeedle=mView.findViewById(R.id.play_music_needle);
        mWholeCircle=mView.findViewById(R.id.play_music_frame_layout_child_1);
        mWholeCircle.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                trigger();
            }
        });
        //加载动画文件
        mPlayingAnim= AnimationUtils.loadAnimation(mContext,R.anim.play_music_rotate_anim);
        mNeedleUpAnim=AnimationUtils.loadAnimation(mContext,R.anim.play_music_needle_up);
        mNeedleDownAnim=AnimationUtils.loadAnimation(mContext,R.anim.play_music_needle_down);
        addView(mView);
    }

2.设置动画效果

    public void startPlayMusic(){
        mIsPlaying=true;
        mPlayFlagImg.setVisibility(GONE);
        //设置音乐播放时的动画
        mWholeCircle.startAnimation(mPlayingAnim);
        mNeedle.startAnimation(mNeedleDownAnim);
    }

    public void stopPlayMusic(){
        mIsPlaying=false;
        mPlayFlagImg.setVisibility(VISIBLE);
        //设置音乐停止播放时的动画
        mNeedle.startAnimation(mNeedleUpAnim);
        mWholeCircle.clearAnimation();
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

tran_sient

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值