Gradient animation (also known as fade) usually refers to the gradual fading of one UI component while simultaneously fading into another. This is useful when the App wants to switch content or views. Gradients are short and subtle, while providing smooth transitions from one interface to the next. If you don’t use any animation when the transition is needed, it can make the transition look abrupt and rushed. Here I explain the specific implementation in detail, and attach the source code.
This example actually designs three files layout/ Activity_Crossfade. XML, Menu/activity_Crossfade
Now I have attached the source code for the three files and explained the functionality in the comments
layout/activity_crossfade.xml
<? xml version="1.0" encoding="utf-8"? > <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ScrollView
android:id="@+id/content"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView style="? android:textAppearanceMedium"
android:lineSpacingMultiplier="1.2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/lorem_ipsum"
android:padding="16dp"/>
</ScrollView>
<ProgressBar
android:id="@+id/loading_spinner"
style="? android:progressBarStyleLarge"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"/ > <! - the android: textAppearanceMedium and? Android: progressBarStyleLarge are all related to android built-in style, specific see android official reference manual -- -- > < / FrameLayout >Copy the code
menu/activity_crossfade.xml
<? xml version="1.0" encoding="utf-8"? > <menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item android:id="@+id/animation"
android:title="@string/action_animation"
app:showAsAction="ifRoom"/>
</menu>
Copy the code
MainActivity.java
package com.example.power.mytest;
import android.animation.Animator;
import android.animation.AnimatorListenerAdapter;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
import java.util.zip.Inflater;
public class MainActivity extends AppCompatActivity {
private View mContentView;
private View mLoadingView;
private int mShortAnimationDuration;
/* We define two views, one int, in which mShortAnimationDuration is used to store the duration of * animation. This time is set to the built-in Android value config_shortAnimTime. * This property defines a standard "short" duration for an animation. This is an ideal duration for subtle or fast-moving animations. You can also use * config_longAnimTime or config_mediumAnimTime as required. * /
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_crossfade);
mContentView = findViewById(R.id.content);
mLoadingView = findViewById(R.id.loading_spinner);
mContentView.setVisibility(View.GONE);
/* First set the visibility of the TextView to view.gone. This prevents the View from taking up space in the layout and also makes it invisible in the layout calculation to speed up the process. * /
mShortAnimationDuration = getResources().getInteger(
android.R.integer.config_shortAnimTime
);
crossfade();
}
private void crossfade(a){
mContentView.setAlpha(0f);
mContentView.setVisibility(View.VISIBLE);
/* After the above two steps, the TextView is visible and takes up layout space, but is set to transparent */
/* Within mShortAnimationDuration, TextView changes from 0f to 1f*/
mContentView.animate()
.alpha(1f)
.setDuration(mShortAnimationDuration)
.setListener(null);
/* Within mShortAnimationDuration, the ProgressBar changes from 1f to 0f, but the ProgressBar disappears before it can be seen. To not take up layout space */
mLoadingView.animate()
.alpha(0f)
.setDuration(mShortAnimationDuration)
.setListener(new AnimatorListenerAdapter() {
@Override
public void onAnimationEnd(Animator animation) { mLoadingView.setVisibility(View.GONE); }}); }@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater menuInflater = getMenuInflater();
menuInflater.inflate(R.menu.activity_crossfade, menu);
return super.onCreateOptionsMenu(menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()){
case R.id.animation:
crossfade();
return true;
default:
return super.onOptionsItemSelected(item); }}}Copy the code
Just paste the source code and the corresponding file, view the specific effect, the relevant details slowly experience.