Android 弹簧动画效果

原创 2015年04月26日 22:43:33

一、概述

Rebound 通过胡克定律,实现的一个类似“弹簧”动画效果的第三方工具包,由FaceBook退出,于2013年10月正式发布,旨在解决笨重、缓慢的传统移动网络界面。

先上几张效果图:

               

         


特点:
Rebound 可以使你的动画看起来像真实自然,像真实世界物理运动
Rebound 不是一个物理引擎库,但是Rebound可以使用弹簧动力来驱动各种各样的动画
Rebound使用和Origami(IOS的)相同的弹簧系数,方便实用。
并且可以和Material Design的设计原则呼应,可用于滚动条、切换开关、呼叫等场景下

二、如何使用

1.首先添加Rebound库依赖

  • 如果你使用Android studio,那么恭喜你,你可以直接添加gradle依赖,相比其他方法简便许多
    dependencies {
      compile 'com.facebook.rebound:rebound:0.3.6'
    }

  • 下载Reboud Jar文件,导入工程
  • 添加Maven依赖 
    <dependency>
      <groupId>com.facebook.rebound</groupId>
      <artifactId>rebound</artifactId>
      <version>0.3.6</version>
    </dependency>

2.创建一个SpringSystem对象

SpringSystem mSpringSystem = SpringSystem.create();

3.添加一个“弹簧”到系统

	
Spring mSpring = mSpringSystem.createSpring();

4.添加监听器

mSpring.addListener(this);
//实现SpringListener接口,需要实现下面方法
@Override
public void onSpringUpdate(Spring spring) {
}
@Override
public void onSpringAtRest(Spring spring) {
}
@Override
public void onSpringActivate(Spring spring) {
}
@Override
public void onSpringEndStateChange(Spring spring) {
}

当然还可以实现简单的监听

spring.addListener(new SimpleSpringListener() {  
  
  @Override  
  public void onSpringUpdate(Spring spring) {  
    // You can observe the updates in the spring  
    // state by asking its current value in onSpringUpdate.  
 
  }  
});  


5.设置动画结束值

mSpring.setEndValue(1f);

6.在弹簧更新数据是对图片进行对应伸缩

public void onSpringUpdate(Spring spring) {
    float value = (float) spring.getCurrentValue();
    float scale = 1f - (value * 0.5f);
    mImageToAnimate.setScaleX(scale);
    mImageToAnimate.setScaleY(scale);
}

通过上面几个步骤可以很方便的实现弹簧阻尼效果的图片伸缩


参考

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

android 仿ios带弹簧效果的ScrollView

仿ios弹簧效果

Rebound-Android的弹簧动画库

简介官方网站githubRebound是facebook出品的一个弹簧动画库,与之对应的IOS版本有一个pop动画库,也是非常的强大给力。Facebook真是互联网企业中的楷模,开源了很多的实用开源库...

Android 弹簧动画效果

一、概述 Rebound 通过胡克定律,实现的一个类似“弹簧”动画效果的第三方工具包,由FaceBook退出,于2013年10月正式发布,旨在解决笨重、缓慢的传统移动网络界面。 先上几张效...

Android自定义View阻尼动画&贝塞尔曲线的实现

package com.example.administrator.myapplication.customview; import android.animation.Animator; impo...

[Android 动画] 实现类似弹簧的插值器SpringInterpolator

一、前言         在我们移动app的开发中,用户与输入框editText的交互应该是必不可少的。为了为用户提供更好的交互体验,我们这样规定:如果用户输入了不符合规则的内容,我们将调用一个抖动的...

android 阻尼效果(图片下拉变大)

效果图动态gif图就不上传了 论坛最大只能支持2M的图片 我也难得麻烦了 当然静态的图片还是要提供的不然亲们都不知道阻尼是个什么东东 其实这个也是一个仿Ios的效果啦不知道这个是什么的东西 ...

Android果冻效果(阻尼动画)

导语 之前发了一个Drawable实现动画效果的帖子,有人找我要过相应圆弧绘制算法,仔细想想那个项目中有些地方还是值得分享出来的,趁现在项目不忙,就准备分享出来。 效果如下(即Activity-A...

android的阻尼效果

很多时候我们在开发的过程中,需要做一些特殊的效果,今天就为大家介绍一下如何做一个阻尼的效果,所谓的阻尼效果就是头布局的背景图片在下拉的时候放大,在释放手指的时候缩小,从而产生放大缩小的效果。实现的方案...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)