Android 仿余額寶數(shù)字跳動(dòng)動(dòng)畫效果完整代碼
一:想都不用想的,有圖有真相,看著爽了,在看下面源碼

二:實(shí)例源碼分析
①:首先定義接口
package com.demo.tools.view;
/**
* 數(shù)字動(dòng)畫自定義
*
* @author zengtao 2015年7月17日 上午11:48:27
*
*/
public interface RiseNumberBase {
public void start();
public RiseNumberTextView withNumber(float number);
public RiseNumberTextView withNumber(float number, boolean flag);
public RiseNumberTextView withNumber(int number);
public RiseNumberTextView setDuration(long duration);
public void setOnEnd(RiseNumberTextView.EndListener callback);
}
②:自定義控件
package com.demo.tools.view;
import android.animation.ValueAnimator;
import android.content.Context;
import android.util.AttributeSet;
import android.widget.TextView;
import com.demo.tools.Utils;
/**
* 數(shù)字動(dòng)畫自定義
*
* @author zengtao 2015年7月17日 上午11:48:03
*
*/
public class RiseNumberTextView extends TextView implements RiseNumberBase {
private static final int STOPPED = 0;
private static final int RUNNING = 1;
private int mPlayingState = STOPPED;
private float number;
private float fromNumber;
private long duration = 1000;
/**
* 1.int 2.float
*/
private int numberType = 2;
private boolean flags = true;
private EndListener mEndListener = null;
final static int[] sizeTable = { 9, 99, 999, 9999, 99999, 999999, 9999999, 99999999, 999999999, Integer.MAX_VALUE };
public RiseNumberTextView(Context context) {
super(context);
}
public RiseNumberTextView(Context context, AttributeSet attr) {
super(context, attr);
}
public RiseNumberTextView(Context context, AttributeSet attr, int defStyle) {
super(context, attr, defStyle);
}
public interface EndListener {
public void onEndFinish();
}
public boolean isRunning() {
return (mPlayingState == RUNNING);
}
private void runFloat() {
ValueAnimator valueAnimator = ValueAnimator.ofFloat(fromNumber, number);
valueAnimator.setDuration(duration);
valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator valueAnimator) {
if (flags) {
setText(Utils.format(",##0.00").format(Double.parseDouble(valueAnimator.getAnimatedValue().toString())) + "");
if (valueAnimator.getAnimatedValue().toString().equalsIgnoreCase(number + "")) {
setText(Utils.format(",##0.00").format(Double.parseDouble(number + "")));
}
} else {
setText(Utils.format("##0.00").format(Double.parseDouble(valueAnimator.getAnimatedValue().toString())) + "");
if (valueAnimator.getAnimatedValue().toString().equalsIgnoreCase(number + "")) {
setText(Utils.format("##0.00").format(Double.parseDouble(number + "")));
}
}
if (valueAnimator.getAnimatedFraction() >= 1) {
mPlayingState = STOPPED;
if (mEndListener != null)
mEndListener.onEndFinish();
}
}
});
valueAnimator.start();
}
private void runInt() {
ValueAnimator valueAnimator = ValueAnimator.ofInt((int) fromNumber, (int) number);
valueAnimator.setDuration(duration);
valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator valueAnimator) {
setText(valueAnimator.getAnimatedValue().toString());
if (valueAnimator.getAnimatedFraction() >= 1) {
mPlayingState = STOPPED;
if (mEndListener != null)
mEndListener.onEndFinish();
}
}
});
valueAnimator.start();
}
static int sizeOfInt(int x) {
for (int i = 0;; i++)
if (x <= sizeTable[i])
return i + 1;
}
@Override
protected void onFinishInflate() {
super.onFinishInflate();
}
@Override
public void start() {
if (!isRunning()) {
mPlayingState = RUNNING;
if (numberType == 1)
runInt();
else
runFloat();
}
}
@Override
public RiseNumberTextView withNumber(float number, boolean flag) {
this.number = number;
this.flags = flag;
numberType = 2;
fromNumber = 0;
return this;
}
@Override
public RiseNumberTextView withNumber(float number) {
System.out.println(number);
this.number = number;
numberType = 2;
fromNumber = 0;
return this;
}
@Override
public RiseNumberTextView withNumber(int number) {
this.number = number;
numberType = 1;
fromNumber = 0;
return this;
}
@Override
public RiseNumberTextView setDuration(long duration) {
this.duration = duration;
return this;
}
@Override
public void setOnEnd(EndListener callback) {
mEndListener = callback;
}
}
③工具類的編寫
package com.demo.tools;
import java.math.RoundingMode;
import java.text.DecimalFormat;
/**
* 配置文件
* @author zengtao 2015年7月17日 上午11:47:44
*
*/
public class Utils {
/**
* 格式化
*/
private static DecimalFormat dfs = null;
public static DecimalFormat format(String pattern) {
if (dfs == null) {
dfs = new DecimalFormat();
}
dfs.setRoundingMode(RoundingMode.FLOOR);
dfs.applyPattern(pattern);
return dfs;
}
}
三:主界面調(diào)用
package com.demo.ui;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import com.demo.tools.view.RiseNumberTextView;
/**
* 數(shù)字動(dòng)畫
*
* @author zengtao 2015年7月17日 上午11:48:54
*
*/
public class MainActivity extends Activity {
private RiseNumberTextView number1, number2, number3, number4, number5;
private Button start;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main_activity);
initView();
}
private void initView() {
number1 = (RiseNumberTextView) findViewById(R.id.number1);
number2 = (RiseNumberTextView) findViewById(R.id.number2);
number3 = (RiseNumberTextView) findViewById(R.id.number3);
number4 = (RiseNumberTextView) findViewById(R.id.number4);
number5 = (RiseNumberTextView) findViewById(R.id.number5);
start = (Button) findViewById(R.id.start);
start.setOnClickListener(listener);
}
OnClickListener listener = new OnClickListener() {
@Override
public void onClick(View v) {
if (v == start) {
initData();
}
}
};
private void initData() {
number1.withNumber(12.3f).start();
number2.withNumber(16.3f).start();
number3.withNumber(10.3f).start();
number4.withNumber(18.3f).start();
number5.withNumber(17.3f).start();
}
}
四:總結(jié)
demo下載地址:http://xiazai.jb51.net/201711/yuanma/Demo.rar
以上所述是小編給大家介紹的Android 仿余額寶數(shù)字跳動(dòng)動(dòng)畫效果完整代碼,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- 通過FancyView提供 Android 酷炫的開屏動(dòng)畫實(shí)例代碼
- Android自定義帶加載動(dòng)畫效果的環(huán)狀進(jìn)度條
- Android自定義viewGroup實(shí)現(xiàn)點(diǎn)擊動(dòng)畫效果
- Android仿打開微信紅包動(dòng)畫效果實(shí)現(xiàn)代碼
- Android仿硬幣轉(zhuǎn)動(dòng)微信紅包動(dòng)畫效果
- Android動(dòng)畫入門教程之kotlin
- Android實(shí)現(xiàn)過渡動(dòng)畫、引導(dǎo)頁 Android判斷是否第一次啟動(dòng)App
- Android開發(fā)簡單實(shí)現(xiàn)搖動(dòng)動(dòng)畫的方法
- Android開發(fā)之背景動(dòng)畫簡單實(shí)現(xiàn)方法
- Android動(dòng)畫實(shí)現(xiàn)原理和代碼
相關(guān)文章
Android自定義View實(shí)現(xiàn)多片葉子旋轉(zhuǎn)滑動(dòng)(五)
這篇文章主要為大家詳細(xì)介紹了Android自定義View實(shí)現(xiàn)多片葉子葉子旋轉(zhuǎn)滑動(dòng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
Android編程實(shí)現(xiàn)壓縮圖片并加載顯示的方法
這篇文章主要介紹了Android編程實(shí)現(xiàn)壓縮圖片并加載顯示的方法,涉及Android開發(fā)中圖片的運(yùn)算、壓縮處理操作及界面布局顯示壓縮圖片等相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-10-10
Android學(xué)習(xí)之AppWidget筆記分享
這篇文章主要為大家詳細(xì)介紹了Android學(xué)習(xí)筆記之AppWidget的相關(guān)資料,感興趣的小伙伴們可以參考一下2016-08-08
android實(shí)現(xiàn)搜索功能并將搜索結(jié)果保存到SQLite中(實(shí)例代碼)
這篇文章主要介紹了android實(shí)現(xiàn)搜索功能并將搜索結(jié)果保存到SQLite中,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04
Android編程實(shí)現(xiàn)的簡易路徑導(dǎo)航條功能示例
這篇文章主要介紹了Android編程實(shí)現(xiàn)的簡易路徑導(dǎo)航條功能,結(jié)合實(shí)例形式分析了Android結(jié)合視圖、布局及路徑操作實(shí)現(xiàn)導(dǎo)航條功能的相關(guān)技巧,需要的朋友可以參考下2017-01-01
android實(shí)現(xiàn)動(dòng)態(tài)顯隱進(jìn)度條
這篇文章主要為大家詳細(xì)介紹了android實(shí)現(xiàn)動(dòng)態(tài)顯隱進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07

