Android自定义View实现打字机效果

一、先来看看效果演示

二、实现原理:

这个其实不难实现,通过一个定时器不断调用TextViewsetText就行了,在setText的时候播放打字的音效。

具体代码如下:

import java.util.Timer;
import java.util.TimerTask;

import android.content.Context;
import android.media.MediaPlayer;
import android.text.TextUtils;
import android.util.AttributeSet;
import android.widget.TextView;

import com.uperone.typetextview.R;

/**
 * 模拟打字机效果
 *
 * */
public class TypeTextView extends TextView {
 private Context mContext = null;
 private MediaPlayer mMediaPlayer = null;
 private String mShowTextString = null;
 private Timer mTypeTimer = null;
 private OnTypeViewListener mOnTypeViewListener = null;
 private static final int TYPE_TIME_DELAY = 80;
 private int mTypeTimeDelay = TYPE_TIME_DELAY; // 打字间隔

 public TypeTextView(Context context, AttributeSet attrs, int defStyle) {
  super(context, attrs, defStyle);
  initTypeTextView( context );
 }

 public TypeTextView(Context context, AttributeSet attrs) {
  super(context, attrs);
  initTypeTextView( context );
 }

 public TypeTextView(Context context) {
  super(context);
  initTypeTextView( context );
 }

 public void setOnTypeViewListener( OnTypeViewListener onTypeViewListener ){
  mOnTypeViewListener = onTypeViewListener;
 }

 public void start( final String textString ){
  start( textString, TYPE_TIME_DELAY );
 }

 public void start( final String textString, final int typeTimeDelay ){
  if( TextUtils.isEmpty( textString ) || typeTimeDelay < 0 ){
   return;
  }
  post( new Runnable( ) {
   @Override
   public void run() {
    mShowTextString = textString;
    mTypeTimeDelay = typeTimeDelay;
    setText( "" );
    startTypeTimer( );
    if( null != mOnTypeViewListener ){
     mOnTypeViewListener.onTypeStart( );
    }
   }
  });
 }

 public void stop( ){
  stopTypeTimer( );
  stopAudio();
 }

 private void initTypeTextView( Context context ){
  mContext = context;
 }

 private void startTypeTimer( ){
  stopTypeTimer( );
  mTypeTimer = new Timer( );
  mTypeTimer.schedule( new TypeTimerTask(), mTypeTimeDelay );
 }

 private void stopTypeTimer( ){
  if( null != mTypeTimer ){
   mTypeTimer.cancel( );
   mTypeTimer = null;
  }
 }

 private void startAudioPlayer() {
  stopAudio();
  playAudio( R.raw.type_in );
 }

 private void playAudio( int audioResId ){
  try{
   stopAudio( );
   mMediaPlayer = MediaPlayer.create( mContext, audioResId );
   mMediaPlayer.start( );
  }catch( Exception e ){
   e.printStackTrace();
  }
 }

 private void stopAudio( ){
  if( mMediaPlayer != null && mMediaPlayer.isPlaying( ) ){
   mMediaPlayer.stop( );
   mMediaPlayer.release( );
   mMediaPlayer = null;
  }
 }

 class TypeTimerTask extends TimerTask{
  @Override
  public void run() {
   post(new Runnable( ) {
    @Override
    public void run() {
     if( getText( ).toString( ).length( ) < mShowTextString.length( ) ){
      setText( mShowTextString.substring(0, getText( ).toString( ).length( ) + 1 ) );
      startAudioPlayer();
      startTypeTimer( );
     }else{
      stopTypeTimer( );
      if( null != mOnTypeViewListener ){
       mOnTypeViewListener.onTypeOver( );
      }
     }
    }
   });
  }
 }

 public interface OnTypeViewListener{
  public void onTypeStart( );
  public void onTypeOver( );
 }
}

三、使用说明:

1、在xml文件中定义:

 <com.uperone.typetext.view.TypeTextView
  android:id="@+id/typeTxtId"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:layout_centerVertical="true" />

2、在代码中实例化:

 mTypeTextView = ( TypeTextView )findViewById(R.id.typeTxtId);
 mTypeTextView.setOnTypeViewListener( new OnTypeViewListener( ) {
  @Override
  public void onTypeStart() {
   print( "onTypeStart" );
  }

  @Override
  public void onTypeOver() {
   print( "onTypeOver" );
  }
 });

3、调用start方法:

