动画TextView增加整数并在某些时候停止?

时间:2014-10-22 08:05:32

标签: android

我有一个显示整数值的TextView。整数值从之前的活动转移,我想添加漂亮的动画。我想如果例如int值是73,我希望textView将显示的数字增加1到73,所以它将是1-2-3-4-5 ...等等。 我怎么能这样做?

5 个答案:

答案 0 :(得分:85)

我认为最好的解决方案是使用这种方法:

public void animateTextView(int initialValue, int finalValue, final TextView  textview) {

    ValueAnimator valueAnimator = ValueAnimator.ofInt(initialValue, finalValue);
    valueAnimator.setDuration(1500);

    valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
        @Override
        public void onAnimationUpdate(ValueAnimator valueAnimator) {

            textview.setText(valueAnimator.getAnimatedValue().toString());

        }
    });
    valueAnimator.start();

}

答案 1 :(得分:38)

这是一个简单的函数,可根据初始值和最终值

为textView的文本设置动画
public void animateTextView(int initialValue, int finalValue, final TextView textview) {
        DecelerateInterpolator decelerateInterpolator = new DecelerateInterpolator(0.8f);
        int start = Math.min(initialValue, finalValue);
        int end = Math.max(initialValue, finalValue);
        int difference = Math.abs(finalValue - initialValue);
        Handler handler = new Handler();
        for (int count = start; count <= end; count++) {
            int time = Math.round(decelerateInterpolator.getInterpolation((((float) count) / difference)) * 100) * count;
            final int finalCount = ((initialValue > finalValue) ? initialValue - count : count);
            handler.postDelayed(new Runnable() {
                @Override
                public void run() {
                    textview.setText(String.valueOf(finalCount));
                }
            }, time);
        }
    }

答案 2 :(得分:3)

我认为github中的这个项目是你想要的:https://github.com/sd6352051/RiseNumber

RiseNumberTextView扩展TextView并使用ValueAnimator实现上升数字效果。

答案 3 :(得分:1)

尝试此代码..使用动画显示增量值

public class MainActivity extends Activity implements AnimationListener {
    private TextView textView;
    AlphaAnimation fadeIn, fadeOut;

    private static int count = 0, finalValue = 20;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.demo);

        textView = (TextView) findViewById(R.id.textView);

        fadeIn = new AlphaAnimation(0.0f, 1.0f);
        fadeOut = new AlphaAnimation(1.0f, 0.0f);

        fadeIn.setDuration(1000);
        fadeIn.setFillAfter(true);
        fadeOut.setDuration(1000);
        fadeOut.setFillAfter(true);

        fadeIn.setAnimationListener(this);
        fadeOut.setAnimationListener(this);
        textView.startAnimation(fadeIn);
        textView.startAnimation(fadeOut);

    }   

    @Override
    public void onAnimationEnd(Animation arg0) {
        // TODO Auto-generated method stub

        Log.i("mini", "Count:" + count);

        runOnUiThread(new Runnable() {

            @Override
            public void run() {
                // TODO Auto-generated method stub
                textView.setText("" + count);
            }
        });

        if (count == finalValue) {
            textView.setText("" + finalValue);
        } else {
            ++count;
            textView.startAnimation(fadeIn);
            textView.startAnimation(fadeOut);
        }

    }

    @Override
    public void onAnimationRepeat(Animation arg0) {
        // TODO Auto-generated method stub

    }

    @Override
    public void onAnimationStart(Animation arg0) {
        // TODO Auto-generated method stub

    }

}

答案 4 :(得分:0)

这是Kotlin代码,用于在一段时间内从初始值递增到最终值。在这里,我使用了5秒的时间。

 fun animateTextView(initialValue: Int, finalValue: Int, textView: TextView) {
        val valueAnimator = ValueAnimator.ofInt(initialValue, finalValue)
        valueAnimator.duration = 5000 // 5 sec
        valueAnimator.addUpdateListener { valueAnimator -> textView.text = valueAnimator.animatedValue.toString() }
        valueAnimator.start()
    }

在“实用工具”中使用此代码,并使用必需的参数相应地调用该方法。