Android has recently released a new physics-based animation Support Library named SpringAnimation, which is available in Support Library 25.3.0. Yesterday, Google Android developer “Nick Butcher” tweeted the announcement and gave a simple code sample in gist that demonstrates the core operations of SpringAnimation.
Let’s take a look at the renderings:
Take a look at the implementation code of the Activity (some adjustments have been made in the author’s source code, which is good for the appearance of the shot and the reading experience) :
package com.yifeng.samples;
import android.app.Activity;
import android.os.Bundle;
import android.support.animation.SpringAnimation;
import android.view.MotionEvent;
import android.view.VelocityTracker;
import android.view.View;
import android.widget.SeekBar;
public class HomeActivity extends Activity implements View.OnTouchListener {
private SeekBar damping, stiffness;
private View box;
private float downX, downY;
private VelocityTracker velocityTracker;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_home);
findViewById(android.R.id.content).setSystemUiVisibility(
View.SYSTEM_UI_FLAG_LAYOUT_STABLE
| View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
| View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION);
stiffness = (SeekBar) findViewById(R.id.stiffness);
damping = (SeekBar) findViewById(R.id.damping);
box = findViewById(R.id.box);
velocityTracker = VelocityTracker.obtain();
findViewById(R.id.root).setOnTouchListener(this);
}
private float getStiffness(a) {
return Math.max(stiffness.getProgress(), 1f);
}
private float getDamping(a) {
return damping.getProgress() / 100f;
}
@Override
public boolean onTouch(View v, MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
downX = event.getX();
downY = event.getY();
velocityTracker.addMovement(event);
return true;
case MotionEvent.ACTION_MOVE:
box.setTranslationX(event.getX() - downX);
box.setTranslationY(event.getY() - downY);
velocityTracker.addMovement(event);
return true;
case MotionEvent.ACTION_UP:
case MotionEvent.ACTION_CANCEL:
velocityTracker.computeCurrentVelocity(1000);
if(box.getTranslationX() ! =0) {
SpringAnimation animX = new SpringAnimation(box, SpringAnimation.TRANSLATION_X, 0);
animX.getSpring().setStiffness(getStiffness());
animX.getSpring().setDampingRatio(getDamping());
animX.setStartVelocity(velocityTracker.getXVelocity());
animX.start();
}
if(box.getTranslationY() ! =0) {
SpringAnimation animY = new SpringAnimation(box, SpringAnimation.TRANSLATION_Y, 0);
animY.getSpring().setStiffness(getStiffness());
animY.getSpring().setDampingRatio(getDamping());
animY.setStartVelocity(velocityTracker.getYVelocity());
animY.start();
}
velocityTracker.clear();
return true;
}
return false; }}Copy the code
The above core code in touch event processing, a brief introduction. SpringAnimation, named after the API, is a clever way to describe the animation effect it can achieve. As you know, the spring will automatically shrink after stretching, and the function of this animation is to achieve the View position automatically restore effect. Constructors are as follows:
SpringAnimation(View v, ViewProperty property, float finalPosition)Copy the code
Take a look at the two important concepts in the example figure, Bounces and damping. Friends who have played spring know that it is two important factors that affect the recovery effect of spring stretching. Spring overstretching, it will damage the spring, not easy to restore the original position; Different springs, corresponding to different damping effects, the actual recovery process will have a short stretch back and forth effect. SpringAnimation perfectly interprets these two factors in spring, which is based on physics animation.
SpringAnimation contains a property of type SpringForce that handles the Boundings and damping effects. As can be seen from the above renderings, the two different size values reflect different specific effects on SpringAnimation. You can try them in practice.
Remember to add dependent libraries to build.gradle:
compile 'com. Android. Support: support - dynamic - animation: 25.3.0'Copy the code
The emergence of SpringAnimation can help many developers solve some troubles caused by self-realization of spring effect. Many friends on Android have done imitation of iOS elastic ScrollView effect, also might as well use this animation library. Think again, are there any other common usage scenarios that SpringAnimation can use? Welcome to discuss.
Welcome to follow my wechat official account
Android Notebook: Focuses on Android development, and some thoughts of programmers.