【Android】属性动画组合(82/100)

2
动画组合主要代码:

private AnimatorSet animSet; // 声明一个属性动画组合对象
    // 初始化属性动画
    private void initObjectAnim() {
        // 构造一个在横轴上平移的属性动画
        ObjectAnimator anim1 = ObjectAnimator.ofFloat(imageView, "translationX", 0f, 100f);
        // 构造一个在透明度上变化的属性动画
        ObjectAnimator anim2 = ObjectAnimator.ofFloat(imageView, "alpha", 1f, 0.1f, 1f, 0.5f, 1f);
        // 构造一个围绕中心点旋转的属性动画
        ObjectAnimator anim3 = ObjectAnimator.ofFloat(imageView, "rotation", 0f, 360f);
        // 构造一个在纵轴上缩放的属性动画
        ObjectAnimator anim4 = ObjectAnimator.ofFloat(imageView, "scaleY", 1f, 0.5f, 1f);
        // 构造一个在横轴上平移的属性动画
        ObjectAnimator anim5 = ObjectAnimator.ofFloat(imageView, "translationX", 100f, 0f);
        animSet = new AnimatorSet(); // 创建一个属性动画组合
        // 把指定的属性动画添加到属性动画组合
        AnimatorSet.Builder builder = animSet.play(anim2);
        // 动画播放顺序为:先执行anim1,再一起执行anim2、anim3、anim3,最后执行anim5
        builder.with(anim3).with(anim4).after(anim1).before(anim5);
        animSet.setDuration(4500); // 设置动画的播放时长
        animSet.start(); // 开始播放属性动画
        animSet.addListener(animatorListener); // 给属性动画添加动画事件监听器
    }

动画监听:


    Animator.AnimatorListener animatorListener=new Animator.AnimatorListener() {
        @Override
        public void onAnimationStart(Animator animation) {

        }

        @Override
        public void onAnimationEnd(Animator animation) {
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
                animSet.setCurrentPlayTime(0); // 设置当前播放的时间点
                animSet.reverse(); // 从动画尾巴开始倒播至setCurrentPlayTime设置的时间点
            }
        }

        @Override
        public void onAnimationCancel(Animator animation) {

        }

        @Override
        public void onAnimationRepeat(Animator animation) {

        }
    };

交互控制:

imageView.setOnClickListener(new View.OnClickListener() {
            @RequiresApi(api = Build.VERSION_CODES.KITKAT)
            @Override
            public void onClick(View v) {
                if (v.getId() == R.id.iv_origin) {
                    if (animSet.isStarted()) { // 属性动画已经播放过了
                        if (animSet.isRunning()) { // 属性动画正在播放
                            if (!isPaused) {
                                animSet.pause(); // 暂停播放属性动画
                            } else {
                                animSet.resume(); // 恢复播放属性动画
                            }
                            isPaused = !isPaused;
                        } else { // 属性动画不在播放
                            animSet.start(); // 开始播放属性动画
                        }
                    } else { // 属性动画尚未开始播放
                        animSet.start(); // 开始播放属性动画
                    }
                }
            }
        });

组合后的动画效果比单一效果炫酷很多

自研产品推荐

历时一年半多开发终于smartApi-v1.0.0版本在2023-09-15晚十点正式上线
smartApi是一款对标国外的postman的api调试开发工具,由于开发人力就作者一个所以人力有限,因此v1.0.0版本功能进行精简,大功能项有:

  • api参数填写
  • api请求响应数据展示
  • PDF形式的分享文档
  • Mock本地化解决方案
  • api列表数据本地化处理
  • 再加上UI方面的打磨

为了更好服务大家把之前的公众号和软件激活结合,如有疑问请大家反馈到公众号即可,下个版本30%以上的更新会来自公众号的反馈。
嗯!先解释不上服务端原因,API调试工具的绝大多数时候就是一个数据模型、数据处理、数据模型理解共识的问题解决工具,所以作者结合自己十多年开发使用的一些痛点来打造的,再加上服务端开发一般是面向企业的,作者目前没有精力和时间去打造企业服务。再加上没有资金投入所以服务端开发会滞后,至于什么时候会进行开发,这个要看募资情况和用户反馈综合考虑。虽然目前国内有些比较知名的api工具了,但作者使用后还是觉得和实际使用场景不符。如果有相关吐槽也可以在作者的公众号里反馈蛤!
下面是一段smartApi使用介绍:
在这里插入图片描述

下载地址:

https://pan.baidu.com/s/1iultkXqeLNG4_eNiefKTjQ?pwd=cnbl

posted @ 2022-08-24 16:39  lichong951  阅读(8)  评论(0编辑  收藏  举报  来源