Android实现数字跳动效果的TextView方法示例

 更新时间:2017年04月23日 11:52:54   作者:Android技术之家  
数字跳动效果相信大家应该都见过,在开发加上这种效果后会让ui交互看起来非常不错,所以下面这篇文章主要给大家介绍了Android实现数字跳动的TextView的相关资料,文中给出了详细的示例代码,需要的朋友可以参考学习,下面来一起看看吧。

前言

本文介绍的是Android如何实现数字跳动效果的TextView,主要运用了DancingNumberView,DancingNumberView是一个用于跳动显示文本中数字的控件,继承自TextView,这种控件一般用于显示金额等对用户较为敏感的数字,让UI交互更加生动。

它具有以下几点特性:

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

效果图如下

导入使用

Gradle

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

allprojects { 
 repositories { 
  ... 
  maven { url "https://jitpack.io" } 
 } 
} 

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

dependencies { 
  compile 'com.github.JianxunRao:DancingNumberView:V1.0.1' 
} 

使用方式

通过XML布局

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

通过Java代码

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

关键代码

/** 
* 文本中的数字开始跳动 
 
*/ 
 
public void dance() { 
 
text = getText().toString(); 
 
numbers=new ArrayList<>(); 
 
Pattern pattern = Pattern.compile("\\d+(\\.\\d+)?"); 
 
Matcher matcher=pattern.matcher(text); 
 
while (matcher.find()){ 
 
numbers.add(Float.parseFloat(matcher.group())); 
 
} 
 
textPattern = text.replaceAll("\\d+(\\.\\d+)?",PLACEHOLDER); 
 
numberTemp=new float[numbers.size()]; 
 
ObjectAnimator objectAnimator=ObjectAnimator.ofFloat(this,"factor",0,1); 
 
objectAnimator.setDuration(duration); 
 
objectAnimator.setInterpolator(new AccelerateDecelerateInterpolator()); 
 
objectAnimator.start(); 
 
} 
 
/** 
 
* 获取算数因子 
 
* @return 算数因子 
 
*/ 
 
public float getFactor() { 
 
return factor; 
 
} 
 
/** 
 
* 设置算数因子,为ObjectAnimator调用 
 
* @see ObjectAnimator 
 
* @param factor 算数因子 
 
*/ 
 
public void setFactor(float factor) { 
 
String textNow=textPattern; 
 
this.factor = factor; 
 
for (int i=0;i<numberTemp.length;i++){ 
 
numberTemp[i]=numbers.get(i)*factor; 
 
textNow=textNow.replaceFirst(PLACEHOLDER,String.format(format,numberTemp[i])); 
 
} 
 
setText(textNow); 
 
} 

总结

以上就是这篇文章的全部内容了,希望本文的内容对各位Android开发者们能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

相关文章

  • Android高级动画篇之SVG矢量动画范例

    Android高级动画篇之SVG矢量动画范例

    矢量动画即是在计算机中使用数学方程来描述屏幕上复杂的曲线,利用图形的抽象运动特征来记录变化的画面信息的动画,本篇带你了解在Android中的矢量动画
    2021-11-11
  • Android中Socket的应用分析

    Android中Socket的应用分析

    这篇文章主要介绍了Android中Socket的应用,结合实例形式分析了Android中socket通信的实现技巧与相关注意事项,需要的朋友可以参考下
    2016-10-10
  • Android 快速实现防止网络重复请求&按钮重复点击的方法

    Android 快速实现防止网络重复请求&按钮重复点击的方法

    下面小编就为大家分享一篇Android 快速实现防止网络重复请求&按钮重复点击的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • Android自定义ListView实现下拉刷新上拉加载更多

    Android自定义ListView实现下拉刷新上拉加载更多

    Listview现在用的很少了,基本都是使用Recycleview,但是不得不说Listview具有划时代的意义,我们可以自己添加下拉刷新,上拉加载更多功能。本文就来利用自定义ListView实现下拉刷新上拉加载更多效果,需要的可以参考一下
    2022-10-10
  • Android实现获取短信验证码并自动填写功能

    Android实现获取短信验证码并自动填写功能

    这篇文章主要为大家详细介绍了Android实现获取短信验证码并自动填写功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • Jetpack Compose实现点击事件click的多种方法

    Jetpack Compose实现点击事件click的多种方法

    这篇文章主要介绍了Jetpack Compose实现点击事件的多种方法,Jetpack Compose是一款基于Kotlin的声明式UI工具包,可以方便地创建漂亮的用户界面,下面我们就来看看Jetpack Compose添加点击事件都可以怎么实现
    2024-02-02
  • 关于Android Activity之间跳转问题(Intent)

    关于Android Activity之间跳转问题(Intent)

    这篇文章主要介绍了Android Activity之间跳转Intent,当一个Acitivity需要启动另一个Activity时,通过Intent来表达自己的意图,告知系统启动哪个Activity,本文给大家详细讲解,需要的朋友可以参考下
    2022-10-10
  • Android中Glide加载圆形图片和圆角图片实例代码

    Android中Glide加载圆形图片和圆角图片实例代码

    本篇文章主要介绍了Android中Glide加载圆形图片和圆角图片实例代码,具体一定的参考价值,有兴趣的可以了解一下
    2017-05-05
  • Android调用系统图片裁剪限定尺寸及7.0照相问题的解决方法

    Android调用系统图片裁剪限定尺寸及7.0照相问题的解决方法

    这篇文章主要介绍了Android调用系统图片裁剪限定尺寸,及7.0照相问题的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-07-07
  • Android启动优化之延时加载的步骤详解

    Android启动优化之延时加载的步骤详解

    这篇文章主要给大家介绍了关于Android启动优化之延时加载的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-02-02

最新评论