热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

TextView实现打印机效果

首先申明,这篇文章不是我写的,我是对着大神的博客,对着写了一遍而已!感谢写这篇文章的作者,其原创博客地址为:http:www.jianshu.comp4d987769785

首先申明,这篇文章不是我写的,我是对着大神的博客,对着写了一遍而已!
感谢写这篇文章的作者,其原创博客地址为:
http://www.jianshu.com/p/4d987769785c

其示意图如下:
这里写图片描述

其自定义TextView的代码如下:

/**
* Created by pxw on 2017/6/12.
* 打印机效果TextView
*/


public class FadeInTextView extends TextView {

//绘制显示的文字
private StringBuffer mStringBuffer = new StringBuffer();
//矩形
private Rect textRect = new Rect();
//定义文字的个数
private int textCount;
//属性动画-值动画
private ValueAnimator textAnimation;
//每个字出现的时间
private int duration = 300;
//当前显示的字的索引
private int currentIndex = -1;
//字的数组
private String[] arr;
//接口对象
private TextAnimationListener textAnimationListener;
public FadeInTextView(Context context) {
super(context);
}

public FadeInTextView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
}

public FadeInTextView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}

public FadeInTextView setTextAnimationListener(TextAnimationListener textAnimationListener){
this.textAnimatiOnListener= textAnimationListener;
return this;
}
//绘制显示的文字
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
if(mStringBuffer != null) {
drawText(canvas,mStringBuffer.toString());
}
}

private void drawText(Canvas canvas, String str) {
//设置文字绘制的区域
textRect.left = getPaddingLeft();
textRect.top = getPaddingTop();
textRect.right = getWidth()-getPaddingRight();
textRect.bottom = getHeight()-getPaddingBottom();
//获取画笔
TextPaint paint = getPaint();
//描述画笔对象的属性特征,计算位置的坐标
Paint.FontMetrics fOntMetrics= paint.getFontMetrics();
//TODO 不是特别明白为啥要除以2
int baseLine = (int) ((textRect.bottom+textRect.top-fontMetrics.bottom-fontMetrics.top)/2);
//文字绘制到整个布局的中心位置
canvas.drawText(str,getPaddingLeft(),baseLine,paint);
}

//利用属性动画冬天改变绘制的文字,文字逐个显示动画,通过插值的方式改变数据源
private void initAnimation(){
//从0到textCount -1,是设置从第一个字到最后一个字的变化因子,获取单个字符
textAnimation = ValueAnimator.ofInt(0,textCount-1);
//执行的总时间就是每个字的时间乘以字数
textAnimation.setDuration(textCount*duration);
//通过插值器来控制来匀速显示文字
textAnimation.setInterpolator(new LinearInterpolator());
//监听动画更新过程
textAnimation.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator animation) {
int index = (int) animation.getAnimatedValue();
Log.e("index",index+"");
//过滤去重,保证每个字只重绘一次
if(currentIndex != index) {
mStringBuffer.append(arr[index]);

currentIndex = index;
Log.e("index",index+"index");
//所有文字都显成之后进度回调结束动画
if(currentIndex == textCount -1) {
if(textAnimationListener != null) {
textAnimationListener.annimationFinish();
}
}
//不断通知重新绘制
invalidate();
}
}
});
}
//设置逐渐显示的字符串,对外提供的方法
public FadeInTextView setTextString(String textString){
if(textString != null) {
//总字数
textCount = textString.length();
//存放单个字的数组
arr = new String[textCount];
for (int i = 0; i //通过循环,截取
arr[i] = textString.substring(i,i+1);
}
//初始化
initAnimation();
}
return this;
}

//开启动画
public FadeInTextView startFadeInAnimation(){
if(textAnimation != null) {
//动画开启的时候参数都设置成初始状态,设置长度为及索引
mStringBuffer.setLength(0);
currentIndex = -1;
textAnimation.start();
}
return this;
}

//停止动画
public FadeInTextView stopFadeInAnimation(){
if(textAnimation != null) {
textAnimation.end();
}
return this;
}
//回调接口
interface TextAnimationListener{
void annimationFinish();
}
}

调用方法为:

fadeInTextView.setTextString("自定义view实现字符串逐字显示")
.startFadeInAnimation()
.setTextAnimationListener(new FadeInTextView.TextAnimationListener() {
@Override
public void annimationFinish() {

}
});

以上,即可,
再次感谢原创博客作者


推荐阅读
  • TextView属性详解:autoLink设置  是否当文本为URL链接email电话号码map时,文本显示为可点击的链接。可选值(nonewebemailphonema ... [详细]
  • 方案1<!--#includefile"$path"-->限制:其中$path是无法动态设置的,所以被否决方案2通过WebRequest获取页面内容,然后输出到 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
  • 本文介绍了pack布局管理器在Perl/Tk中的使用方法及注意事项。通过调用pack()方法,可以控制部件在显示窗口中的位置和大小。同时,本文还提到了在使用pack布局管理器时,应注意将部件分组以便在水平和垂直方向上进行堆放。此外,还介绍了使用Frame部件或Toplevel部件来组织部件在窗口内的方法。最后,本文强调了在使用pack布局管理器时,应避免在中间切换到grid布局管理器,以免造成混乱。 ... [详细]
  • OpenMap教程4 – 图层概述
    本文介绍了OpenMap教程4中关于地图图层的内容,包括将ShapeLayer添加到MapBean中的方法,OpenMap支持的图层类型以及使用BufferedLayer创建图像的MapBean。此外,还介绍了Layer背景标志的作用和OMGraphicHandlerLayer的基础层类。 ... [详细]
  • 本文介绍了使用C++Builder实现获取USB优盘序列号的方法,包括相关的代码和说明。通过该方法,可以获取指定盘符的USB优盘序列号,并将其存放在缓冲中。该方法可以在Windows系统中有效地获取USB优盘序列号,并且适用于C++Builder开发环境。 ... [详细]
  • STM32 IO口模拟串口通讯
    转自:http:ziye334.blog.163.comblogstatic224306191201452833850647前阵子,调项目时需要用到低波 ... [详细]
  • 8.2location对象location对象既是window对象的属性,也是document对象的属性.window.location和document.location引用的是同一个对象. ... [详细]
  • 显示中文星期几
    显示中文星期几引自:第一种方法:直接翻译,最笨、最容易想到的方法。Code获得中文星期名称 ... [详细]
  • #region3DES<summary>3DES加密<summary> ... [详细]
  • Android,TextView优雅显示长文本、富文本Android提供了TextView这个类作为Android开发当中展示文字的工作,最近笔者在做类似于一个展示类型的APP,发现TextV ... [详细]
author-avatar
倔强的追求
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有