1. 背景

 项目中按钮数不确定,有时一排按钮显示过多,button宽度过短导致里面字换行。

2. 思路

通过计算字体宽度与button的宽度的比率,然后一乘。(这让我想起多年以前写的C#计算字体,感兴趣的可以看我以前的帖子)

3. 实现

/**
 * 
 * 字体大小自适应按钮宽度的按钮
 * 如果需要动态变化可以调用invalidate()方法来触发onDraw()重绘
 * @author qiyant
 */
public class AutofitButton extends AppCompatButton {

    public AutofitButton(Context context) {
        super(context);
        init(context, null);
    }

    public AutofitButton(Context context, AttributeSet attrs) {
        super(context, attrs);
        init(context, attrs);
    }

    private void init(Context context, AttributeSet attrs) {


    }

    @Override
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {
        super.onSizeChanged(w, h, oldw, oldh);
        invalidate();
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        autoFitTextSize();
    }

    /**
     * 计算fontSize通过text、width、padding
     */
    private void autoFitTextSize() {
        Paint p = getPaint();
        p.setTypeface(getTypeface());
        p.setTextSize(getTextSize());
        float needWidth = getPaddingLeft() + getPaddingRight() + p.measureText(getText().toString());
//        Log.e("autofitbutton", needWidth + "," + needWidth / getWidth() + "," + getTextSize());
//这里是为了防止一个按钮时,按钮内字体过大
        if (needWidth > getWidth())
//Math.floor是为了防止算出的值有小数导致绘画的字体闪烁
            setTextSize(TypedValue.COMPLEX_UNIT_PX, (float) Math.floor(getTextSize() * (getWidth() / needWidth)));
    }
}

over

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