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选择与上传图片之ImagePicker教程

    Android选择与上传图片之ImagePicker教程

    这篇文章主要介绍了在Android中对于图片的选择与上传方法,本文介绍了ImagePicker的相关使用教程,学习Android的同学进来看看吧
    2021-08-08
  • 详解 android 光线传感器 light sensor的使用

    详解 android 光线传感器 light sensor的使用

    这篇文章主要介绍了详解 android 光线传感器 light sensor的使用的相关资料,需要的朋友可以参考下
    2017-06-06
  • Flutter常用的布局和事件示例详解

    Flutter常用的布局和事件示例详解

    这篇文章主要给大家介绍了关于Flutter常用的布局和事件的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Flutter具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • Kotlin WorkManager使用方法详解

    Kotlin WorkManager使用方法详解

    这篇文章主要介绍了Kotlin WorkManager使用方法,WorkManager是 安卓体系结构之一,也是Android JetPack的一部分。WorkManager用于可延期并需要保证执行的后台工作
    2023-01-01
  • Android Jetpack库剖析之Lifecycle组件篇

    Android Jetpack库剖析之Lifecycle组件篇

    本章也是带来了Jetpack中我认为最重要的架构组件Lifecycle的原理探索,至于为什么觉得它是最重要是因为像ViewModel,LiveData这些组件也依赖于Lifecycle来感知宿主的生命周期,那么本章我们带着几个问题来探索一下这个组件
    2022-07-07
  • ReactiveCocoa代码实践之-RAC网络请求重构

    ReactiveCocoa代码实践之-RAC网络请求重构

    这篇文章主要介绍了ReactiveCocoa代码实践之-RAC网络请求重构 的相关资料,需要的朋友可以参考下
    2016-04-04
  • Android仿今日头条APP实现下拉导航选择菜单效果

    Android仿今日头条APP实现下拉导航选择菜单效果

    这篇文章主要为大家详细介绍了Android仿今日头条APP实现下拉导航选择菜单效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • android自定义弹出框样式的实现方法

    android自定义弹出框样式的实现方法

    这篇文章主要为大家详细介绍了android自定义弹出框样式的实现方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • Android gradle配置抽取合并的操作步骤

    Android gradle配置抽取合并的操作步骤

    这篇文章主要介绍了Android gradle配置抽取合并的操作步骤,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-11-11
  • Android studio 引用aar 进行java开发的操作步骤

    Android studio 引用aar 进行java开发的操作步骤

    这篇文章主要介绍了Android studio 引用aar 进行java开发的操作步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09

最新评论