Android基于TextView实现的跑马灯效果实例

本文实例讲述了Android基于TextView实现的跑马灯效果。分享给大家供大家参考,具体如下:

package sweet.venst.act;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.os.Parcel;
import android.os.Parcelable;
import android.util.AttributeSet;
import android.util.DisplayMetrics;
import android.view.Display;
import android.view.View;
import android.view.WindowManager;
import android.view.View.MeasureSpec;
import android.view.View.OnClickListener;
import android.widget.TextView;
public class AutoScrollTextView extends TextView {
 public final static String TAG = AutoScrollTextView.class.getSimpleName();
 private float textLength = 0f;// 文本长度
 private int viewWidth = 0;
 private int viewHight = 300;
 private float step = 0f;// 文字的横坐标
 private float y = 0f;// 文字的纵坐标
 private float temp_view_plus_text_length = 0.0f;// 用于计算的临时变量
 private float temp_view_plus_two_text_length = 0.0f;// 用于计算的临时变量
 public boolean isStarting = false;// 是否开始滚动
 private Paint paint = null;// 绘图样式
 private String text = "";// 文本内容
 public AutoScrollTextView(Context context)
 {
 super(context);
 }
 public AutoScrollTextView(Context context, AttributeSet attrs)
 {
 super(context, attrs);
 }
 public AutoScrollTextView(Context context, AttributeSet attrs, int defStyle)
 {
 super(context, attrs, defStyle);
 }
 @Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec)
 {
 // TODO Auto-generated method stub
 super.onMeasure(widthMeasureSpec, heightMeasureSpec);
 int measureWidth = measureWidth(widthMeasureSpec);
 int measureHight = measureHeight(heightMeasureSpec);
 // int measureWidth = 1024;
 // int measureHight = 300;
 viewWidth = measureWidth;
 viewHight = measureHight;
 setMeasuredDimension(viewWidth, viewHight);
 }
 private int measureWidth(int widthMeasureSpec)
 {
 int specMode = MeasureSpec.getMode(widthMeasureSpec);
 int specSize = MeasureSpec.getSize(widthMeasureSpec);
 if (specMode == MeasureSpec.UNSPECIFIED) {
  return viewWidth;
 }
 else  {
   return viewWidth;
  }
 }
 private int measureHeight(int widthMeasureSpec) {
 int specMode = MeasureSpec.getMode(widthMeasureSpec);
 int specSize = MeasureSpec.getSize(widthMeasureSpec);
 if (specMode == MeasureSpec.UNSPECIFIED) {
  return viewHight;
 } else {
  return viewHight;
 }
 }
 public void setScrollText(String text)
 {
 this.text = text;
 inittextLength(text);
 // invalidate();
 }
 public void init(Context cx) {
 paint = getPaint();
 paint.setTextSize(40);
 paint.setColor(Color.WHITE);
 text = getText().toString();
 textLength = paint.measureText(text);
 viewWidth = getWidth();
 if (viewWidth == 0) {
  DisplayMetrics dm = new DisplayMetrics();
  dm = cx.getApplicationContext().getResources().getDisplayMetrics();
  viewWidth = dm.widthPixels;
 }
 step = textLength;
 temp_view_plus_text_length = viewWidth + textLength;
 temp_view_plus_two_text_length = viewWidth + textLength * 2;
 y = getTextSize() + getPaddingTop();
 }
 private void inittextLength(String text) {
 textLength = paint.measureText(text);
 step = textLength;
 temp_view_plus_text_length = viewWidth + textLength;
 temp_view_plus_two_text_length = viewWidth + textLength * 2;
 }
 @Override
 public Parcelable onSaveInstanceState() {
 Parcelable superState = super.onSaveInstanceState();
 SavedState ss = new SavedState(superState);
 ss.step = step;
 ss.isStarting = isStarting;
 return ss;
 }
 @Override
 public void onRestoreInstanceState(Parcelable state) {
 if (!(state instanceof SavedState)) {
  super.onRestoreInstanceState(state);
  return;
 }
 SavedState ss = (SavedState) state;
 super.onRestoreInstanceState(ss.getSuperState());
 step = ss.step;
 isStarting = ss.isStarting;
 }
 public static class SavedState extends BaseSavedState {
 public boolean isStarting = false;
 public float step = 0.0f;
 SavedState(Parcelable superState) {
  super(superState);
 }
 @Override
 public void writeToParcel(Parcel out, int flags) {
  super.writeToParcel(out, flags);
  out.writeBooleanArray(new boolean[] { isStarting });
  out.writeFloat(step);
 }
 public static final Parcelable.Creator<SavedState> CREATOR = new Parcelable.Creator<SavedState>() {
  public SavedState[] newArray(int size) {
  return new SavedState[size];
  }
  public SavedState createFromParcel(Parcel in) {
  return new SavedState(in);
  }
 };
 private SavedState(Parcel in) {
  super(in);
  boolean[] b = null;
  in.readBooleanArray(b);
  if (b != null && b.length > 0)
  isStarting = b[0];
  step = in.readFloat();
 }
 }
 public void startScroll() {
 isStarting = true;
 // invalidate();
 }
 public void stopScroll() {
 isStarting = false;
 // invalidate();
 }
 public void onDraw(Canvas canvas) {
 canvas.save();
 canvas.drawText(text, temp_view_plus_text_length - step, y, paint);
 if (!isStarting) {
  return;
 }
 step += 3.2;// 0.5为文字滚动速度。
 if (step > temp_view_plus_two_text_length)
  step = textLength;
 canvas.restore();
// invalidate();
 postInvalidate();
 }
}

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android开发入门与进阶教程》、《Android多媒体操作技巧汇总(音频,视频,录音等)》、《Android基本组件用法总结》、《Android视图View技巧总结》、《Android布局layout技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

