Android属性アニメーションはTextViewのような支付宝残高の数字スクロールを実現
Demoはリンク項目の中の小さな需要をダウンロードして、支付宝の残高のようなデジタルスクロール効果を完成して、ネット上の小さなdemoを探して、郭おばさんの属性アニメーションに関する文章を加えて、一部のコードを整理して必要な人に分かち合います.
以下にパッケージされたTextViewコードの断片を貼り、主に属性アニメーションを利用してTextViewを更新してデジタルスクロール更新を完了する.
メインインタフェース呼び出し
Demoダウンロードプロパティアニメーションに詳しくない場合は、この記事を参照することをお勧めしますhttp://blog.csdn.net/guolin_blog/article/details/43536355
以下にパッケージされたTextViewコードの断片を貼り、主に属性アニメーションを利用してTextViewを更新してデジタルスクロール更新を完了する.
package shidong.com.numberscrolldemo.view;
import android.animation.ValueAnimator;
import android.content.Context;
import android.util.AttributeSet;
import android.widget.TextView;
import java.text.DecimalFormat;
import shidong.com.numberscrolldemo.R;
/**
* NumberScrollTextView,
* created by shidong
*/
public class NumberScrollTextView extends TextView implements IRiseNumber {
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 DecimalFormat fnum;
private EndListener mEndListener = null;
final static int[] sizeTable = {9, 99, 999, 9999, 99999, 999999, 9999999,
99999999, 999999999, Integer.MAX_VALUE};
/**
*
*
* @param context
*/
public NumberScrollTextView(Context context) {
super(context);
}
/**
*
*
* @param context
* @param attr
*/
public NumberScrollTextView(Context context, AttributeSet attr) {
super(context, attr);
setTextColor(context.getResources().getColor(R.color.black));
setTextSize(30);
}
public NumberScrollTextView(Context context, AttributeSet attr, int defStyle) {
super(context, attr, defStyle);
}
/**
*
*
* @return
*/
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) {
setText(fnum.format(Float.parseFloat(valueAnimator
.getAnimatedValue().toString())));
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();
fnum = new DecimalFormat("##0.00");
}
/**
*
*/
@Override
public void start() {
if (!isRunning()) {
mPlayingState = RUNNING;
if (numberType == 1)
runInt();
else
runFloat();
}
}
/**
*
*
* @param number
*/
@Override
public void withNumber(int number) {
this.number = number;
numberType = 1;
if (number > 1000) {
fromNumber = number
- (float) Math.pow(10, sizeOfInt((int) number) - 2);
} else {
fromNumber = number / 2;
}
}
/**
*
*
* @param number
*/
@Override
public void withNumber(float number) {
this.number = number;
numberType = 2;
if (number > 1000) {
fromNumber = number
- (float) Math.pow(10, sizeOfInt((int) number) - 1);
} else {
fromNumber = number / 2;
}
}
@Override
public void setFromAndEndNumber(int fromNumber, int endNumber) {
this.fromNumber = fromNumber;
this.number = endNumber;
numberType = 1;
}
@Override
public void setFromAndEndNumber(float fromNumber, float endNumber) {
this.fromNumber = fromNumber;
this.number = endNumber;
numberType = 2;
}
/**
*
*/
@Override
public void setDuration(long duration) {
this.duration = duration;
}
/**
*
*/
@Override
public void setOnEndListener(EndListener callback) {
mEndListener = callback;
}
/**
*
*/
public interface EndListener {
/**
*
*/
public void onEndFinish();
}
}
メインインタフェース呼び出し
package shidong.com.numberscrolldemo;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import shidong.com.numberscrolldemo.view.NumberScrollTextView;
/**
* ,
* created by mashidong
*/
public class MainActivity extends AppCompatActivity {
private NumberScrollTextView tv_number;
private Button btn_start;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initViews();
}
private void initViews() {
tv_number = (NumberScrollTextView) findViewById(R.id.tv_number);
tv_number.setFromAndEndNumber(0, 20000);
tv_number.setDuration(1000);
btn_start = (Button) findViewById(R.id.btn_start);
btn_start.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
tv_number.start();
}
});
}
}
Demoダウンロードプロパティアニメーションに詳しくない場合は、この記事を参照することをお勧めしますhttp://blog.csdn.net/guolin_blog/article/details/43536355