我写了一个类来解决这个限制。它似乎在有限的测试中工作,但我还没有编写我需要它的应用程序。请注意,它假定自定义字体可用作资产,并进行静态调用以检索应用程序的上下文(它需要访问资源)。更好的方法是将上下文传递给构造函数..
import android.content.Context;
public class TypefaceResourceSpan extends MetricAffectingSpan implements ParcelableSpan {
private String resourceName_;
private Typeface tf_;
public TypefaceResourceSpan(String resourceName) {
super();
resourceName_=resourceName;
tf_=createTypeface(resourceName_);
}
public TypefaceResourceSpan(Parcel src) {
resourceName_ = src.readString();
tf_=createTypeface(resourceName_);
}
private Typeface createTypeface(String resourceName) {
Typeface result=null;
Context c=TikunKorimMain.getAppContext();
if (c==null) {
Log.e("TypefaceResourceSpan", "Application context is null!");
}
AssetManager am=c.getAssets();
if (am==null) {
Log.e("TypefaceResourceSpan", "AssetManager is null!");
}
result=Typeface.createFromAsset(am, resourceName);
return result;
}
public void writeToParcel(Parcel dest, int flags) {
dest.writeString(resourceName_);
}
@Override
public void updateMeasureState(TextPaint p) {
Typeface old=p.getTypeface();
if ( old != null && !old.isBold() && tf_.isBold() ) {
p.setFakeBoldText(true);
}
if ( old != null && !old.isItalic() && tf_.isItalic() ) {
p.setTextSkewX(-0.25f);
}
p.setTypeface(tf_);
}
@Override
public void updateDrawState(TextPaint tp) {
Typeface old=tp.getTypeface();
if ( old != null && !old.isBold() && tf_.isBold() ) {
tp.setFakeBoldText(true);
}
if ( old != null && !old.isItalic() && tf_.isItalic() ) {
tp.setTextSkewX(-0.25f);
}
tp.setTypeface(tf_);
}
public int getSpanTypeId() {
// TODO does this work???!?
return 123456;
}
public int describeContents() {
return 0;
}
}