Android文字描边

实现文字描边原理不难,就是两个TextView叠在一起
package com.example.testproject;
 
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Paint.Style;
import android.text.TextPaint;
import android.util.AttributeSet;
import android.view.ViewGroup;
import android.widget.TextView;
/*
  * StrokeTextView的目标是给文字描边
  * 实现方法是两个TextView叠加,只有描边的TextView为底,实体TextView叠加在上面
  * 看上去文字就有个不同颜色的边框了
  */
public class StrokeTextView extends TextView {
 
     private TextView borderText = null ; ///用于描边的TextView
 
     public StrokeTextView(Context context) {
         super (context);
         borderText = new TextView(context);
         init();
     }
 
     public StrokeTextView(Context context, AttributeSet attrs) {
         super (context, attrs);
         borderText = new TextView(context,attrs);
         init();
     }
 
     public StrokeTextView(Context context, AttributeSet attrs,
             int defStyle) {
         super (context, attrs, defStyle);
         borderText = new TextView(context,attrs,defStyle);
         init();
     }
 
     public void init(){
         TextPaint tp1 = borderText.getPaint();
         tp1.setStrokeWidth( 4 );                                  //设置描边宽度
         tp1.setStyle(Style.STROKE);                             //对文字只描边
         borderText.setTextColor(getResources().getColor(R.color.border_text));  //设置描边颜色
         borderText.setGravity(getGravity());
     }
 
     @Override
     public void setLayoutParams (ViewGroup.LayoutParams params){
         super .setLayoutParams(params);
         borderText.setLayoutParams(params);
     }
 
     @Override
     protected void onMeasure( int widthMeasureSpec, int heightMeasureSpec) {
         CharSequence tt = borderText.getText();
         
         //两个TextView上的文字必须一致
         if (tt== null || !tt.equals( this .getText())){
             borderText.setText(getText());
             this .postInvalidate();
         }
         super .onMeasure(widthMeasureSpec, heightMeasureSpec);
         borderText.measure(widthMeasureSpec, heightMeasureSpec);
     }
 
     protected void onLayout ( boolean changed, int left, int top, int right, int bottom){
         super .onLayout(changed, left, top, right, bottom);
         borderText.layout(left, top, right, bottom);
     }
 
     @Override
     protected void onDraw(Canvas canvas) {
         borderText.draw(canvas);
         super .onDraw(canvas);
     }
 
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值