类似滑动苹果解锁Text

这里我们来自定义一个闪光的textview,非常简单~

--------------自定义TextView---------

import android.content.Context;  
import android.graphics.Canvas;  
import android.graphics.LinearGradient;  
import android.graphics.Matrix;  
import android.graphics.Paint;  
import android.graphics.Shader;  
import android.util.AttributeSet;  
import android.widget.TextView;  
  
public class MyTextView extends TextView {  
  
    private LinearGradient mLinearGradient;  
    private Matrix mGradientMatrix;  
    private Paint mPaint;  
    private int mViewWidth = 0;  
    private int mTranslate = 0;  
  
    private boolean mAnimating = true;  
  
    public MyTextView(Context context, AttributeSet attrs) {  
        super(context, attrs);  
    }  
  
    @Override  
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {  
        super.onSizeChanged(w, h, oldw, oldh);  
        if (mViewWidth == 0) {  
            mViewWidth = getMeasuredWidth();  
            if (mViewWidth > 0) {  
                mPaint = getPaint();  
                mLinearGradient = new LinearGradient(-mViewWidth, 0, 0, 0,  
                        new int[] { 0x33ffffff, 0xffffffff, 0x33ffffff },  
                        new float[] { 0, 0.5f, 1 }, Shader.TileMode.CLAMP);  
                mPaint.setShader(mLinearGradient);  
                mGradientMatrix = new Matrix();  
            }  
        }  
    }  
  
    @Override  
    protected void onDraw(Canvas canvas) {  
        super.onDraw(canvas);  
        if (mAnimating && mGradientMatrix != null) {  
            mTranslate += mViewWidth / 10;  
            if (mTranslate > 2 * mViewWidth) {  
                mTranslate = -mViewWidth;  
            }  
            mGradientMatrix.setTranslate(mTranslate, 0);  
            mLinearGradient.setLocalMatrix(mGradientMatrix);  
            postInvalidateDelayed(50);  
        }  
    }  
  
}  

如何引用该布局呢?

该类的包名再加上类名com.hao.view.MyTextView 
com.hao.view包名   MyTextView 类名
大概就到这吧!!试着实现一下吧~~~
                                                                       小伙伴们有好看的特效或有更好的效果,留下博客哦~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值