Android数字跳动的TextView实现

移动开发 Android
DancingNumberView是一个用于跳动显示文本中数字的控件,继承自TextView.这种控件一般用于显示金额等对用户较为敏感的数字,让UI交互更加生动。

[[189084]]

简介

DancingNumberView是一个用于跳动显示文本中数字的控件,继承自TextView.这种控件一般用于显示金额等对用户较为敏感的数字,让UI交互更加生动。

它具有以下几点特性:

  • 自动获取文本中的所有数字,并同时开始跳动,免去多个TextView拼接的麻烦
  • 支持数字按照自定义的格式显示,例如限定只显示小数点后两位

效果预览 

 

 

 

导入使用

Gradle

第1步,在project的build.gradle文件中适当位置添加

  1. allprojects { 
  2.     repositories { 
  3.         ... 
  4.         maven { url "https://jitpack.io" } 
  5.     } 
  6.  

第2步,在app的build.gradle文件中适当位置添加依赖项

  1. dependencies { 
  2.        compile 'com.github.JianxunRao:DancingNumberView:V1.0.1' 
  3.  

使用方式

通过XML布局

  1. <me.trojx.dancingnumber.DancingNumberView 
  2.             android:id="@+id/dnv" 
  3.             android:layout_width="wrap_content" 
  4.             android:layout_height="wrap_content" 
  5.             app:dnv_duration="6000" 
  6.             app:dnv_format="%.2f"/>  

通过Java代码

  1. DancingNumberView dnv = (DancingNumberView) findViewById(R.id.dnv); 
  2.    dnv.setText(text);//设置显示内容 
  3.    dnv.setDuration(duration);//设置完成跳动的持续时长(单位ms) 
  4.    dnv.setFormat(format);//设置数字的显示格式 
  5.    dnv.dance();//启动效果,开始数字跳动  

关键代码

  1. /**  
  2. * 文本中的数字开始跳动 
  3.  
  4. */ 
  5.  
  6. public void dance() { 
  7.  
  8. text = getText().toString(); 
  9.  
  10. numbers=new ArrayList<>(); 
  11.  
  12. Pattern pattern = Pattern.compile("\\d+(\\.\\d+)?"); 
  13.  
  14. Matcher matcher=pattern.matcher(text); 
  15.  
  16. while (matcher.find()){ 
  17.  
  18. numbers.add(Float.parseFloat(matcher.group())); 
  19.  
  20.  
  21. textPattern = text.replaceAll("\\d+(\\.\\d+)?",PLACEHOLDER); 
  22.  
  23. numberTemp=new float[numbers.size()]; 
  24.  
  25. ObjectAnimator objectAnimator=ObjectAnimator.ofFloat(this,"factor",0,1); 
  26.  
  27. objectAnimator.setDuration(duration); 
  28.  
  29. objectAnimator.setInterpolator(new AccelerateDecelerateInterpolator()); 
  30.  
  31. objectAnimator.start(); 
  32.  
  33.  
  34. /** 
  35.  
  36. * 获取算数因子 
  37.  
  38. * @return 算数因子 
  39.  
  40. */ 
  41.  
  42. public float getFactor() { 
  43.  
  44. return factor; 
  45.  
  46.  
  47. /** 
  48.  
  49. * 设置算数因子,为ObjectAnimator调用 
  50.  
  51. * @see ObjectAnimator 
  52.  
  53. * @param factor 算数因子 
  54.  
  55. */ 
  56.  
  57. public void setFactor(float factor) { 
  58.  
  59. String textNow=textPattern; 
  60.  
  61. this.factor = factor; 
  62.  
  63. for (int i=0;i<numberTemp.length;i++){ 
  64.  
  65. numberTemp[i]=numbers.get(i)*factor; 
  66.  
  67. textNow=textNow.replaceFirst(PLACEHOLDER,String.format(format,numberTemp[i])); 
  68.  
  69.  
  70. setText(textNow); 
  71.  
  72.  
责任编辑:庞桂玉 来源: Android技术之家
相关推荐

2012-12-28 14:23:12

Android开发TextView

2013-04-07 10:09:00

Android开发TextView属性

2016-12-07 10:32:14

移动应用开发底部导航android

2010-09-06 13:21:04

TextViewAndroid

2011-09-14 11:31:26

Android API

2013-03-28 15:47:53

TextView文字自

2012-12-25 13:54:28

AndroidTextview

2010-09-10 10:09:26

Android

2021-10-21 07:29:09

AndroidSpannableStTextView

2018-05-11 10:11:33

数字体验数字体验管理Riverbed

2022-06-24 15:18:48

字节跳动数据库ClickHouse

2009-09-08 22:53:39

c# textbox数

2019-04-12 13:53:58

存储

2022-08-21 21:28:32

数据库实践

2023-11-16 11:33:58

数字机库Lufthansa客户

2020-08-20 08:23:48

MySQL数据库技术

2015-07-17 10:07:33

JAVA数字水印

2013-03-28 13:33:13

Android平台Ai

2022-06-08 13:25:51

数据

2022-06-06 11:55:12

Flink字节跳动State
点赞
收藏

51CTO技术栈公众号