(0)

相关推荐

  • Android 实现不依赖焦点和选中的TextView跑马灯

    前言 之前有写一篇TextView跑马灯的效果,后来实际项目中有发现新的问题,比如还是无法自动跑,文本超过了显示区域就截取的问题,今天换了一种思路来实现,更简单更好用. 正文 代码实现: public class MarqueeTextView extends TextView { /** 是否停止滚动 */ private boolean mStopMarquee; private String mText; private float mCoordinateX; private float

  • Android实现图文垂直跑马灯效果

    最近在维护老项目,老项目有一个地方需要修改,就是垂直跑马灯的问题,之前的垂直跑马灯是只有文字跑马灯,新版需要加上. 之前是用的MarqueeView,看了下源代码是只支持文字的,于是我就改了下原作者的源代码. MarqueeView类之前作者的 // 创建ViewFlipper下的TextView private TextView createTextView(CharSequence text, int position) { TextView tv = new TextView(mConte

  • Android自定义View实现纵向跑马灯效果详解

    首先看看效果图(录制的gif有点卡,真实的效果还是很流畅的) 实现思路 通过上面的gif图可以得出结论,其实它就是同时绘制两条文本信息,然后通过动画不断的改变两条文本信息距离顶部的高度,以此来实现滚动的效果. 具体实现 首先定义一些要用到的属性 <declare-styleable name="MarqueeViewStyle"> <attr name="textSize" format="dimension" /> &l

  • Android基于TextView属性android:ellipsize实现跑马灯效果的方法

    本文实例讲述了Android基于TextView属性android:ellipsize实现跑马灯效果的方法.分享给大家供大家参考,具体如下: Android系统中TextView实现跑马灯效果,必须具备以下几个条件: 1.android:ellipsize="marquee" 2.TextView必须单行显示,即内容必须超出TextView大小 3.TextView要获得焦点才能滚动 XML代码: android:ellipsize="marquee", andro

  • Android TextView跑马灯效果实现方法

    本文实例讲述了Android TextView跑马灯效果实现方法.分享给大家供大家参考,具体如下: public class MyTextView extends TextView{ public MyTextView(Context context, AttributeSet attrs) { super(context, attrs); // TODO Auto-generated constructor stub } public MyTextView(Context context, A

  • Android TextView实现跑马灯效果的方法

    本文为大家分享一个非常简单但又很常用的控件,跑马灯状态的TextView.当要显示的文本长度太长,又不想换行时用它来显示文本,一来可以完全的显示出文本,二来效果也挺酷,实现起来超级简单,所以,何乐不为.先看下效果图: 代码实现 TextView自带了跑马灯功能,只要把它的ellipsize属性设置为marquee就可以了.但有个前提,就是TextView要处于被选中状态才能有效果,看到这,我们就很自然的自定义一个控件,写出以下代码: public class MarqueeTextView ex

  • Android基于TextView不获取焦点实现跑马灯效果

    本文实例讲述了Android基于TextView不获取焦点实现跑马灯效果.分享给大家供大家参考,具体如下: 1. 写一个类继承TextView package com.example.tt; import android.content.Context; import android.graphics.Rect; import android.util.AttributeSet; import android.widget.TextView; public class ScrollingText

  • Android自定义View实现竖直跑马灯效果案例解析

    首先给出跑马灯效果图 中间的色块是因为视频转成GIF造成的失真,自动忽略哈. 大家知道,横向的跑马灯android自带的TextView就可以实现,详情请百度[Android跑马灯效果].但是竖直的跑马灯效果原生Android是不支持的.网上也有很多网友实现了自定义的效果,但是我一贯是不喜欢看别人的代码,所以这篇博客的思路完全是我自己的想法哈. 首先,我们需要给自定义的控件梳理一下格局,如下图所示: 1.首先我们将控件分为三个区块,上面绿色部分为消失不可见的块,中间黑色部分为可见区域,下面红色部

  • Android 中TextView中跑马灯效果的实现方法

     条件: 1.android:ellipsize="marquee" 2.TextView必须单行显示,即内容必须超出TextView大小 3.TextView要获得焦点才能滚动 mTVText.setText("超过文本长度的数据"); mTVText.setSingleLine(true);设置单行显示 mTVText.setEllipsize(TruncateAt.MARQUEE);设置跑马灯显示效果 TextView.setHorizontallyScrol

  • Android实现跑马灯效果的方法

    本文实例讲述了Android实现跑马灯效果的方法.分享给大家供大家参考.具体如下: 运行效果截图如下: 直接在布局里写代码就好了: <TextView android:id="@+id/menu_desc" android:layout_width="300dip" android:layout_height="wrap_content" android:text="温馨提示:左右滑动更改菜单,点击进入" android

随机推荐