自定义View——点击飘动红心

1.效果展示

在这里插入图片描述

2.实现

1)思路

通过自定义View 加动画 实现

动画:属性动画(位移+缩放+透明度+旋转)
+
随机数:(属性动画参数+颜色选取)

2)代码

package com.example.myviewtest;

import android.animation.Animator;
import android.animation.AnimatorListenerAdapter;
import android.animation.AnimatorSet;
import android.animation.ObjectAnimator;
import android.content.Context;
import android.content.res.ColorStateList;
import android.media.Image;
import android.util.AttributeSet;
import android.view.ViewGroup;
import android.view.animation.AccelerateInterpolator;
import android.view.animation.CycleInterpolator;
import android.widget.ImageView;
import android.widget.RelativeLayout;

public class MyView extends RelativeLayout {
    private int defoutWidth = 200;//默认控件宽度
    private long mDuration = 3000;//默认动画时间
    //颜色集合 从中获取颜色
    private int[] color = {
            0xFFFF34B3, 0xFF9ACD32, 0xFF9400D3, 0xFFEE9A00,
            0xFFFFB6C1, 0xFFDA70D6, 0xFF8B008B, 0xFF4B0082,
            0xFF483D8B, 0xFF1E90FF, 0xFF00BFFF, 0xFF00FF7F
    };


    public MyView(Context context) {
        super(context);
        initFrameLayout();
    }


    public MyView(Context context, AttributeSet attrs) {
        super(context, attrs);
        initFrameLayout();
    }

    private void initFrameLayout() {
        ViewGroup.LayoutParams params = new ViewGroup.LayoutParams(defoutWidth, ViewGroup.LayoutParams.WRAP_CONTENT);
        setLayoutParams(params);
    }

    private ImageView createHeartView() {
        //创建心形的ImageView
        ImageView imageView = new ImageView(getContext());
        LayoutParams params = new LayoutParams(defoutWidth / 2, defoutWidth / 2);
        //设置位置
        params.addRule(RelativeLayout.ALIGN_PARENT_BOTTOM);
        params.addRule(RelativeLayout.CENTER_HORIZONTAL);

        imageView.setLayoutParams(params);
        imageView.setImageResource(R.drawable.heart);

        //改变颜色
        imageView.setImageTintList(
                ColorStateList.valueOf(color[(int) (color.length * Math.random())])
        );
        //返回
        return imageView;
    }

    public void start() {
        //获取心形ImageView
        final ImageView heartView = createHeartView();
        //添加到布局中
        addView(heartView);
        AnimatorSet animatorSet = new AnimatorSet();
        animatorSet.play(createTranslationX(heartView))
                .with(createTranslationY(heartView))
                .with(createScale(heartView))
                .with(createRotation(heartView))
                .with(createAlpha(heartView));
        //执行动画
        animatorSet.start();

        //在动画结束的时候 销毁view
        animatorSet.addListener(new AnimatorListenerAdapter() {
            @Override
            public void onAnimationEnd(Animator animation) {
                super.onAnimationEnd(animation);
                removeView(heartView);
            }
        });
    }

    private Animator createAlpha(ImageView heartView) {
        //透明
        ObjectAnimator animator = ObjectAnimator.ofFloat(heartView, "alpha", 1, 0.1f);
        animator.setDuration(mDuration);
        //加速
        animator.setInterpolator(new AccelerateInterpolator());
        return animator;
    }

    private Animator createRotation(ImageView heartView) {
        //抖动的动画
        ObjectAnimator animator = ObjectAnimator.ofFloat(heartView, "rotation", 0, (float) (25f * Math.random()));
        animator.setDuration(mDuration);
        animator.setInterpolator(new CycleInterpolator((float) (6 * Math.random())));
        return animator;
    }

    private Animator createScale(ImageView heartView) {
        //放大动画
        ObjectAnimator animatorX = ObjectAnimator.ofFloat(heartView, "scaleX", 1, 1.5f);
        ObjectAnimator animatorY = ObjectAnimator.ofFloat(heartView, "scaleY", 1, 1.5f);
        AnimatorSet animatorSet = new AnimatorSet();
        animatorSet.setDuration(mDuration);
        //加速
        animatorSet.setInterpolator(new AccelerateInterpolator());
        animatorSet.play(animatorX).with(animatorY);
        return animatorSet;
    }

    private Animator createTranslationY(ImageView heartView) {
        //纵向平移
        ObjectAnimator animator = ObjectAnimator.ofFloat(heartView, "translationY", 0, -1000);
        animator.setDuration(mDuration);
        //加速
        animator.setInterpolator(new AccelerateInterpolator());
        return animator;
    }

    private Animator createTranslationX(ImageView heartView) {
        //横向平移
        ObjectAnimator animator = ObjectAnimator.ofFloat(heartView, "translationX", 0, (float) (defoutWidth * Math.random() / 4));
        animator.setDuration(mDuration);
        //CycleInterpolator cycles 正弦曲线数
        animator.setInterpolator(new CycleInterpolator((float) (3 * Math.random())));
        return animator;
    }

}

在Activity中 通过点击事件,调用自定义View中的start方法 实现动画的开始

package com.example.myviewtest;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {
    private Button btn;
    private MyView myView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);


        btn = (Button) findViewById(R.id.btn);
        myView = (MyView) findViewById(R.id.myView);
        btn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                myView.start();
            }
        });
    }
}

布局中 可以根据自己的需求 设置该动画开始的位置

要开心加油

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值