字体描边 终极版

package com.joyodream.common.view;

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;

/**
 * 
 * 描边,默认是灰色描边
 * 
 * @author lipeilong
 *
 */
public class JDStrokeTextView extends TextView {
     
    private TextView borderText = null;
    private final int STROKE_WIDTH        = 6;  // 线宽度
 
    public JDStrokeTextView(Context context) {
        super(context);
        borderText = new TextView(context);
        init();
    }
 
    public JDStrokeTextView(Context context, AttributeSet attrs) {
        super(context, attrs);
        borderText = new TextView(context,attrs);
        init();
    }
 
    public JDStrokeTextView(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(STROKE_WIDTH);                                  
        tp1.setStyle(Style.STROKE);                             
        borderText.setTextColor(0xff333333);  
        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();        
        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+STROKE_WIDTH, bottom);
        borderText.layout(left, top, right+STROKE_WIDTH, bottom);// 总要,否则会截断部分文字
    }
 
    @Override
    protected void onDraw(Canvas canvas) {
        borderText.draw(canvas);
        super.onDraw(canvas);
    }
 
}

网上找的几种解决方案中,这个是最靠谱的了。使用系统自带的阴影也是可以实现部分效果,看情况选择使用

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
字体描边算法是一种在字体文字周围添加边框的技术。在计算机图形学中,描边算法被广泛应用于字体设计和文字处理领域。 字体描边算法的目的是增加文字的可读性和视觉效果,使文字在背景中更加突出,同时使整个设计更加美观。描边算法通过在字体文字周围添加一层边框,扩展文字的形状,增加了文字的边缘对比度和清晰度。 字体描边算法的具体实现使用C语言编程。在C语言中,可以通过使用图形库(如OpenGL、DirectX等)来实现描边效果。描边算法的实现主要包括以下步骤: 1. 读取字体文件:首先,需要读取字体文件,获取字体的轮廓数据和字符信息。 2. 字符轮廓细化:对于每个字符,需要对其轮廓进行细化处理,以得到更加平滑的边缘。这可以通过Bresenham直线算法或Bezier曲线等数学方法来实现。 3. 边缘扩展:在细化后的字符轮廓周围添加边缘。这可以通过扩展轮廓的方式实现,例如,可以向外扩展轮廓的每个点,以生成边框。 4. 边缘着色:为边框添加颜色,通常选择和字体颜色相近的颜色,以保持视觉统一性。 5. 字符叠加:将扩展后的字符轮廓和原始字符叠加在一起,以形成描边效果。 6. 输出结果:最后,将描边后的字符渲染到屏幕上或输出到图片文件中,以供使用。 总的来说,字体描边算法是一种通过在字体文字周围添加边框来改善文字可读性和视觉效果的技术。它在计算机图形学中得到广泛应用,并以C语言为基础实现,通过对字符轮廓的细化、边缘扩展和着色等步骤实现描边效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值