Android-LinearGradient实现TextView字体渐变的效果

熟话说,没图我说个XX,所以我这儿配备一张动态图片:



看了这张效果图,你应该明天我们今天要做一个什么样的东西了。

首先,我们需要知道  LinearGradient这个  类:这个类叫作线性渲染,LinearGradient的作用是实现某一区域内颜色的线性渐变效果,及我们上面看到的效果,主要就是使用它来完成的。

然后,我们下面看下这个类的继承关系:


可以看出,这个类提供了两个构造方法:

参数说明:

参数x0:表示渐变的起始点x坐标;
参数y0:表示渐变的起始点y坐标;
参数x1:表示渐变的终点x坐标;
参数y1:表示渐变的终点y坐标;
参数colors:表示渐变的颜色数组;
参数positions:用来指定颜色数组的相对位置;
参数  color0:  表示渐变开始颜色;
参数  color1:  表示渐变结束颜色;
参数tile:表示平铺方式

Shader.TileMode有3种参数可供选择,分别为CLAMPREPEATMIRROR

CLAMP的作用:是如果渲染器超出原始边界范围,则会复制边缘颜色对超出范围的区域进行着色

REPEAT的作用是:在横向和纵向上以平铺的形式重复渲染位图

MIRROR的作用是:在横向和纵向上以镜像的方式重复渲染位图


注意:通常,参数positions设为null,表示颜色数组以斜坡线的形式均匀分布。


下面是源码:
01 public class GradientTextView extends TextView
02 {
03  
04     private LinearGradient mLinearGradient;
05     private Matrix mGradientMatrix;
06     private Paint mPaint;
07     private int mViewWidth = 0;
08     private int mTranslate = 0;
09  
10     private boolean mAnimating = true;
11  
12     public GradientTextView(Context context, AttributeSet attrs)
13     {
14         super(context, attrs);
15     }
16  
17     @Override
18     protected void onSizeChanged(int w, int h, int oldw, int oldh)
19     {
20         super.onSizeChanged(w, h, oldw, oldh);
21         if (mViewWidth == 0)
22         {
23             //getWidth得到是某个view的实际尺寸.
24             //getMeasuredWidth是得到某view想要在parent view里面占的大小.
25             mViewWidth = getMeasuredWidth();
26             if (mViewWidth > 0)
27             {
28                 mPaint = getPaint();
29                 //线性渐变
30                 mLinearGradient = new LinearGradient(-mViewWidth, 000new int[]
31                 0x33ffffff0xffffffff0x33ffffff }, new float[]
32                 00.5f, 1 }, Shader.TileMode.CLAMP);
33                 mPaint.setShader(mLinearGradient);
34                 mGradientMatrix = new Matrix();
35             }
36         }
37     }
38  
39     @Override
40     protected void onDraw(Canvas canvas)
41     {
42         super.onDraw(canvas);
43         if (mAnimating && mGradientMatrix != null)
44         {
45             mTranslate += mViewWidth / 10;
46             if (mTranslate > 2 * mViewWidth)
47             {
48                 mTranslate = -mViewWidth;
49             }
50             mGradientMatrix.setTranslate(mTranslate, 0);
51             mLinearGradient.setLocalMatrix(mGradientMatrix);
52             //50ms刷新一次
53             postInvalidateDelayed(50);
54         }
55     }
56  
57 }

首先,onSizeChanged()里面,测量child iew在parent view中占的宽度。

并且给LinearGradient设置渐变的颜色值,位置,以及初始渐变的位置

这个渐变的初始位置是在手机屏幕的外面x=(-mViewWidth,0)就是屏幕外面,这个不难理解。 

onDraw()方法当中通过不断的绘制界面达到我们看到的动画效果,

mTranslate += mViewWidth / 10:表示每一次运动的递增值

if (mTranslate > 2 * mViewWidth)
   {
        mTranslate = -mViewWidth;
   }

这就是结束条件语句当递增值大于两倍child view宽度时候,及回到屏幕的左边

至此,整个就完成了我们开始在文章开头的效果了,你只需要在XML文件当中引用这个类即可。

demo地址:http://download.csdn.net/detail/poison_h/8722249
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值