Android案例(逐帧动画和属性动画)

1、实现效果
在这里插入图片描述

2、布局

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/bj">

    <ImageView
        android:id="@+id/iv_bird"
        android:layout_width="120dp"
        android:layout_height="120dp"
        android:layout_marginTop="20dp"
        android:background="@drawable/bird_animation" />

    <ImageView
        android:layout_marginBottom="100dp"
        android:layout_alignParentBottom="true"
        android:id="@+id/iv_butterfly"
        android:layout_width="120dp"
        android:layout_height="120dp"
        android:layout_marginTop="20dp"
        android:background="@drawable/butterfly_animation" />

</RelativeLayout>

butterfly_animation.xml

<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:drawable="@drawable/star_one" android:duration="100"/>
    <item android:drawable="@drawable/star_two" android:duration="100"/>
    <item android:drawable="@drawable/star_three" android:duration="100"/>
    <item android:drawable="@drawable/star_four" android:duration="100"/>
    <item android:drawable="@drawable/star_five" android:duration="100"/>
    <item android:drawable="@drawable/star_six" android:duration="100"/>
    <item android:drawable="@drawable/star_seven" android:duration="100"/>
    <item android:drawable="@drawable/star_eight" android:duration="100"/>
</animation-list>

bird_animation.xml

<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:drawable="@drawable/one" android:duration="100"/>
    <item android:drawable="@drawable/two" android:duration="100"/>
    <item android:drawable="@drawable/three" android:duration="100"/>
    <item android:drawable="@drawable/four" android:duration="100"/>
    <item android:drawable="@drawable/five" android:duration="100"/>
    <item android:drawable="@drawable/six" android:duration="100"/>
    <item android:drawable="@drawable/seven" android:duration="100"/>
    <item android:drawable="@drawable/eight" android:duration="100"/>
</animation-list>

3、java代码

package com.example.butterflyapplication;
import android.animation.AnimatorSet;
import android.animation.ObjectAnimator;
import android.graphics.drawable.AnimationDrawable;
import android.os.Bundle;
import android.util.DisplayMetrics;
import android.view.animation.Animation;
import android.view.animation.LinearInterpolator;
import android.widget.ImageView;
import androidx.appcompat.app.AppCompatActivity;

public class MainActivity extends AppCompatActivity {
    private int screenWidth;
    private ImageView iv_butterfly,iv_bird;
    private AnimationDrawable animation;
    private AnimatorSet flyAnimatorSet;
    private ObjectAnimator objectAnimator;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        init();
    }
    private void init(){
        getWindowWidth();
        iv_butterfly=findViewById(R.id.iv_butterfly);
        iv_bird=findViewById(R.id.iv_bird);
        flyAnimation(1); //实现蝴蝶飞舞的效果
        flyAnimation(2); //实现小鸟飞舞的效果
    }
    /**
     * 获取屏幕宽度
     */
    private void getWindowWidth(){
        DisplayMetrics dm=new DisplayMetrics();
        getWindowManager().getDefaultDisplay().getMetrics(dm);
        screenWidth= dm.widthPixels;
    }
    /**
     * 实现飞舞的效果
     */
    private void flyAnimation(int flag){
        flyAnimatorSet=new AnimatorSet();
        if (flag==1) {
            //获取逐帧动画
            animation= (AnimationDrawable) iv_butterfly.getBackground();
            //设置蝴蝶在水平方向移动的距离为屏幕的宽度-270
            objectAnimator = ObjectAnimator.ofFloat(iv_butterfly,
                    "translationX", screenWidth - 270);
            objectAnimator.setDuration(3*1000);//设置动画时间为3秒
        }else if (flag==2){
            //获取逐帧动画
            animation= (AnimationDrawable) iv_bird.getBackground();
            //设置小鸟在水平方向移动的距离为屏幕的宽度
            objectAnimator = ObjectAnimator.ofFloat(iv_bird,
                    "translationX", screenWidth);
            objectAnimator.setRepeatCount(Animation.RESTART); //重新开始播放动画
            objectAnimator.setRepeatCount(Animation.INFINITE);//循环播放动画
            objectAnimator.setDuration(10*1000);//设置动画时间为10秒
        }
        objectAnimator.setInterpolator(new LinearInterpolator());//设置线性插值器
        flyAnimatorSet.play(objectAnimator);
        animation.start();     //开启逐帧动画
        flyAnimatorSet.start();//开启属性动画
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值