mTypeTextView.start( TEST_DATA );

四、总结

以上就是Android自定义View实现打字机效果的全部内容,感兴趣的快快自己动手实践起来,希望本文的内容对大家开发Android的时候能有所帮助,如果有疑问可以留言交流。

(0)

相关推荐

  • Android自定义view实现水波纹进度球效果

    今天我们要实现的这个view没有太多交互性的view,所以就继承view. 自定义view的套路,套路很深 1.获取我们自定义属性attrs(可省略) 2.重写onMeasure方法,计算控件的宽和高 3.重写onDraw方法,绘制我们的控件 这么看来,自定义view的套路很清晰嘛. 我们看下今天的效果图,其中一个是放慢的效果(时间调的长) 我们按照套路来. 一.自定义属性 <declare-styleable name="WaveProgressView"> <at

  • Android 自定义View的使用介绍

    在项目开发中,可能系统自带的一些widget不能满足我们的需求,这时就需要自定义View. 通过查看系统中的常用widget如Button,TextView,EditText,他们都继承自View,所以我们在继承自定义View的时候也自然的需要继承View.1.首先新建一个类LView继承自View 复制代码 代码如下: public class LView extends View { private Paint paint; public LView(Context context) {  

  • Android自定义View实现折线图效果

    下面就是结果图(每种状态用一个表情图片表示): 一.主页面的布局文件如下: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height=&quo

  • MPAndroidChart开源图表库的使用介绍之饼状图、折线图和柱状图

    MPAndroidChart开源图表库之饼状图 为大家介绍一款图标开源库MPAndroidChart,它不仅可以在Android设备上绘制各种统计图表,而且可以对图表进行拖动和缩放操作,用起来非常灵活.MPAndroidChart同样拥有常用的图表类型:线型图.饼图.柱状图和散点图. mpandroidchartlibrary.jar包下载地址: https://github.com/PhilJay/MPAndroidChart/releases 下面主要实现以下饼状图: 1.从上面的地址中下载

  • Android自定义View实现圆环交替效果

    下面请先看效果图: 看上去是不很炫的样子,它的实现上也不是很复杂,重点在与onDraw()方法的绘制. 首先是我们的attrs文件: <?xml version="1.0" encoding="utf-8"?> <resources> <attr name="firstColor" format="color"/> <attr name="secondColor"

  • php下实现折线图效果的代码

    <?php   Class ImageReport{  var $X;//图片大小X轴  var $Y;//图片大小Y轴  var $R;//背影色R值  var $G;//...G.  var $B;//...B.  var $TRANSPARENT;//是否透明1或0  var $IMAGE;//图片对像  //-------------------  var $ARRAYSPLIT;//指定用于分隔数值的符号  var $ITEMARRAY;//数值  var $REPORTTYPE;//

  • android自定义进度条渐变色View的实例代码

    最近在公司,项目不是很忙了,偶尔看见一个兄台在CSDN求助,帮忙要一个自定义的渐变色进度条,我当时看了一下进度条,感觉挺漂亮的,就尝试的去自定义view实现了一个,废话不说,先上图吧! 这个自定义的view,完全脱离了android自带的ProgressView,并且没使用一张图片,这样就能更好的降低程序代码上的耦合性! 下面我贴出代码  ,大概讲解一下实现思路吧! 复制代码 代码如下: package com.spring.progressview; import android.conten

  • jQuery实现折线图的方法

    本文实例讲述了jQuery实现折线图的方法.分享给大家供大家参考.具体如下: 效果图如下所示: js引用: 复制代码 代码如下: <script src="Js/Index/jquery-1.5.2.min.js" type="text/javascript"></script>  <script src="js/Index/raphael.2.1.0.min.js" type="text/javascri

  • Android开发之天气趋势折线图

    先来看下效果: 控件内容比较简单,就是一个普通的折线图,上下分别带有数字,点击的时候显示当天温度的差值. 创建一个类继承自View,并添加两个构造方法: public class TrendGraph extends View { public TrendGraph(Context context) { // 在java代码中创建调用 super(context); } public TrendGraph(Context context, AttributeSet attrs) { // 在xm

  • asp.net画曲线图(折线图)代码 详细注释

    复制代码 代码如下: using System; using System.Collections; using System.Configuration; using System.Data; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.HtmlControls; using System.Web.UI.WebControls; using System.Web.UI

随机推荐