Android数字跳动的TextView实现

简介:

Android数字跳动的TextView实现

简介

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.  






本文作者:佚名
来源:51CTO
目录
相关文章
|
2月前
|
XML 存储 Java
浅谈Android的TextView控件
浅谈Android的TextView控件
46 0
|
3月前
|
Android开发
Android经典实战之Textview文字设置不同颜色、下划线、加粗、超链接等效果
本文介绍了 `SpannableString` 在 Android 开发中的强大功能,包括如何在单个字符串中应用多种样式,如颜色、字体大小、风格等,并提供了详细代码示例,展示如何设置文本颜色、添加点击事件等,助你实现丰富文本效果。
313 3
|
6月前
|
XML IDE 开发工具
13. 【Android教程】文本框 TextView
13. 【Android教程】文本框 TextView
120 2
|
6月前
|
编解码 Android开发
Android 解决TextView多行滑动与NestedScrollView嵌套滑动冲突的问题
Android 解决TextView多行滑动与NestedScrollView嵌套滑动冲突的问题
111 0
|
7月前
|
Android开发
android TextView HTML 的效果
android TextView HTML 的效果
48 2
|
7月前
|
XML 搜索推荐 Java
Android TextView的字体设置
【5月更文挑战第13天】
302 0
|
7月前
|
XML Java Android开发
Android控件之基础控件——进度条类的view——TextView、Checkbox复选控件、RadioButton单选控件、ToggleButton开关、SeekBar拖动条、menu、弹窗
Android控件之基础控件——进度条类的view——TextView、Checkbox复选控件、RadioButton单选控件、ToggleButton开关、SeekBar拖动条、menu、弹窗
752 1
|
7月前
|
Android开发
Android开发小技巧:怎样在 textview 前面加上一个小图标。
Android开发小技巧:怎样在 textview 前面加上一个小图标。
133 0
|
XML Android开发 数据格式
Android 中使用SpannableString实现TextView文本超链接跳转功能
Android 中使用SpannableString实现TextView文本超链接跳转功能
247 0
|
Android开发
Android 实现视图文本TextView的展开与收缩功能
Android 实现视图文本TextView的展开与收缩功能
314 0