弹性动画

来源:互联网 发布:vue app.js报错 编辑:程序博客网 时间:2024/05/28 17:06


弹性动画

原创 2017年10月08日 09:10:03

首先我们要在build.gradle中引入如下依赖:compile 'com.facebook.rebound:rebound:0.3.8'//首先建一个图片布局
[html] view plain copy
  1. <ImageView  
  2.     android:id="@+id/iv"  
  3.     android:layout_width="wrap_content"  
  4.     android:layout_height="wrap_content"  
  5.     android:layout_centerInParent="true"  
  6.     android:src="@mipmap/ic_launcher" />  
[html] view plain copy
  1. //接着在onCreate()方法里写如下代码:  
  2. //找控件  
  3.   
  4. iv = (ImageView) findViewById(R.id.iv);  
  5. //设置点击事件  
  6. iv.setOnClickListener(new View.OnClickListener() {  
  7.     @Override  
  8.     public void onClick(View view) {  
  9.         onScale();//点击时调用此方法  
  10.     }  
  11. });  
  12.   
  13. private void onScale(){  
  14.     SpringSystem springSystem=SpringSystem.create();  
  15.     Spring spring=springSystem.createSpring();  
  16.     spring.setCurrentValue(1.0f);//初始值  
  17.     spring.setSpringConfig(new SpringConfig(60,4));  
  18.   
  19.     //效果可以改变这两个参数来改变效果  
  20.     //第一个表示拉力,越大效果越明显,第二个表示摩擦力,越小效果越明显  
  21.   
  22.     spring.addListener(new SimpleSpringListener(){          
  23.           @Override          
  24.           public void onSpringUpdate(Spring spring) {              
  25.                super.onSpringUpdate(spring);              
  26.                float currentValue= (float) spring.getCurrentValue();              
  27.                iv.setScaleX(currentValue);              
  28.                iv.setScaleY(currentValue);          
  29.          }      
  30.     });      
  31.     spring.setEndValue(1.8f);//结束值