Android实现文字滚动播放效果的代码

来自:网络
时间:2020-10-14
阅读:

在开发时,我们会遇到文字过长,TextView不能完全展示,但又不想文字换行展示,这样有时会影响美观。这时我们就需要文字滚动播放,让用户可以看到所有的文字。

话不多说,直接上代码:

import android.content.Context;
import android.util.AttributeSet;
import android.widget.TextView;

public class MarqueTextView extends TextView {
 public MarqueTextView(Context context, AttributeSet attrs, int defStyle) {
 super(context, attrs, defStyle);
 }
 public MarqueTextView(Context context, AttributeSet attrs) {
 super(context, attrs);
 }
 public MarqueTextView(Context context) {
 super(context);
 }
 @Override
 public boolean isFocused() {
 //true表示获取焦点
 return true;
 }
}

使用方法:

<com.xxx.MarqueTextView
 android:singleLine="true"
 android:marqueeRepeatLimit="marquee_forever"
 android:ellipsize="marquee"/>

ps:下面看下android 横向滚动文字的实现

android 横向滚动文字的实现

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.view.Display;
import android.view.WindowManager;
import android.widget.TextView;

public class MarqueeTextView extends TextView {
 /**
  * 文字长度
  */
 private float textLength = 0f;
 /**
  * 滚动条长度
  */
 private float viewWidth = 0f;
 /**
  * 文本x轴 的坐标
  */
 private float tx = 0f;
 /**
  * 文本Y轴的坐标
  */
 private float ty = 0f;
 /**
  * 文本当前长度
  */
 private float temp_tx1 = 0.0f;
 /**
  * 文本当前变换的长度
  */
 private float temp_tx2 = 0x0f;
 /**
  * 文本滚动开关
  */
 private boolean isStarting = false;
 /**
  * 画笔对象
  */
 private Paint paint = null;
 /**
  * 显示的文字
  */
 private String text = "";
 /**
  * 文本滚动速度
  **/
 private float sudu;

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

 /**
  * 初始化自动滚动条,每次改变文字内容时,都需要重新初始化一次
  *
  * @param windowManager 获取屏幕
  * @param text   显示的内容
  * @param su   文字滚动的速度
  */
 public void initScrollTextView(WindowManager windowManager, String text, float su) {
  // 得到画笔,获取父类的textPaint
  paint = this.getPaint();
  // 得到文字
  this.text = text;
  this.sudu = su;
  textLength = paint.measureText(text);// 获得当前文本字符串长度
  viewWidth = this.getWidth();// 获取宽度return mRight - mLeft;
  if (viewWidth == 0) {
   // 获取当前屏幕的属性
   Display display = windowManager.getDefaultDisplay();
   viewWidth = display.getWidth();// 获取屏幕宽度 viewWidth 是滚动的开始位置,需要修改的
   // 可再此入手
  }
  tx = textLength;
  temp_tx1 = viewWidth + textLength;
  temp_tx2 = viewWidth + textLength * 2;// 自己定义,文字变化多少
  // // 文字的大小+距顶部的距离
  ty = this.getTextSize() + this.getPaddingTop();
 }

 /**
  * 开始滚动
  */
 public void starScroll() {
  // 开始滚动
  isStarting = true;
  this.invalidate();// 刷新屏幕
 }

 /**
  * 停止方法,停止滚动
  */
 public void stopScroll() {
  // 停止滚动
  isStarting = false;
  this.invalidate();// 刷新屏幕
 }

 /**
  * 重写onDraw方法
  */
 @Override
 protected void onDraw(Canvas canvas) {
  if (isStarting) {
   // A-Alpha透明度/R-Read红色/g-Green绿色/b-Blue蓝色
   //paint.setARGB(255, 200, 200, 200);
   canvas.drawText(text, temp_tx1 - tx, ty, paint);
   tx += sudu;
   // 当文字滚动到屏幕的最左边
   if (tx > temp_tx2) {
    // 把文字设置到最右边开始
    tx = textLength;
   }
   this.invalidate();// 刷新屏幕
  }
  super.onDraw(canvas);
 }
}

使用:

MarqueeTextView marqueeTextView = contentView.findViewById(R.id.five_text__view);
marqueeTextView.initScrollTextView(getWindowManager(), "滚动文字", 1);
marqueeTextView.setText("");
marqueeTextView.starScroll();
返回顶部
顶部