美文网首页
SpringAimation 弹性动画

SpringAimation 弹性动画

作者: 白夜的地平线 | 来源:发表于2019-08-03 16:14 被阅读0次

1、SpringAnimation动画简单介绍

                //从右向左位移0.5秒完成
                ObjectAnimator objectAnimator = null;
                objectAnimator = ObjectAnimator.ofFloat(view, "translationX", pageWidth, 0);//位移页面宽度
                objectAnimator.setDuration(500);//位移时长
                objectAnimator.start();
                new Handler().postDelayed(new Runnable() {
                    @Override
                    public void run() {
                        //SpringAnimation动画sin算法方式会超出屏幕  建议在设置控件距离的时候使用    
                        //android:layout_marginLeft="5dp"偏移五个单位的dp

                        SpringForce spring = new SpringForce(0)
                                .setDampingRatio(0.3f)//0.9幅度小一次 0.7幅度小一次,0.3两次,dampingRatio越大,摆动次数越少,当到1的时候完全不摆动
                                .setStiffness(50f);//stiffness值越小,弹簧越容易摆动,摆动的时间越长,反之摆动时间越短
                        new SpringAnimation(view, SpringAnimation.TRANSLATION_X)//X轴方向位移
                                .setSpring(spring)
                                .setStartValue(0)//初始值
                                .setStartVelocity(100)//开始速度
                                .start();
                    }
                }, 500);

开始速度,dampingRatio,stiffness值,三个值相互影响


cda21039d72cf631ac24245b5e8dfa7.jpg

弹性效果入上图绘制,这个效果不是很好,还要设置控件的距离,有点鸡肋,不是咱程序员干的事情

2、如果不想要默认的可以直接设置插值器。对弹跳的值进行设置

ObjectAnimator objectAnimator = null;
                objectAnimator = ObjectAnimator.ofFloat(view, "translationX", pageWidth, 0);
                objectAnimator.setDuration(500);
                objectAnimator.setInterpolator(new SpringScaleInterpolator());
                objectAnimator.start();

public class SpringScaleInterpolator implements Interpolator {

   private float factor;

   public SpringScaleInterpolator(float factor) {
       this.factor = factor;
   }

   @Override
   public float getInterpolation(float x) {
       return (float) (pow(2,1) * sin((x - factor / 4) * (2 * PI) / factor) );//pow的用法可以百度   这里用的是sin,你自己也可以判断在小于0的时候就直接网上抛,这样做就不会出现屏幕会被遮挡的情况
   }
}
b7bc19e7ef4af0e6e1df79e4c710dda.jpg

这个图骗过好一点,不过return (float) (pow(2,1) * sin((x - factor / 4) * (2 * PI) / factor) );
这个函数还在计算,明天给与答案,今天有点事情忙先

相关文章

  • SpringAimation 弹性动画

    1、SpringAnimation动画简单介绍 开始速度,dampingRatio,stiffness值,三个值相...

  • 使用两种方式完成四种弹性动画

    前言   最近这段时间对弹性动画比较感兴趣,空闲就做了一下弹性动画的实现。网上对弹性动画的实现其实是有3种,属性动...

  • 可视化

    饼图 弹性动画 缓动跟随 弹性动画 动画原理根据上面的原理我们知道,你眼前所看到图像正在以每秒60次的频率刷新,由...

  • 动画iOS

    动画类型: pop:大小弹性缩放效果 shake:左右摇晃效果 morph:左右上下弹性变形效果 squeeze:...

  • iOS 动画篇 - pop动画库

    Pop 是 iOS,tvOS 和 OS X 的可扩展动画引擎。除了基本的静态动画外,他支持弹性和衰减动画动态动画,...

  • 弹性滑动和惯性滑动

    弹性滑动指的是平滑的滑动(smoothScrollTo),可以用View动画,属性动画,Scroller来实现,当...

  • Android开发之Scroller

    什么是Scroller? 翻译为弹性滑动对象,可以实现View的弹性滑动动画,与Scroller相关的就是大家比较...

  • Scroller(触摸滑屏)

    什么是Scroller?翻译为弹性滑动对象,可以实现View的弹性滑动动画,与Scroller相关的就是大家比较熟...

  • 源码推荐:自定义下拉刷新动画 弹性的分段选择控件

    源码推荐:自定义下拉刷新动画 弹性的分段选择控件

  • 交互篇--frame_基础篇1

    (一)点击变换 addButton弹性动画/列表滚动 drag 气泡 (二)快捷键

网友评论

      本文标题:SpringAimation 弹性动画

      本文链接:https://www.haomeiwen.com/subject/lzygrctx.html