[Silverlight]奇技银巧系列-6 使用点阵字体(如宋体)及相关方面的技巧
我们知道,Silverlight的默认中文字体是【雅黑】,它是一种矢量字体,有点是可以保证在文字大小变化时也不失真。但是它的效果真的如我们想想中那么好吗?
我们做一个实验,一段简单的XAML
<TextBlock FontSize="14" Text="我是宋体吗ABC?" Margin="30"/>
效果如下图:
看起来还可以,但是做过实际项目开发的各位都清楚,sl中雅黑下的某些字比如:“增”字一类的字变形的比较厉害(虽然sl3有了明显的改善),这很难让我们这些经常和宋体等标准中文字体打交道的人接受。
群里经常有人问:“为啥sl的字体那么模糊啊。sl不能用宋体,真烂!”等等。
其实sl中是绝对可以使用点阵字体的,只不过这个技巧大部分人不太清楚而已。
我们设置一下XAML的FontFamily属性
<TextBlock FontSize="14" FontFamily="SimSun" Text="我是宋体吗ABC?" Margin="30"/>
看效果
怎么样?标准的宋体吧!关键就在于FontFamily的值应该是“SimSun”而不是“宋体”。
不过到了这里,这个解决方案还不是很完美。我们仔细看“ABC”这三个英文,还不如默认的好看呢。这个具体我也不大清楚,不过要解决这个问题我们只需显式的设置英文(比如Arial)字体就可以了。具体设置方法看XAML
<TextBlock FontSize="14" FontFamily="Arial,SimSun" Text="我是宋体吗ABC?" Margin="30"/>
看效果
恩,很完美了哦。
注意FontFamily的顺序和设置方法:两种字体见要以半角逗号(,)分割,而且英文字体必须写在中文字体之前。
OK,希望对大家有用。
提前祝大家元旦快乐!
作者:紫色永恒
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利