关闭

android_文本垂直滚动

210人阅读 评论(0) 收藏 举报
分类:


这个自定义view主要实现的是垂直文本自动滚动,当文本高度超出垂直高度时自动滚动。也可以修改成其他条件触发滚动。参考了网上一篇文章,找不到出处了。


package com.serviatech.mediaplayer.view;

import com.serviatech.mediaplayer.utils.Logcat;

import android.content.Context;
import android.graphics.Color;
import android.graphics.Typeface;
import android.os.Handler;
import android.util.AttributeSet;
import android.view.Gravity;
import android.widget.ScrollView;
import android.widget.TextView;

/**
 * 里面有一个textview,当textview文字高度小于1080时,设置textview为1080高度,如果大于就开始滚动
 */
public class AutoScrollView extends ScrollView {

	private final Handler handler = new Handler();
	private long duration = 50;
	private boolean isScrolled = false;
	private int currentIndex = 0;
	private long period = 1000;
	private int currentY = -1;

	private float mTextSize;
	private int mTextColor;
	private Typeface mTypeface;
	private String string;
	private Context mContext;

	public AutoScrollView(Context context) {
		this(context, null);
		init(context);
	}

	public AutoScrollView(Context context, AttributeSet attrs) {
		this(context, attrs, 0);
		init(context);
	}

	public AutoScrollView(Context context, AttributeSet attrs, int defStyle) {
		super(context, attrs, defStyle);
		init(context);
	}

	public void init(Context context) {
		this.mContext = context;

		mTextSize = 50;
		mTextColor = Color.RED;
		mTypeface = Typeface.DEFAULT;
	}

	// /////////////////////////////////

	public void setTextSize(float textSize) {
		this.mTextSize = textSize;
		caculate();
	}

	public void setTextColor(int textColor) {
		this.mTextColor = textColor;
	}

	public void setTypeface(Typeface typeface) {
		this.mTypeface = typeface;
		caculate();
	}

	public void setText(String string) {
		this.string = string;
		caculate();
	}

	public void setBackgroundColor(int color) {
		setBackgroundColor(color);
	}

	// /////////////////////////////////
	/**
	 * 计算是否需要滚动
	 * 
	 * @data 2016-5-27 上午9:21:51
	 */
	public void caculate() {

		stopScroll();
		final TextView textView = new TextView(mContext);
		textView.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT,
				LayoutParams.WRAP_CONTENT));
		textView.setTextSize(mTextSize);
		textView.setTextColor(mTextColor);
		textView.setTypeface(mTypeface);
		textView.setText(string);
		textView.setGravity(Gravity.CENTER);
		removeAllViews();
		addView(textView);

		new Thread() {

			@Override
			public void run() {
				super.run();

				try {
					sleep(200);// 必须要休眠一段时间
					Logcat.d("@@@",
							"textView.getHeight(): " + textView.getHeight()
									+ ",getHeight(): " + getHeight());
					if (textView.getHeight() > getHeight()) {
						autoScroll();
					} else {
						stopScroll();
					}
				} catch (Exception e) {
				}
			}
		}.start();
	}

	private void stopScroll() {
		isScrolled = false;
	}

	private void autoScroll() {

		isScrolled = true;
		handler.postDelayed(new Runnable() {
			@Override
			public void run() {
				boolean flag = isScrolled;
				if (flag) {
					// Log.d("test", "currentY = " + currentY
					// + "  getScrollY() = " + getScrollY());
					if (currentY == getScrollY()) {
						try {
							Thread.sleep(period);
						} catch (InterruptedException e) {
							e.printStackTrace();
						}
						currentIndex = 0;
						scrollTo(0, 0);
						handler.postDelayed(this, period);
					} else {
						currentY = getScrollY();
						handler.postDelayed(this, duration);
						currentIndex++;
						scrollTo(0, currentIndex * 1);
					}
				} else {
					// currentIndex = 0;
					// scrollTo(0, 0);
				}
			}
		}, duration);
	}
	// ////////////////////////////////

}


