自定义TextViw实现文字描边功能

博客介绍了一种实现特定运行效果的思路,即把两个等同的TextView叠放并设置不同颜色。具体步骤为实现TextView子类,实例化描边的TextView并配置,测量显示范围使新view与父View一致,确定显示位置,且sTextView.draw(canvas)要在super.onDraw(canvas)前执行。
  • 运行效果
    在这里插入图片描述

  • 思路

  • 如果把两个等同的textviewd叠在一起,并给定不同颜色,这样既可以实现

  • 首先实现TextView的子类,并实例化描边的TextView,设置相关的配置

public class YXJMEView extends TextView {

    private TextView sTextView;

    public YXJMEView(Context context) {
        this(context,null);
    }


    public YXJMEView(Context context, AttributeSet attrs) {
        this(context, attrs,0);
    }
    
    public YXJMEView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        sTextView = new TextView(context,attrs,defStyleAttr);
        Paint paint = sTextView.getPaint();
        paint.setStyle(Paint.Style.STROKE);
        //描边的宽度
        paint.setStrokeWidth(10);
        
        sTextView.setTextColor(Color.BLUE);
        sTextView.setGravity(getGravity());
    }
    }

  • 测量TextView的显示范围,创建的新view必须要和父View一样(范围,值)
   @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
        CharSequence str = sTextView.getText();
        if (sTextView!=null||!sTextView.equals(str)){
            sTextView.setText(getText());
            postInvalidate();
        }
        sTextView.measure(widthMeasureSpec,heightMeasureSpec);
    }
  • 显示的位置
   @Override
    public void setLayoutParams(ViewGroup.LayoutParams params) {
        super.setLayoutParams(params);
        sTextView.setLayoutParams(params);
    }


    @Override
    protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
        super.onLayout(changed, left, top, right, bottom);
        sTextView.layout(left,top,right,bottom);
    }

  • 最后 sTextView.draw(canvas)一定要在super.onDraw(canvas);之前执行

    @Override
    protected void onDraw(Canvas canvas) {
        sTextView.draw(canvas);
        super.onDraw(canvas);
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

将哥哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值