android金币动效_Android 仿余额宝数字跳动动画效果完整代码
一:想都不用想的,有图有真相,看着爽了,在看下面源码
二:实例源码分析
①:首先定义接口
package com.demo.tools.view;
/**
* 数字动画自定义
*
* @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;
/**
* 数字动画自定义
*
* @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;
}
}
三:主界面调用
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;
/**
* 数字动画
*
* @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();
}
}
四:总结
以上所述是小编给大家介绍的Android 仿余额宝数字跳动动画效果完整代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
android金币动效_Android 仿余额宝数字跳动动画效果完整代码相关推荐
- android 文字跳动动画,Android 仿余额宝数字跳动动画效果完整代码
Android 仿余额宝数字跳动动画效果完整代码 发布时间:2020-08-24 06:55:30 来源:脚本之家 阅读:120 作者:曾淘 一:想都不用想的,有图有真相,看着爽了,在看下面源码 二: ...
- android仿微信红包动画,Android仿打开微信红包动画效果实现代码
首先看下效果: 实现原理: 准备3张不同角度的图片,通过AnimationDrawable帧动画进行播放即可 代码实现: 1.编写动画xml文件: 根标签为animation-list,其中onesh ...
- android金币动效_动起来-几个Android常用动效
生活不能没有运动,so让我们动起来吧^^~ 下面分享几个简单.常用.不易出错的动效. 要点 文字滚动. 视图自带的动画. 抛物位移. 按压水面波纹效果. 共享元素动画. Demo 一如既往的霍尔首页^ ...
- android金币动效_打造高逼格Android个人中心动效UI
简介 前段时间由于产品的"神奇"(qi pa)需求,需要能下拉刷新放大,上划折叠,而且下半部分还是一个Tab+Viewpager布局. 类似新浪微博的个人中心,但他的也不能下拉放大 ...
- iOS动效-利用CATransform3D实现翻页动画效果
从事iOS开发已经有一段时间了,之前一直忙于工作,几乎很少有时间写一些东西来对自己掌握的技术进行一下总结,现在想想,有些后悔,因为之前在遇见问题的时候或者学习新技术的时候都是在翻看他人的博客或者查看苹 ...
- 仿余额宝数字跳动效果 TextCounter
1.TextCounter 效果 2.TextCounter 说明 每次打开余额宝第一件事情就去看看有多少钱,最炫的就是看着钱在跳动相当的舒服,今天放出这个效果. 温馨提示:支持的Androi ...
- 50行代码实现3D模拟真实撒金币动效
我们将会用50行不到的代码来实现一个3D模拟撒金币动效.你只需要一点Egret基础就能够快速上手,如果你不了解Egret,这里有一篇3分钟创建hello world来带你快速入门. 实现效果 源码和在 ...
- Android 仿支付宝蚂蚁森林动画效果
Android 动画可以归纳为以下几种: 视图动画(View 动画) 帧动画(Frame 动画.Drawable 动画) 属性动画 触摸反馈动画(Ripple Effect) 揭露动画(Reveal ...
- qt同时两个动画执行_Qt实现数字滚动动画效果
自己开发了一个股票智能分析软件,功能很强大,需要的点击下面的链接获取: https://www.cnblogs.com/bclshuai/p/11380657.html Qt实现数字滚动动画效果 3. ...
最新文章
- python之迭代锁与信号量
- 佩珀代因大学计算机科学专业,佩珀代因大学计算机科学与数学本科专业.pdf
- SQL_MODE设置
- [转]C语言茶余饭后之if...else PK switch...case
- python中str用法_python中的str()不能直接用吗
-问答-阿里云开发者社区-阿里云
- 服务提供者和服务消费者
- REST 101开发人员专用
- VS2013崩溃,无法打开项目的解决方案
- ClickHouse内核分析-MergeTree的Merge和Mutation机制
- jq之$(“[href]“)
- 汇编语言:编写code段中代码,将a段和b段中的数据依次相加,将结果放到c段
- hdoj1789:Doing Homework again (贪心)
- 开源软件的安全性风险_开源安全性,Google惊喜等
- java锁机制ppt_总结:Java锁机制
- 面试硬核干货:纯CSS实现垂直居中,快来收藏吧
- ai作文批改_每日即评 | 积极适应“AI批改作文”的潮流
- QT找不到python27.dll或python36.dll解决办法
- 电子商务世界历程及国内历程
- imp命令导入dmp文件问题
- android 多个蓝牙连接电脑,Android BLE蓝牙多设备连接
热门文章
- 【报告分享】抖音品牌主页运营官方指导手册.pdf(附下载链接)
- 【论文】最新图学习推荐系统综述 | Graph Learning Approaches to Recommender
- pytorch查缺补漏
- python深度学习第一讲——用python写神经网络
- 腾讯广告:广告场景下有哪些视觉算法应用?
- Green Deep Learning:NLP在大模型之外的另一种思路!
- java打开的文件过多_显示打开文件数目过多的解决方法.
- 使用反射获得jar包中的类、方法、参数、返回值类型,然后动态加载jar包运行方法
- vue中定义多重样式
- SpringBoot App Registers UNKNOWN with Eureka in Brixton SR3