使用


    <com.serviatech.mediaplayer.view.AutoScrollView
        android:id="@+id/tv_emergen"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_centerInParent="true"
        android:background="#fff"
        android:fillViewport="true"
        android:gravity="center"
        android:text="遇到紧急情况!!!"
        android:textColor="#f00"
        android:textSize="50sp"
        android:visibility="gone" />




0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

使用VerticalRollingTextView实现单行文字垂直滚动

VerticalRollingTextView是一个竖直方向无限循环滚动显示单行文本的控件。非常轻量级,直接继承View实现,使用Paint绘制文本,不依赖任何第三方。 开源项目地址: htt...
  • ruancoder
  • ruancoder
  • 2016-09-09 17:52
  • 3061

JavaScript实现竖直文本滚动

var stopscroll = false; var scrollContHeight = 95; //滚动区域的高度 var scrollContWidth = 230; //滚动区域的宽...
  • u011043843
  • u011043843
  • 2014-06-12 15:22
  • 1252

自定义垂直滚动切换TextView

很多app的首页都会有一个用于显示热点消息的banner,通过垂直切换文本的方式动态展示消息。垂直切换的方式可以有效利用空间显示更多的内容,动态的效果也更能吸引用户的注意力。        实现这个...
  • goodlixueyong
  • goodlixueyong
  • 2016-03-03 00:41
  • 3479

android TextView 垂直自动滚动字幕实现

http://www.voidcn.com/blog/cuiran/article/p-27628.html 参考网上一些做法然后进行了修改, 首先继承TextView /** ...
  • qq_35114086
  • qq_35114086
  • 2016-11-25 09:37
  • 1164

水平/垂直滚动联动

证券炒股软件经常会遇到有很多Tab要显示,使得控件的上下/垂直滚动联动经常要使用到,比如撤单,查询等业务都要用到这个控件,今天刚好项目没那么紧,就把这个控件的实现总结一下。 先看看我们实现后的效果 ...
  • jiang547860818
  • jiang547860818
  • 2016-11-15 21:09
  • 507

Android控件——ViewFlipper的使用,垂直滚动广告条

1 前言之前开发过一个TextView的滚动显示,但是局限性比较大,只能显示文字,不能显示图片等其他View。对比淘宝App的淘宝头条,发现显示的内容挺丰富的。网上搜索了下资料发现android自带的...
  • qiyei2009
  • qiyei2009
  • 2017-01-17 19:46
  • 1173

Bootstrap创建垂直滚动监听

Bootstrap Example body { position: relative; } #section1 {padding-top:50px...
  • u010002184
  • u010002184
  • 2017-07-02 20:22
  • 227

安卓控件使用系列22:ScrollView垂直滚动控件的使用方法

在使用安卓系统的时候,我们经常看到当一些图片和文字不能全部显示在屏幕上的时候就会出现向下滑动的效果,那么下面将这样的实现方式分享给大家。 这里的例子实现的是很多图片的显示,已经超过了屏幕的高度,通过...
  • luoshiwutai
  • luoshiwutai
  • 2015-10-03 11:40
  • 520

iOS - 支持水平 / 垂直显示自动滚动的跑马灯控件 --- SKAutoScrollLabel 的使用和实现

原文链接:http://www.jianshu.com/p/7221bc08f26a SKAutoScrollLabel 是一个同时支持水平 / 垂直两种类型的 “跑马灯” 效果的自动滚动 UILa...
  • qq_34047841
  • qq_34047841
  • 2017-04-20 10:42
  • 764

Android自定义垂直滚动自动选择日期控件

项目中需要一个日期选择控件,该日期选择控件是垂直滚动,停止滚动时需要校正日期数字位置,自动选择离中心位置最近的数字。可能有其他的应用场景,分享给各位,可以修改或应用于你自己的项目。
  • xuwei527
  • xuwei527
  • 2013-09-26 14:39
  • 8868
    个人资料
    • 访问:298679次
    • 积分:4774
    • 等级:
    • 排名:第7013名
    • 原创:147篇
    • 转载:264篇
    • 译文:1篇
    • 评论:16条
    文章分类
    最新评论