自动循环滚动textview

本文介绍了一个自定义的Android TextView组件,能够实现文字自动滚动效果。通过初始化和设置文本内容,可以控制文字从屏幕右侧滚动至左侧,适用于Android应用中需要展示滚动文字场景。

先初始化,在调用

starScroll()即可

代码:

public class AutoScrollTextView 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 = ""; 
   
    public AutoScrollTextView(Context context, AttributeSet attrs) { 
        super(context, attrs); 
    } 
   
    /** 
     * 初始化自动滚动条,每次改变文字内容时,都需要重新初始化一次 
     *  
     * @param windowManager 
     *            获取屏幕 
     * @param text 
     *            显示的内容 
     */ 
    public void initScrollTextView(WindowManager windowManager, String text) { 
        // 得到画笔,获取父类的textPaint 
        paint = this.getPaint(); 
        // 得到文字 
        this.text = text; 
   
        textLength = paint.measureText(text);// 获得当前文本字符串长度 
        viewWidth = this.getWidth();// 获取宽度return mRight - mLeft; 
        if (viewWidth == 0) { 
            if (windowManager != null) { 
                // 获取当前屏幕的属性 
                Display display = windowManager.getDefaultDisplay(); 
                viewWidth = display.getWidth();// 获取屏幕宽度 
   
            } 
        } 
        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 += 1; 
            // 当文字滚动到屏幕的最左边 
            if (tx >= temp_tx2) { 
                // 把文字设置到最右边开始 
                tx = temp_tx1 - viewWidth; 
            } 
            this.invalidate();// 刷新屏幕 
        } 
        super.onDraw(canvas); 
    } 
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值