一、概述
由于业务需要,各端之间统一字体(Android、IOS、PC、网页)。所以android也需要替换成特定的字体。
以后有可能还会增加其他的字体。
方案:
使用LayoutInflaterCompat.setFactory2来全局替换字体。这样做的好处是可以一次性的替换大部分的字体。剩余的个性化字体再单独适配。
这样效率最高,最省时间。
二、代码示例
1.在BaseActivity中加入
//全局字体设置
LayoutInflaterCompat.setFactory2(getLayoutInflater(), getLayoutFactory2());
2.自定义一个类继承LayoutInflater.Factory2接口
private LayoutInflater.Factory2 getLayoutFactory2() { return new TextViewFontProxy(); } private class TextViewFontProxy implements LayoutInflater.Factory2 { @Nullable @Override public View onCreateView(@Nullable View parent, @NonNull String name, @NonNull Context context, @NonNull AttributeSet attrs) { return getProxyView(name, context, attrs); } @Nullable @Override public View onCreateView(@NonNull String name, @NonNull Context context, @NonNull AttributeSet attrs) { return getProxyView(name, context, attrs); } } private View getProxyView(@NonNull String name, @NonNull Context context, @NonNull AttributeSet attrs){ switch(name){ case "TextView": return new SiYuanBlackBodyTextView(context, attrs); case "EditText": return new SiYuanBlackBodyEditText(context, attrs); } return null; }
3.自定义一个字体类
/** * 思源黑体,自定义字体 */ class SiYuanBlackBodyTextView : AppCompatTextView { private val fontPath = "font/source_han_sans_cn_bold.otf" constructor(context: Context, attrs: AttributeSet?, defStyleAttr: Int) : super( context, attrs, defStyleAttr ) { setTypeFace() } constructor(context: Context, attrs: AttributeSet?) : super(context, attrs) { setTypeFace() } constructor(context: Context) : super(context) { setTypeFace() } private fun setTypeFace() { try { includeFontPadding = false val typeface = Typeface.createFromAsset(context.assets, fontPath) setTypeface(typeface) } catch (ignored: Throwable) { } } }
三、问题补充
这里需要注意一下字体的上下填充,思源合体默认上下填充是非常大的。如果不做适配直接回影响全局的布局。
这里在设置字体的时候加入includeFontPadding = false即可。作用:去掉字体上下填充
标签:return,NonNull,字体,attrs,context,Android,全局,name From: https://www.cnblogs.com/tony-yang-flutter/p/18291383